@cortex-js/compute-engine 0.12.7 → 0.13.0
This diff represents the content of publicly available package versions that have been released to one of the supported registries. The information contained in this diff is provided for informational purposes only and reflects changes between package versions as they appear in their respective public registries.
- package/dist/compute-engine.esm.js +341 -70
- package/dist/compute-engine.js +341 -70
- package/dist/compute-engine.min.esm.js +341 -70
- package/dist/compute-engine.min.js +341 -70
- package/dist/math-json.esm.js +2 -2
- package/dist/math-json.js +2 -2
- package/dist/math-json.min.esm.js +2 -2
- package/dist/math-json.min.js +2 -2
- package/dist/types/common/grapheme-splitter.d.ts +1 -1
- package/dist/types/common/signals.d.ts +1 -1
- package/dist/types/common/utils.d.ts +1 -1
- package/dist/types/compute-engine/assume.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/abstract-boxed-expression.d.ts +2 -1
- package/dist/types/compute-engine/boxed-expression/box.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-dictionary.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-domain.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-function-definition.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-function.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-number.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-patterns.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-string.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-symbol-definition.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/boxed-symbol.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/expression-map.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/order.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/serialize.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/utils.d.ts +1 -1
- package/dist/types/compute-engine/boxed-expression/validate.d.ts +1 -1
- package/dist/types/compute-engine/compile.d.ts +3 -0
- package/dist/types/compute-engine/compute-engine.d.ts +2 -2
- package/dist/types/compute-engine/cost-function.d.ts +1 -1
- package/dist/types/compute-engine/domain-utils.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-algebra.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-arithmetic.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-calculus.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-core.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-inequalities.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-logic.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-other.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-sets.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-symbols.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions-trigonometry.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/dictionary/definitions.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/latex-syntax.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/parse-identifier.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/parse.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/public.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/serialize-number.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/serializer-style.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/serializer.d.ts +1 -1
- package/dist/types/compute-engine/latex-syntax/tokenizer.d.ts +1 -1
- package/dist/types/compute-engine/library/arithmetic-add.d.ts +2 -2
- package/dist/types/compute-engine/library/arithmetic-divide.d.ts +1 -1
- package/dist/types/compute-engine/library/arithmetic-multiply.d.ts +1 -1
- package/dist/types/compute-engine/library/arithmetic-power.d.ts +1 -1
- package/dist/types/compute-engine/library/arithmetic.d.ts +1 -1
- package/dist/types/compute-engine/library/calculus.d.ts +1 -1
- package/dist/types/compute-engine/library/collections.d.ts +1 -1
- package/dist/types/compute-engine/library/core.d.ts +1 -1
- package/dist/types/compute-engine/library/domains.d.ts +1 -1
- package/dist/types/compute-engine/library/library.d.ts +1 -1
- package/dist/types/compute-engine/library/logic.d.ts +1 -1
- package/dist/types/compute-engine/library/polynomials.d.ts +1 -1
- package/dist/types/compute-engine/library/random-expression.d.ts +1 -1
- package/dist/types/compute-engine/library/relational-operator.d.ts +1 -1
- package/dist/types/compute-engine/library/sets.d.ts +1 -1
- package/dist/types/compute-engine/library/trigonometry.d.ts +1 -1
- package/dist/types/compute-engine/library/utils.d.ts +1 -1
- package/dist/types/compute-engine/numerics/numeric-bigint.d.ts +1 -1
- package/dist/types/compute-engine/numerics/numeric-bignum.d.ts +1 -1
- package/dist/types/compute-engine/numerics/numeric-complex.d.ts +1 -1
- package/dist/types/compute-engine/numerics/numeric.d.ts +1 -1
- package/dist/types/compute-engine/numerics/primes.d.ts +1 -1
- package/dist/types/compute-engine/numerics/rationals.d.ts +1 -1
- package/dist/types/compute-engine/public.d.ts +1 -1
- package/dist/types/compute-engine/rules.d.ts +1 -1
- package/dist/types/compute-engine/simplify-rules.d.ts +1 -1
- package/dist/types/compute-engine/solve.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/expand.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/flatten.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/negate.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/polynomials.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/product.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/sum.d.ts +1 -1
- package/dist/types/compute-engine/symbolic/utils.d.ts +1 -1
- package/dist/types/compute-engine.d.ts +2 -2
- package/dist/types/math-json/math-json-format.d.ts +1 -1
- package/dist/types/math-json/utils.d.ts +3 -1
- package/dist/types/math-json.d.ts +2 -2
- package/package.json +1 -1
|
@@ -1,4 +1,4 @@
|
|
|
1
|
-
/** CortexJS Compute Engine 0.
|
|
1
|
+
/** CortexJS Compute Engine 0.13.0 */
|
|
2
2
|
var __create = Object.create;
|
|
3
3
|
var __defProp = Object.defineProperty;
|
|
4
4
|
var __getOwnPropDesc = Object.getOwnPropertyDescriptor;
|
|
@@ -3949,6 +3949,14 @@ function symbol(expr) {
|
|
|
3949
3949
|
return null;
|
|
3950
3950
|
return s;
|
|
3951
3951
|
}
|
|
3952
|
+
function isListLike(expr) {
|
|
3953
|
+
if (expr === null)
|
|
3954
|
+
return false;
|
|
3955
|
+
const h = head(expr);
|
|
3956
|
+
if (!h || typeof h !== "string")
|
|
3957
|
+
return false;
|
|
3958
|
+
return /^(List|Sequence|Tuple|Single|Pair|Triple)$/.test(h);
|
|
3959
|
+
}
|
|
3952
3960
|
function keyValuePair(expr) {
|
|
3953
3961
|
const h = head(expr);
|
|
3954
3962
|
if (h === "KeyValuePair" || h === "Tuple" || h === "Pair") {
|
|
@@ -4584,6 +4592,10 @@ var DEFINITIONS_ARITHMETIC = [
|
|
|
4584
4592
|
parse: "ExponentialE",
|
|
4585
4593
|
serialize: "\\exponentialE"
|
|
4586
4594
|
},
|
|
4595
|
+
{
|
|
4596
|
+
trigger: "\\mathrm{e}",
|
|
4597
|
+
parse: "ExponentialE"
|
|
4598
|
+
},
|
|
4587
4599
|
{
|
|
4588
4600
|
kind: "function",
|
|
4589
4601
|
trigger: "exp",
|
|
@@ -4597,6 +4609,10 @@ var DEFINITIONS_ARITHMETIC = [
|
|
|
4597
4609
|
name: "ImaginaryUnit",
|
|
4598
4610
|
trigger: ["\\imaginaryI"]
|
|
4599
4611
|
},
|
|
4612
|
+
{
|
|
4613
|
+
trigger: "\\mathrm{i}",
|
|
4614
|
+
parse: "ImaginaryUnit"
|
|
4615
|
+
},
|
|
4600
4616
|
// Operations
|
|
4601
4617
|
{
|
|
4602
4618
|
/** Could be the determinant if the argument is a matrix */
|
|
@@ -5156,7 +5172,7 @@ function parseSequence(parser, terminator, lhs, prec, sep) {
|
|
|
5156
5172
|
}
|
|
5157
5173
|
return result;
|
|
5158
5174
|
}
|
|
5159
|
-
function
|
|
5175
|
+
function serializeOps(sep = "") {
|
|
5160
5176
|
return (serializer, expr) => (ops(expr) ?? []).map((x) => serializer.serialize(x)).join(sep);
|
|
5161
5177
|
}
|
|
5162
5178
|
var DEFINITIONS_CORE = [
|
|
@@ -5224,22 +5240,19 @@ var DEFINITIONS_CORE = [
|
|
|
5224
5240
|
return "";
|
|
5225
5241
|
const style = serializer.options.groupStyle(expr, serializer.level + 1);
|
|
5226
5242
|
const arg1 = op(expr, 1);
|
|
5227
|
-
|
|
5228
|
-
|
|
5229
|
-
let
|
|
5230
|
-
let
|
|
5231
|
-
let
|
|
5243
|
+
const h1 = head(arg1);
|
|
5244
|
+
const defaultFence = { List: "[],", Sequence: "" }[typeof h1 === "string" ? h1 : ""] ?? "(),";
|
|
5245
|
+
let open = defaultFence[0] ?? "";
|
|
5246
|
+
let close = defaultFence[1] ?? "";
|
|
5247
|
+
let sep = defaultFence[2] ?? "";
|
|
5232
5248
|
if (argCount > 1) {
|
|
5233
5249
|
const op22 = stringValue(op(expr, 2)) ?? "";
|
|
5234
|
-
open = op22[0] ??
|
|
5235
|
-
close = op22[1] ??
|
|
5236
|
-
sep = op22[2] ??
|
|
5250
|
+
open = op22[0] ?? defaultFence[0];
|
|
5251
|
+
close = op22[1] ?? defaultFence[1];
|
|
5252
|
+
sep = op22[2] ?? defaultFence[2];
|
|
5237
5253
|
}
|
|
5238
|
-
const body =
|
|
5239
|
-
serializer.wrapString(body, style,
|
|
5240
|
-
if (!open || !close)
|
|
5241
|
-
return serializer.wrapString(body, style);
|
|
5242
|
-
return `${open} ${body} ${close}`;
|
|
5254
|
+
const body = isListLike(arg1) ? serializeOps(sep)(serializer, arg1) : serializer.serialize(arg1);
|
|
5255
|
+
return serializer.wrapString(body, style, open + close);
|
|
5243
5256
|
}
|
|
5244
5257
|
},
|
|
5245
5258
|
{
|
|
@@ -5340,7 +5353,7 @@ var DEFINITIONS_CORE = [
|
|
|
5340
5353
|
serialize: (serializer, expr) => {
|
|
5341
5354
|
return joinLatex([
|
|
5342
5355
|
"\\lbrack",
|
|
5343
|
-
|
|
5356
|
+
serializeOps(", ")(serializer, expr),
|
|
5344
5357
|
"\\rbrack"
|
|
5345
5358
|
]);
|
|
5346
5359
|
}
|
|
@@ -5378,7 +5391,7 @@ var DEFINITIONS_CORE = [
|
|
|
5378
5391
|
},
|
|
5379
5392
|
{
|
|
5380
5393
|
name: "Sequence",
|
|
5381
|
-
serialize:
|
|
5394
|
+
serialize: serializeOps("")
|
|
5382
5395
|
},
|
|
5383
5396
|
{
|
|
5384
5397
|
trigger: [";"],
|
|
@@ -5508,24 +5521,17 @@ var DEFINITIONS_CORE = [
|
|
|
5508
5521
|
return result;
|
|
5509
5522
|
},
|
|
5510
5523
|
serialize: (serialize2, expr) => {
|
|
5511
|
-
|
|
5512
|
-
|
|
5513
|
-
|
|
5514
|
-
|
|
5515
|
-
|
|
5516
|
-
|
|
5517
|
-
|
|
5518
|
-
|
|
5519
|
-
if (op(row, 2)) {
|
|
5520
|
-
body.push(serialize2.serialize(op(row, 2)));
|
|
5521
|
-
const condition = op(row, 1);
|
|
5522
|
-
if (condition !== null)
|
|
5523
|
-
body.push("&", serialize2.serialize(condition));
|
|
5524
|
-
}
|
|
5524
|
+
const rows = [];
|
|
5525
|
+
const args = ops(expr);
|
|
5526
|
+
if (args) {
|
|
5527
|
+
for (let i = 0; i <= args.length - 2; i += 2) {
|
|
5528
|
+
const row = [];
|
|
5529
|
+
row.push(serialize2.serialize(args[i + 1]));
|
|
5530
|
+
row.push(serialize2.serialize(args[i]));
|
|
5531
|
+
rows.push(row.join("&"));
|
|
5525
5532
|
}
|
|
5526
|
-
rowSep = "\\\\";
|
|
5527
5533
|
}
|
|
5528
|
-
return joinLatex(["\\begin{cases}",
|
|
5534
|
+
return joinLatex(["\\begin{cases}", rows.join("\\\\"), "\\end{cases}"]);
|
|
5529
5535
|
}
|
|
5530
5536
|
}
|
|
5531
5537
|
];
|
|
@@ -7427,11 +7433,6 @@ var DEFAULT_DELIMITER = {
|
|
|
7427
7433
|
"\\rceil": "\\rceil",
|
|
7428
7434
|
"\\rfloor": "\\rfloor"
|
|
7429
7435
|
};
|
|
7430
|
-
function triggerLength(trigger) {
|
|
7431
|
-
if (Array.isArray(trigger))
|
|
7432
|
-
return trigger.length;
|
|
7433
|
-
return 1;
|
|
7434
|
-
}
|
|
7435
7436
|
function addEntry(result, entry, onError) {
|
|
7436
7437
|
const [trigger, indexedEntry] = makeIndexedEntry(entry, onError);
|
|
7437
7438
|
if (indexedEntry === null)
|
|
@@ -7473,7 +7474,7 @@ function addEntry(result, entry, onError) {
|
|
|
7473
7474
|
if (indexedEntry.kind === "matchfix") {
|
|
7474
7475
|
result.matchfix.push(indexedEntry);
|
|
7475
7476
|
} else if (indexedEntry.kind === "environment") {
|
|
7476
|
-
const triggerString = tokensToString(entry.trigger ??
|
|
7477
|
+
const triggerString = tokensToString(entry.trigger ?? []);
|
|
7477
7478
|
if (result.environment.has(triggerString)) {
|
|
7478
7479
|
onError({
|
|
7479
7480
|
severity: "warning",
|
|
@@ -7487,22 +7488,31 @@ function addEntry(result, entry, onError) {
|
|
|
7487
7488
|
result.environment.set(triggerString, indexedEntry);
|
|
7488
7489
|
} else if (trigger) {
|
|
7489
7490
|
console.assert(entry.trigger);
|
|
7490
|
-
const triggerString = tokensToString(entry.trigger ?? "");
|
|
7491
|
-
const n = triggerLength(trigger);
|
|
7492
|
-
result.lookahead = Math.max(result.lookahead, n);
|
|
7493
7491
|
if (indexedEntry.kind === "function") {
|
|
7494
|
-
|
|
7495
|
-
|
|
7492
|
+
console.assert(typeof entry.trigger === "string");
|
|
7493
|
+
const fnName = entry.trigger;
|
|
7494
|
+
if (!result.function.has(fnName))
|
|
7495
|
+
result.function.set(fnName, [indexedEntry]);
|
|
7496
7496
|
else
|
|
7497
|
-
result.function.set(
|
|
7498
|
-
...result.function.get(
|
|
7497
|
+
result.function.set(fnName, [
|
|
7498
|
+
...result.function.get(fnName),
|
|
7499
7499
|
indexedEntry
|
|
7500
7500
|
]);
|
|
7501
7501
|
} else {
|
|
7502
|
+
let triggerString;
|
|
7503
|
+
let tokenCount;
|
|
7504
|
+
if (typeof entry.trigger === "string") {
|
|
7505
|
+
triggerString = entry.trigger;
|
|
7506
|
+
tokenCount = countTokens(triggerString);
|
|
7507
|
+
} else {
|
|
7508
|
+
triggerString = tokensToString(entry.trigger ?? []);
|
|
7509
|
+
tokenCount = entry.trigger.length;
|
|
7510
|
+
}
|
|
7511
|
+
result.lookahead = Math.max(result.lookahead, tokenCount);
|
|
7502
7512
|
const kind2 = indexedEntry.kind;
|
|
7503
|
-
if (result[kind2][
|
|
7504
|
-
result[kind2][
|
|
7505
|
-
const list = result[kind2][
|
|
7513
|
+
if (result[kind2][tokenCount] === void 0)
|
|
7514
|
+
result[kind2][tokenCount] = /* @__PURE__ */ new Map();
|
|
7515
|
+
const list = result[kind2][tokenCount];
|
|
7506
7516
|
if (list.has(triggerString))
|
|
7507
7517
|
list.get(triggerString).push(indexedEntry);
|
|
7508
7518
|
else
|
|
@@ -7582,13 +7592,11 @@ function makeIndexedEntry(entry, onError) {
|
|
|
7582
7592
|
if (result.kind === "expression" && isExpressionEntry(entry)) {
|
|
7583
7593
|
result.serialize = entry.serialize ?? triggerString;
|
|
7584
7594
|
if (typeof result.serialize === "string") {
|
|
7585
|
-
const
|
|
7595
|
+
const serializeStr = result.serialize;
|
|
7586
7596
|
result.serialize = (serializer, expr) => {
|
|
7587
7597
|
if (!head(expr))
|
|
7588
|
-
return
|
|
7589
|
-
return `${serializer.
|
|
7590
|
-
serializeExpr
|
|
7591
|
-
)}${serializer.wrapArguments(expr)}`;
|
|
7598
|
+
return serializeStr;
|
|
7599
|
+
return `${serializeStr}${serializer.wrapArguments(expr)}`;
|
|
7592
7600
|
};
|
|
7593
7601
|
}
|
|
7594
7602
|
{
|
|
@@ -8335,7 +8343,7 @@ var _Parser = class {
|
|
|
8335
8343
|
defs = this.lookAhead().map((x, n) => this._dictionary[kind][n]?.get(x));
|
|
8336
8344
|
}
|
|
8337
8345
|
const result = [];
|
|
8338
|
-
for (let i = defs.length; i > 0; i--) {
|
|
8346
|
+
for (let i = defs.length - 1; i > 0; i--) {
|
|
8339
8347
|
if (defs[i] !== void 0) {
|
|
8340
8348
|
console.assert(Array.isArray(defs[i]));
|
|
8341
8349
|
for (const def of defs[i])
|
|
@@ -10089,14 +10097,16 @@ var Serializer = class {
|
|
|
10089
10097
|
wrapString(s, style, fence) {
|
|
10090
10098
|
if (style === "none")
|
|
10091
10099
|
return s;
|
|
10092
|
-
|
|
10093
|
-
|
|
10100
|
+
if (fence === void 0)
|
|
10101
|
+
fence = "()";
|
|
10102
|
+
const openFence = fence?.[0] ?? ".";
|
|
10103
|
+
const closeFence = fence?.[1] ?? ".";
|
|
10094
10104
|
if ((openFence === "." || closeFence === ".") && style === "paren")
|
|
10095
10105
|
style = "leftright";
|
|
10096
10106
|
if (style === "leftright")
|
|
10097
|
-
return
|
|
10107
|
+
return `\\left${openFence}${s}\\right${closeFence}}`;
|
|
10098
10108
|
if (style === "big")
|
|
10099
|
-
return `${openFence === "." ? "" : `\\Bigl
|
|
10109
|
+
return `${openFence === "." ? "" : `\\Bigl${openFence}`}${s}${closeFence === "." ? "" : `\\Bigr${closeFence}`})`;
|
|
10100
10110
|
return openFence + s + closeFence;
|
|
10101
10111
|
}
|
|
10102
10112
|
wrapArguments(expr) {
|
|
@@ -13149,6 +13159,246 @@ function domainSetsLibrary() {
|
|
|
13149
13159
|
|
|
13150
13160
|
// src/compute-engine/boxed-expression/abstract-boxed-expression.ts
|
|
13151
13161
|
var import_complex6 = __toESM(require_complex());
|
|
13162
|
+
|
|
13163
|
+
// src/compute-engine/compile.ts
|
|
13164
|
+
function compileToJavascript(expr) {
|
|
13165
|
+
const js = compile(expr, expr.freeVars);
|
|
13166
|
+
try {
|
|
13167
|
+
return new Function("_", `return ${js}`);
|
|
13168
|
+
} catch (e) {
|
|
13169
|
+
console.error(`${e}
|
|
13170
|
+
${expr.latex}
|
|
13171
|
+
${js}`);
|
|
13172
|
+
}
|
|
13173
|
+
return void 0;
|
|
13174
|
+
}
|
|
13175
|
+
function compile(expr, freeVars = [], prec = 0) {
|
|
13176
|
+
const f = asFloat(expr);
|
|
13177
|
+
if (f !== null)
|
|
13178
|
+
return f.toString();
|
|
13179
|
+
const s = expr.symbol;
|
|
13180
|
+
if (s !== null) {
|
|
13181
|
+
const result = {
|
|
13182
|
+
True: "true",
|
|
13183
|
+
False: "false",
|
|
13184
|
+
Pi: "Math.PI",
|
|
13185
|
+
ExponentialE: "Math.E",
|
|
13186
|
+
I: "Math.I",
|
|
13187
|
+
NaN: "Number.NaN",
|
|
13188
|
+
ImaginaryUnit: "NaN"
|
|
13189
|
+
}[s];
|
|
13190
|
+
if (result !== void 0)
|
|
13191
|
+
return result;
|
|
13192
|
+
if (freeVars.includes(s))
|
|
13193
|
+
return `_.${s}`;
|
|
13194
|
+
return s;
|
|
13195
|
+
}
|
|
13196
|
+
const str = expr.string;
|
|
13197
|
+
if (str !== null)
|
|
13198
|
+
return JSON.stringify(str);
|
|
13199
|
+
const keys = expr.keys;
|
|
13200
|
+
if (keys !== null) {
|
|
13201
|
+
const result = [];
|
|
13202
|
+
for (const key of keys) {
|
|
13203
|
+
const value = expr.getKey(key);
|
|
13204
|
+
if (value)
|
|
13205
|
+
result.push(`${key}: ${compile(value, freeVars, 0)}`);
|
|
13206
|
+
}
|
|
13207
|
+
return `{${result.join(", ")}}`;
|
|
13208
|
+
}
|
|
13209
|
+
const h = expr.head;
|
|
13210
|
+
if (typeof h === "string") {
|
|
13211
|
+
if (h === "Negate") {
|
|
13212
|
+
const arg = expr.op1;
|
|
13213
|
+
if (arg === null)
|
|
13214
|
+
return "";
|
|
13215
|
+
return `-${compile(arg, freeVars, 3)}`;
|
|
13216
|
+
}
|
|
13217
|
+
if (h === "Error") {
|
|
13218
|
+
return "NaN";
|
|
13219
|
+
}
|
|
13220
|
+
if (h === "Sum")
|
|
13221
|
+
return compileLoop(expr, "+");
|
|
13222
|
+
if (h === "Product")
|
|
13223
|
+
return compileLoop(expr, "*");
|
|
13224
|
+
if (h === "Root") {
|
|
13225
|
+
const arg = expr.op1;
|
|
13226
|
+
if (arg === null)
|
|
13227
|
+
return "";
|
|
13228
|
+
const exp2 = expr.op2;
|
|
13229
|
+
if (exp2 === null)
|
|
13230
|
+
return `Math.sqrt(${compile(arg, freeVars, 0)})`;
|
|
13231
|
+
return `Math.pow(${compile(arg, freeVars)}, 1/${compile(exp2, freeVars)}`;
|
|
13232
|
+
}
|
|
13233
|
+
if (h === "Factorial") {
|
|
13234
|
+
const arg = expr.op1;
|
|
13235
|
+
if (arg === null)
|
|
13236
|
+
return "";
|
|
13237
|
+
return `${compile(arg, freeVars, 3)}!`;
|
|
13238
|
+
}
|
|
13239
|
+
const OPS = {
|
|
13240
|
+
Add: ["+", 1],
|
|
13241
|
+
Subtract: ["-", 1],
|
|
13242
|
+
Multiply: ["*", 2],
|
|
13243
|
+
Divide: ["/", 3]
|
|
13244
|
+
};
|
|
13245
|
+
const op3 = OPS[h];
|
|
13246
|
+
if (op3 !== void 0) {
|
|
13247
|
+
const args2 = expr.ops;
|
|
13248
|
+
if (args2 === null)
|
|
13249
|
+
return "";
|
|
13250
|
+
const result = [];
|
|
13251
|
+
for (const arg of args2)
|
|
13252
|
+
result.push(compile(arg, freeVars, op3[1]));
|
|
13253
|
+
return op3[1] < prec ? `(${result.join(op3[0])})` : result.join(op3[0]);
|
|
13254
|
+
}
|
|
13255
|
+
const fn = {
|
|
13256
|
+
Abs: "Math.abs",
|
|
13257
|
+
Arccos: "Math.acos",
|
|
13258
|
+
Arcosh: "Math.acosh",
|
|
13259
|
+
Arsin: "Math.asin",
|
|
13260
|
+
Arsinh: "Math.asinh",
|
|
13261
|
+
Arctan: "Math.atan",
|
|
13262
|
+
Artanh: "Math.atanh",
|
|
13263
|
+
// Math.cbrt
|
|
13264
|
+
Ceiling: "Math.ceil",
|
|
13265
|
+
Cos: "Math.cos",
|
|
13266
|
+
Cosh: "Math.cosh",
|
|
13267
|
+
Exp: "Math.exp",
|
|
13268
|
+
Floor: "Math.floor",
|
|
13269
|
+
// Math.hypot
|
|
13270
|
+
Ln: "Math.log",
|
|
13271
|
+
Log: "Math.log10",
|
|
13272
|
+
Lb: "Math.log2",
|
|
13273
|
+
Max: "Math.max",
|
|
13274
|
+
Min: "Math.min",
|
|
13275
|
+
Power: "Math.pow",
|
|
13276
|
+
Random: "Math.random",
|
|
13277
|
+
Round: "Math.round",
|
|
13278
|
+
Sgn: "Math.sign",
|
|
13279
|
+
Sin: "Math.sin",
|
|
13280
|
+
Sinh: "Math.sinh",
|
|
13281
|
+
Sqrt: "Math.sqrt",
|
|
13282
|
+
Tan: "Math.tan",
|
|
13283
|
+
Tanh: "Math.tanh"
|
|
13284
|
+
// Factorial: 'factorial', // TODO: implement
|
|
13285
|
+
// Hallucinated by Copilot, but interesting ideas...
|
|
13286
|
+
// Cot: 'Math.cot',
|
|
13287
|
+
// Sec: 'Math.sec',
|
|
13288
|
+
// Csc: 'Math.csc',
|
|
13289
|
+
// ArcCot: 'Math.acot',
|
|
13290
|
+
// ArcSec: 'Math.asec',
|
|
13291
|
+
// ArcCsc: 'Math.acsc',
|
|
13292
|
+
// Coth: 'Math.coth',
|
|
13293
|
+
// Sech: 'Math.sech',
|
|
13294
|
+
// Csch: 'Math.csch',
|
|
13295
|
+
// ArcCoth: 'Math.acoth',
|
|
13296
|
+
// ArcSech: 'Math.asech',
|
|
13297
|
+
// ArcCsch: 'Math.acsch',
|
|
13298
|
+
// Root: 'Math.root',
|
|
13299
|
+
// Gamma: 'Math.gamma',
|
|
13300
|
+
// Erf: 'Math.erf',
|
|
13301
|
+
// Erfc: 'Math.erfc',
|
|
13302
|
+
// Erfi: 'Math.erfi',
|
|
13303
|
+
// Zeta: 'Math.zeta',
|
|
13304
|
+
// PolyGamma: 'Math.polygamma',
|
|
13305
|
+
// HurwitzZeta: 'Math.hurwitzZeta',
|
|
13306
|
+
// DirichletEta: 'Math.dirichletEta',
|
|
13307
|
+
// Beta: 'Math.beta',
|
|
13308
|
+
// Binomial: 'Math.binomial',
|
|
13309
|
+
// Mod: 'Math.mod',
|
|
13310
|
+
// Quotient: 'Math.quotient',
|
|
13311
|
+
// GCD: 'Math.gcd',
|
|
13312
|
+
// LCM: 'Math.lcm',
|
|
13313
|
+
// Divisors: 'Math.divisors',
|
|
13314
|
+
// PrimeQ: 'Math.isPrime',
|
|
13315
|
+
// PrimePi: 'Math.primePi',
|
|
13316
|
+
// Prime: 'Math.prime',
|
|
13317
|
+
// NextPrime: 'Math.nextPrime',
|
|
13318
|
+
// PreviousPrime: 'Math.prevPrime',
|
|
13319
|
+
// PrimePowerQ: 'Math.isPrimePower',
|
|
13320
|
+
// PrimePowerPi: 'Math.primePowerPi',
|
|
13321
|
+
// PrimePower: 'Math.primePower',
|
|
13322
|
+
// NextPrimePower: 'Math.nextPrimePower',
|
|
13323
|
+
// PreviousPrimePower: 'Math.prevPrimePower',
|
|
13324
|
+
// PrimeFactors: 'Math.primeFactors',
|
|
13325
|
+
// DivisorSigma: 'Math.divisorSigma',
|
|
13326
|
+
// DivisorSigma0: 'Math.divisorSigma0',
|
|
13327
|
+
// DivisorSigma1: 'Math.divisorSigma1',
|
|
13328
|
+
// DivisorSigma2: 'Math.divisorSigma2',
|
|
13329
|
+
// DivisorSigma3: 'Math.divisorSigma3',
|
|
13330
|
+
// DivisorSigma4: 'Math.divisorSigma4',
|
|
13331
|
+
// DivisorCount: 'Math.divisorCount',
|
|
13332
|
+
// DivisorSum: 'Math.divisorSum',
|
|
13333
|
+
// MoebiusMu: 'Math.moebiusMu',
|
|
13334
|
+
// LiouvilleLambda: 'Math.liouvilleLambda',
|
|
13335
|
+
// CarmichaelLambda: 'Math.carmichaelLambda',
|
|
13336
|
+
// EulerPhi: 'Math.eulerPhi',
|
|
13337
|
+
// EulerPsi: 'Math.eulerPsi',
|
|
13338
|
+
// EulerGamma: 'Math.eulerGamma',
|
|
13339
|
+
// HarmonicNumber: 'Math.harmonicNumber',
|
|
13340
|
+
// BernoulliB: 'Math.bernoulliB',
|
|
13341
|
+
// StirlingS1: 'Math.stirlingS1',
|
|
13342
|
+
// StirlingS2: 'Math.stirlingS2',
|
|
13343
|
+
// BellB: 'Math.bellB',
|
|
13344
|
+
// BellNumber: 'Math.bellNumber',
|
|
13345
|
+
// LahS: 'Math.lahS',
|
|
13346
|
+
// LahL: 'Math.lahL',
|
|
13347
|
+
// RiemannR: 'Math.riemannR',
|
|
13348
|
+
// RiemannZeta: 'Math.riemannZeta',
|
|
13349
|
+
// RiemannXi: 'Math.riemannXi',
|
|
13350
|
+
// RiemannH: 'Math.riemannH',
|
|
13351
|
+
// RiemannZ: 'Math.riemannZ',
|
|
13352
|
+
// RiemannS: 'Math.riemannS',
|
|
13353
|
+
// RiemannXiZero: 'Math.riemannXiZero',
|
|
13354
|
+
// RiemannZetaZero: 'Math.riemannZetaZero',
|
|
13355
|
+
// RiemannHZero: 'Math.riemannHZero',
|
|
13356
|
+
// RiemannSZero: 'Math.riemannSZero',
|
|
13357
|
+
// RiemannPrimeCount: 'Math.riemannPrimeCount',
|
|
13358
|
+
// RiemannRLog: 'Math.riemannRLog',
|
|
13359
|
+
// RiemannRLogDerivative: 'Math.riemannRLogDerivative',
|
|
13360
|
+
// RiemannRLogZero: 'Math.riemannRLogZero',
|
|
13361
|
+
// RiemannRLogZeroDerivative: 'Math.riemannRLogZeroDerivative',
|
|
13362
|
+
// RiemannRZero: 'Math.riemannRZero',
|
|
13363
|
+
// RiemannRDerivative: 'Math.riemannRDerivative',
|
|
13364
|
+
// RiemannXiZeroDerivative: 'Math.riemannXiZeroDerivative',
|
|
13365
|
+
// RiemannZetaZeroDerivative: 'Math.riemannZetaZeroDerivative',
|
|
13366
|
+
// RiemannHZeroDerivative: 'Math.riemannHZeroDerivative',
|
|
13367
|
+
// RiemannSZeroDerivative: 'Math.riemannSZeroDerivative',
|
|
13368
|
+
// RiemannSZeroDerivative2: 'Math.riemannSZeroDerivative2',
|
|
13369
|
+
// RiemannSZeroDerivative3: 'Math.riemannSZeroDerivative3',
|
|
13370
|
+
// RiemannSZeroDerivative4: 'Math.riemannSZeroDerivative4',
|
|
13371
|
+
// RiemannSZeroDerivative5: 'Math.riemannSZeroDerivative5',
|
|
13372
|
+
// RiemannSZeroDerivative6: 'Math.riemannSZeroDerivative6',
|
|
13373
|
+
}[h] ?? h;
|
|
13374
|
+
const args = expr.ops;
|
|
13375
|
+
if (args !== null) {
|
|
13376
|
+
const result = [];
|
|
13377
|
+
for (const arg of args)
|
|
13378
|
+
result.push(compile(arg, freeVars, 0));
|
|
13379
|
+
return `${fn}(${result.join(", ")})`;
|
|
13380
|
+
}
|
|
13381
|
+
}
|
|
13382
|
+
return "";
|
|
13383
|
+
}
|
|
13384
|
+
function compileLoop(expr, op3) {
|
|
13385
|
+
const args = expr.ops;
|
|
13386
|
+
if (args === null)
|
|
13387
|
+
return "NaN";
|
|
13388
|
+
if (!expr.op1 || !expr.op2)
|
|
13389
|
+
return "NaN";
|
|
13390
|
+
const [index, lower, upper, isFinite2] = normalizeLimits(expr.op2);
|
|
13391
|
+
const fn = compile(expr.op1, [...expr.op1.freeVars, index], 0);
|
|
13392
|
+
return `((_) => {
|
|
13393
|
+
let acc = ${op3 === "+" ? "0" : "1"};
|
|
13394
|
+
const fn = (_) => ${fn};
|
|
13395
|
+
for (let i = ${lower}; i < ${upper}; i++)
|
|
13396
|
+
acc ${op3}= fn({ ..._, ${index}: i });
|
|
13397
|
+
return acc;
|
|
13398
|
+
})()`;
|
|
13399
|
+
}
|
|
13400
|
+
|
|
13401
|
+
// src/compute-engine/boxed-expression/abstract-boxed-expression.ts
|
|
13152
13402
|
var AbstractBoxedExpression = class {
|
|
13153
13403
|
constructor(ce, metadata) {
|
|
13154
13404
|
this.engine = ce;
|
|
@@ -13473,6 +13723,9 @@ var AbstractBoxedExpression = class {
|
|
|
13473
13723
|
N(_options) {
|
|
13474
13724
|
return this.evaluate();
|
|
13475
13725
|
}
|
|
13726
|
+
compile() {
|
|
13727
|
+
return compileToJavascript(this);
|
|
13728
|
+
}
|
|
13476
13729
|
};
|
|
13477
13730
|
|
|
13478
13731
|
// src/compute-engine/boxed-expression/serialize.ts
|
|
@@ -14935,7 +15188,7 @@ function validateNumericArgs(ce, ops2, count) {
|
|
|
14935
15188
|
}
|
|
14936
15189
|
}
|
|
14937
15190
|
return xs.map(
|
|
14938
|
-
(op3) => !op3.isValid || op3.isNumber ? op3 : ce.error(["incompatible-domain", "Number", op3.domain], op3)
|
|
15191
|
+
(op3) => op3 && !op3.isValid || op3.isNumber ? op3 : ce.error(["incompatible-domain", "Number", op3.domain], op3)
|
|
14939
15192
|
);
|
|
14940
15193
|
}
|
|
14941
15194
|
function validateSignature(sig, ops2, codomain) {
|
|
@@ -15643,7 +15896,6 @@ var UNIVARIATE_ROOTS = [
|
|
|
15643
15896
|
// ],
|
|
15644
15897
|
];
|
|
15645
15898
|
function findUnivariateRoots(expr, x) {
|
|
15646
|
-
console.log("findUnivariateRoots", expr.toString(), x);
|
|
15647
15899
|
const ce = expr.engine;
|
|
15648
15900
|
if (expr.head === "Equal") {
|
|
15649
15901
|
expr = ce.add([expr.op1.canonical, ce.neg(expr.op2.canonical)]).simplify();
|
|
@@ -19582,6 +19834,18 @@ function randomExpression(level) {
|
|
|
19582
19834
|
level ?? (level = 1);
|
|
19583
19835
|
if (level === 1) {
|
|
19584
19836
|
const h = oneOf([
|
|
19837
|
+
[
|
|
19838
|
+
"Sqrt",
|
|
19839
|
+
[
|
|
19840
|
+
"Multiply",
|
|
19841
|
+
6,
|
|
19842
|
+
[
|
|
19843
|
+
"Sum",
|
|
19844
|
+
["Divide", 1, ["Power", "n", 2]],
|
|
19845
|
+
["Triple", ["Hold", "n"], 1, { num: "+Infinity" }]
|
|
19846
|
+
]
|
|
19847
|
+
]
|
|
19848
|
+
],
|
|
19585
19849
|
"Add",
|
|
19586
19850
|
"Add",
|
|
19587
19851
|
"Add",
|
|
@@ -19600,13 +19864,16 @@ function randomExpression(level) {
|
|
|
19600
19864
|
"Negate",
|
|
19601
19865
|
"trig"
|
|
19602
19866
|
]);
|
|
19603
|
-
|
|
19867
|
+
if (typeof h === "string")
|
|
19868
|
+
return randomExpressionWithHead(h, 1);
|
|
19869
|
+
return h;
|
|
19604
19870
|
}
|
|
19605
19871
|
if (level === 2) {
|
|
19606
|
-
|
|
19607
|
-
|
|
19608
|
-
if (Math.random() > 0.75)
|
|
19872
|
+
const r = Math.random();
|
|
19873
|
+
if (r > 0.75)
|
|
19609
19874
|
return randomExpression(1);
|
|
19875
|
+
if (r > 0.5)
|
|
19876
|
+
return randomExpression(3);
|
|
19610
19877
|
const h = oneOf([
|
|
19611
19878
|
"Multiply",
|
|
19612
19879
|
"Multiply",
|
|
@@ -19660,7 +19927,7 @@ function randomExpression(level) {
|
|
|
19660
19927
|
["Rational", 12, 15],
|
|
19661
19928
|
["Rational", 15, 12],
|
|
19662
19929
|
"ExponentialE",
|
|
19663
|
-
|
|
19930
|
+
// 'ImaginaryUnit',
|
|
19664
19931
|
["Sqrt", 3],
|
|
19665
19932
|
["Sqrt", 5],
|
|
19666
19933
|
["Sqrt", 15],
|
|
@@ -19678,8 +19945,8 @@ function randomExpression(level) {
|
|
|
19678
19945
|
["Power", "x", 4],
|
|
19679
19946
|
["Subtract", "x", 1],
|
|
19680
19947
|
["Add", "x", 1],
|
|
19681
|
-
|
|
19682
|
-
|
|
19948
|
+
// 'a',
|
|
19949
|
+
// 'b',
|
|
19683
19950
|
"Pi"
|
|
19684
19951
|
]);
|
|
19685
19952
|
}
|
|
@@ -23925,6 +24192,10 @@ var ComputeEngine = class _ComputeEngine {
|
|
|
23925
24192
|
return new this._bignum(a);
|
|
23926
24193
|
}
|
|
23927
24194
|
complex(a, b) {
|
|
24195
|
+
if (a instanceof Decimal)
|
|
24196
|
+
a = a.toNumber();
|
|
24197
|
+
if (b instanceof Decimal)
|
|
24198
|
+
b = b.toNumber();
|
|
23928
24199
|
return new import_complex19.Complex(a, b);
|
|
23929
24200
|
}
|
|
23930
24201
|
isBignum(a) {
|
|
@@ -24620,10 +24891,10 @@ var ComputeEngine = class _ComputeEngine {
|
|
|
24620
24891
|
};
|
|
24621
24892
|
|
|
24622
24893
|
// src/compute-engine.ts
|
|
24623
|
-
var version = "0.
|
|
24894
|
+
var version = "0.13.0";
|
|
24624
24895
|
globalThis[Symbol.for("io.cortexjs.compute-engine")] = {
|
|
24625
24896
|
ComputeEngine: ComputeEngine.prototype.constructor,
|
|
24626
|
-
version: "0.
|
|
24897
|
+
version: "0.13.0"
|
|
24627
24898
|
};
|
|
24628
24899
|
export {
|
|
24629
24900
|
ComputeEngine,
|