feat:node-modules

This commit is contained in:
houjunxiang
2025-11-24 10:26:18 +08:00
parent 753766893b
commit 8a3e48d856
8825 changed files with 567399 additions and 1 deletions

View File

@@ -0,0 +1,32 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.absBigNumber = absBigNumber;
exports.addBigNumber = addBigNumber;
exports.divideBigNumber = divideBigNumber;
exports.multiplyBigNumber = multiplyBigNumber;
exports.subtractBigNumber = subtractBigNumber;
const signature1 = 'BigNumber';
const signature2 = 'BigNumber, BigNumber';
function absBigNumber(a) {
return a.abs();
}
absBigNumber.signature = signature1;
function addBigNumber(a, b) {
return a.add(b);
}
addBigNumber.signature = signature2;
function subtractBigNumber(a, b) {
return a.sub(b);
}
subtractBigNumber.signature = signature2;
function multiplyBigNumber(a, b) {
return a.mul(b);
}
multiplyBigNumber.signature = signature2;
function divideBigNumber(a, b) {
return a.div(b);
}
divideBigNumber.signature = signature2;

29
node_modules/mathjs/lib/cjs/plain/bignumber/index.js generated vendored Normal file
View File

@@ -0,0 +1,29 @@
"use strict";
var _interopRequireDefault = require("@babel/runtime/helpers/interopRequireDefault");
Object.defineProperty(exports, "__esModule", {
value: true
});
var _exportNames = {
bignumber: true
};
exports.bignumber = bignumber;
var _decimal = _interopRequireDefault(require("decimal.js"));
var _arithmetic = require("./arithmetic.js");
Object.keys(_arithmetic).forEach(function (key) {
if (key === "default" || key === "__esModule") return;
if (Object.prototype.hasOwnProperty.call(_exportNames, key)) return;
if (key in exports && exports[key] === _arithmetic[key]) return;
Object.defineProperty(exports, key, {
enumerable: true,
get: function () {
return _arithmetic[key];
}
});
});
// TODO: this is ugly. Instead, be able to pass your own isBigNumber function to typed?
const BigNumber = _decimal.default.clone();
BigNumber.prototype.isBigNumber = true;
function bignumber(x) {
return new BigNumber(x);
}

334
node_modules/mathjs/lib/cjs/plain/number/arithmetic.js generated vendored Normal file

File diff suppressed because it is too large Load Diff

64
node_modules/mathjs/lib/cjs/plain/number/bitwise.js generated vendored Normal file
View File

@@ -0,0 +1,64 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.bitAndNumber = bitAndNumber;
exports.bitNotNumber = bitNotNumber;
exports.bitOrNumber = bitOrNumber;
exports.bitXorNumber = bitXorNumber;
exports.leftShiftNumber = leftShiftNumber;
exports.rightArithShiftNumber = rightArithShiftNumber;
exports.rightLogShiftNumber = rightLogShiftNumber;
var _number = require("../../utils/number.js");
const n1 = 'number';
const n2 = 'number, number';
function bitAndNumber(x, y) {
if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {
throw new Error('Integers expected in function bitAnd');
}
return x & y;
}
bitAndNumber.signature = n2;
function bitNotNumber(x) {
if (!(0, _number.isInteger)(x)) {
throw new Error('Integer expected in function bitNot');
}
return ~x;
}
bitNotNumber.signature = n1;
function bitOrNumber(x, y) {
if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {
throw new Error('Integers expected in function bitOr');
}
return x | y;
}
bitOrNumber.signature = n2;
function bitXorNumber(x, y) {
if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {
throw new Error('Integers expected in function bitXor');
}
return x ^ y;
}
bitXorNumber.signature = n2;
function leftShiftNumber(x, y) {
if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {
throw new Error('Integers expected in function leftShift');
}
return x << y;
}
leftShiftNumber.signature = n2;
function rightArithShiftNumber(x, y) {
if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {
throw new Error('Integers expected in function rightArithShift');
}
return x >> y;
}
rightArithShiftNumber.signature = n2;
function rightLogShiftNumber(x, y) {
if (!(0, _number.isInteger)(x) || !(0, _number.isInteger)(y)) {
throw new Error('Integers expected in function rightLogShift');
}
return x >>> y;
}
rightLogShiftNumber.signature = n2;

View File

@@ -0,0 +1,39 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.combinationsNumber = combinationsNumber;
var _number = require("../../utils/number.js");
var _product = require("../../utils/product.js");
function combinationsNumber(n, k) {
if (!(0, _number.isInteger)(n) || n < 0) {
throw new TypeError('Positive integer value expected in function combinations');
}
if (!(0, _number.isInteger)(k) || k < 0) {
throw new TypeError('Positive integer value expected in function combinations');
}
if (k > n) {
throw new TypeError('k must be less than or equal to n');
}
const nMinusk = n - k;
let answer = 1;
const firstnumerator = k < nMinusk ? nMinusk + 1 : k + 1;
let nextdivisor = 2;
const lastdivisor = k < nMinusk ? k : nMinusk;
// balance multiplications and divisions to try to keep intermediate values
// in exact-integer range as long as possible
for (let nextnumerator = firstnumerator; nextnumerator <= n; ++nextnumerator) {
answer *= nextnumerator;
while (nextdivisor <= lastdivisor && answer % nextdivisor === 0) {
answer /= nextdivisor;
++nextdivisor;
}
}
// for big n, k, floating point may have caused weirdness in remainder
if (nextdivisor <= lastdivisor) {
answer /= (0, _product.product)(nextdivisor, lastdivisor);
}
return answer;
}
combinationsNumber.signature = 'number, number';

10
node_modules/mathjs/lib/cjs/plain/number/constants.js generated vendored Normal file
View File

@@ -0,0 +1,10 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.tau = exports.pi = exports.phi = exports.e = void 0;
const pi = exports.pi = Math.PI;
const tau = exports.tau = 2 * Math.PI;
const e = exports.e = Math.E;
const phi = exports.phi = 1.6180339887498948; // eslint-disable-line no-loss-of-precision

104
node_modules/mathjs/lib/cjs/plain/number/index.js generated vendored Normal file

File diff suppressed because it is too large Load Diff

27
node_modules/mathjs/lib/cjs/plain/number/logical.js generated vendored Normal file
View File

@@ -0,0 +1,27 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.andNumber = andNumber;
exports.notNumber = notNumber;
exports.orNumber = orNumber;
exports.xorNumber = xorNumber;
const n1 = 'number';
const n2 = 'number, number';
function notNumber(x) {
return !x;
}
notNumber.signature = n1;
function orNumber(x, y) {
return !!(x || y);
}
orNumber.signature = n2;
function xorNumber(x, y) {
return !!x !== !!y;
}
xorNumber.signature = n2;
function andNumber(x, y) {
return !!(x && y);
}
andNumber.signature = n2;

View File

@@ -0,0 +1,85 @@
"use strict";
Object.defineProperty(exports, "__esModule", {
value: true
});
exports.gammaG = void 0;
exports.gammaNumber = gammaNumber;
exports.lgammaN = exports.lgammaG = exports.gammaP = void 0;
exports.lgammaNumber = lgammaNumber;
exports.lnSqrt2PI = exports.lgammaSeries = void 0;
var _number = require("../../utils/number.js");
var _product = require("../../utils/product.js");
/* eslint-disable no-loss-of-precision */
function gammaNumber(n) {
let x;
if ((0, _number.isInteger)(n)) {
if (n <= 0) {
return isFinite(n) ? Infinity : NaN;
}
if (n > 171) {
return Infinity; // Will overflow
}
return (0, _product.product)(1, n - 1);
}
if (n < 0.5) {
return Math.PI / (Math.sin(Math.PI * n) * gammaNumber(1 - n));
}
if (n >= 171.35) {
return Infinity; // will overflow
}
if (n > 85.0) {
// Extended Stirling Approx
const twoN = n * n;
const threeN = twoN * n;
const fourN = threeN * n;
const fiveN = fourN * n;
return Math.sqrt(2 * Math.PI / n) * Math.pow(n / Math.E, n) * (1 + 1 / (12 * n) + 1 / (288 * twoN) - 139 / (51840 * threeN) - 571 / (2488320 * fourN) + 163879 / (209018880 * fiveN) + 5246819 / (75246796800 * fiveN * n));
}
--n;
x = gammaP[0];
for (let i = 1; i < gammaP.length; ++i) {
x += gammaP[i] / (n + i);
}
const t = n + gammaG + 0.5;
return Math.sqrt(2 * Math.PI) * Math.pow(t, n + 0.5) * Math.exp(-t) * x;
}
gammaNumber.signature = 'number';
// TODO: comment on the variables g and p
const gammaG = exports.gammaG = 4.7421875;
const gammaP = exports.gammaP = [0.99999999999999709182, 57.156235665862923517, -59.597960355475491248, 14.136097974741747174, -0.49191381609762019978, 0.33994649984811888699e-4, 0.46523628927048575665e-4, -0.98374475304879564677e-4, 0.15808870322491248884e-3, -0.21026444172410488319e-3, 0.21743961811521264320e-3, -0.16431810653676389022e-3, 0.84418223983852743293e-4, -0.26190838401581408670e-4, 0.36899182659531622704e-5];
// lgamma implementation ref: https://mrob.com/pub/ries/lanczos-gamma.html#code
// log(2 * pi) / 2
const lnSqrt2PI = exports.lnSqrt2PI = 0.91893853320467274178;
const lgammaG = exports.lgammaG = 5; // Lanczos parameter "g"
const lgammaN = exports.lgammaN = 7; // Range of coefficients "n"
const lgammaSeries = exports.lgammaSeries = [1.000000000190015, 76.18009172947146, -86.50532032941677, 24.01409824083091, -1.231739572450155, 0.1208650973866179e-2, -0.5395239384953e-5];
function lgammaNumber(n) {
if (n < 0) return NaN;
if (n === 0) return Infinity;
if (!isFinite(n)) return n;
if (n < 0.5) {
// Use Euler's reflection formula:
// gamma(z) = PI / (sin(PI * z) * gamma(1 - z))
return Math.log(Math.PI / Math.sin(Math.PI * n)) - lgammaNumber(1 - n);
}
// Compute the logarithm of the Gamma function using the Lanczos method
n = n - 1;
const base = n + lgammaG + 0.5; // Base of the Lanczos exponential
let sum = lgammaSeries[0];
// We start with the terms that have the smallest coefficients and largest denominator
for (let i = lgammaN - 1; i >= 1; i--) {
sum += lgammaSeries[i] / (n + i);
}
return lnSqrt2PI + (n + 0.5) * Math.log(base) - base + Math.log(sum);
}
lgammaNumber.signature = 'number';

View File

@@ -0,0 +1 @@
"use strict";

Some files were not shown because too many files have changed in this diff Show More