@pie-lib/math-evaluator 2.17.1-next.0 → 2.18.1
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/esm/index.js +175 -0
- package/esm/index.js.map +1 -0
- package/package.json +10 -3
package/esm/index.js
ADDED
|
@@ -0,0 +1,175 @@
|
|
|
1
|
+
import * as mathjs from 'mathjs';
|
|
2
|
+
import me from '@pie-framework/math-expressions';
|
|
3
|
+
|
|
4
|
+
function _extends() {
|
|
5
|
+
_extends = Object.assign || function (target) {
|
|
6
|
+
for (var i = 1; i < arguments.length; i++) {
|
|
7
|
+
var source = arguments[i];
|
|
8
|
+
|
|
9
|
+
for (var key in source) {
|
|
10
|
+
if (Object.prototype.hasOwnProperty.call(source, key)) {
|
|
11
|
+
target[key] = source[key];
|
|
12
|
+
}
|
|
13
|
+
}
|
|
14
|
+
}
|
|
15
|
+
|
|
16
|
+
return target;
|
|
17
|
+
};
|
|
18
|
+
|
|
19
|
+
return _extends.apply(this, arguments);
|
|
20
|
+
}
|
|
21
|
+
|
|
22
|
+
const decimalCommaRegex = /,/g;
|
|
23
|
+
const decimalRegex = /\.|,/g;
|
|
24
|
+
const decimalWithThousandSeparatorNumberRegex = /^(?!0+\.00)(?=.{1,9}(\.|$))(?!0(?!\.))\d{1,3}(,\d{3})*(\.\d+)?$/;
|
|
25
|
+
|
|
26
|
+
const rationalizeAllPossibleSubNodes = expression => rationalize(mathjs.parse(expression));
|
|
27
|
+
|
|
28
|
+
const rationalize = tree => {
|
|
29
|
+
const transformedTree = tree.transform(node => {
|
|
30
|
+
try {
|
|
31
|
+
const rationalizedNode = mathjs.rationalize(node);
|
|
32
|
+
return rationalizedNode;
|
|
33
|
+
} catch (_unused) {
|
|
34
|
+
return node;
|
|
35
|
+
}
|
|
36
|
+
});
|
|
37
|
+
return transformedTree;
|
|
38
|
+
};
|
|
39
|
+
|
|
40
|
+
function prepareExpression(string, isLatex) {
|
|
41
|
+
let returnValue = string ? string.trim() : '';
|
|
42
|
+
returnValue = returnValue.replace(decimalCommaRegex, '.');
|
|
43
|
+
returnValue = isLatex ? latexToText(`${returnValue}`) : textToMathText(`${returnValue}`, {
|
|
44
|
+
unknownCommands: 'passthrough'
|
|
45
|
+
}).toString();
|
|
46
|
+
returnValue = returnValue.replace('=', '==');
|
|
47
|
+
return rationalizeAllPossibleSubNodes(returnValue);
|
|
48
|
+
}
|
|
49
|
+
|
|
50
|
+
const latexToAstOpts = {
|
|
51
|
+
missingFactor: (token, e) => {
|
|
52
|
+
console.warn('missing factor for: ', token.token_type);
|
|
53
|
+
|
|
54
|
+
if (token.token_type === 'NUMBER') {
|
|
55
|
+
throw e;
|
|
56
|
+
}
|
|
57
|
+
|
|
58
|
+
return 0;
|
|
59
|
+
},
|
|
60
|
+
unknownCommandBehavior: 'passthrough'
|
|
61
|
+
};
|
|
62
|
+
const astToTextOpts = {
|
|
63
|
+
unicode_operators: {
|
|
64
|
+
ne: function (operands) {
|
|
65
|
+
return operands.join(' != ');
|
|
66
|
+
},
|
|
67
|
+
'%': function (operands) {
|
|
68
|
+
return `percent(${operands[0]})`;
|
|
69
|
+
}
|
|
70
|
+
}
|
|
71
|
+
};
|
|
72
|
+
const latexToText = (latex, extraOtps = {}) => {
|
|
73
|
+
const la = new me.converters.latexToAstObj(_extends({}, latexToAstOpts, extraOtps));
|
|
74
|
+
const at = new me.converters.astToTextObj(_extends({}, astToTextOpts, extraOtps));
|
|
75
|
+
const ast = la.convert(latex);
|
|
76
|
+
return at.convert(ast);
|
|
77
|
+
};
|
|
78
|
+
const textToMathText = (latex, extraOtps = {}) => {
|
|
79
|
+
const la = new me.converters.textToAstObj(_extends({}, latexToAstOpts, extraOtps));
|
|
80
|
+
const at = new me.converters.astToTextObj(_extends({}, astToTextOpts, extraOtps));
|
|
81
|
+
const ast = la.convert(latex);
|
|
82
|
+
return at.convert(ast);
|
|
83
|
+
};
|
|
84
|
+
|
|
85
|
+
function shouldRationalizeEntireTree(tree) {
|
|
86
|
+
let shouldDoIt = true; // we need to iterate the entire tree to check for some conditions that might make rationalization impossible
|
|
87
|
+
|
|
88
|
+
try {
|
|
89
|
+
tree.traverse(node => {
|
|
90
|
+
// if we have a variable as an exponent for power operation, we should not rationalize
|
|
91
|
+
// try to see if there are power operations with variable exponents
|
|
92
|
+
if (node.type === 'OperatorNode' && node.fn === 'pow') {
|
|
93
|
+
const exponent = node.args[1]; // try to see if it can be compiled and evaluated - if it's a non-numerical value, it'll throw an error
|
|
94
|
+
|
|
95
|
+
exponent.compile().eval();
|
|
96
|
+
} // we cannot have variables for unresolved function calls either
|
|
97
|
+
|
|
98
|
+
|
|
99
|
+
if (node.type === 'FunctionNode') {
|
|
100
|
+
//try to see if the argument that the function is called with can be resolved as non-variable
|
|
101
|
+
const functionParameter = node.args[0]; // if it holds variables, this will throw an error
|
|
102
|
+
|
|
103
|
+
functionParameter.compile().eval();
|
|
104
|
+
}
|
|
105
|
+
});
|
|
106
|
+
mathjs.rationalize(tree);
|
|
107
|
+
} catch (_unused2) {
|
|
108
|
+
shouldDoIt = false;
|
|
109
|
+
}
|
|
110
|
+
|
|
111
|
+
return shouldDoIt;
|
|
112
|
+
}
|
|
113
|
+
|
|
114
|
+
function containsDecimal(expression = '') {
|
|
115
|
+
return expression.match(decimalRegex);
|
|
116
|
+
}
|
|
117
|
+
|
|
118
|
+
const SIMPLIFY_RULES = [{
|
|
119
|
+
l: 'n1^(1/n2)',
|
|
120
|
+
r: 'nthRoot(n1, n2)'
|
|
121
|
+
}, {
|
|
122
|
+
l: 'sqrt(n1)',
|
|
123
|
+
r: 'nthRoot(n1, 2)'
|
|
124
|
+
}];
|
|
125
|
+
|
|
126
|
+
const simplify = v => mathjs.simplify(v, SIMPLIFY_RULES.concat(mathjs.simplify.rules)); //.concat(SIMPLIFY_RULES));
|
|
127
|
+
|
|
128
|
+
|
|
129
|
+
const areValuesEqual = (valueOne, valueTwo, options = {}) => {
|
|
130
|
+
const {
|
|
131
|
+
// if explicitly set to false, having a decimal value in either side will result in a false equality
|
|
132
|
+
// regardless of mathematical correctness
|
|
133
|
+
allowDecimals,
|
|
134
|
+
isLatex,
|
|
135
|
+
// if the passed in values are latex, they need to be escaped
|
|
136
|
+
inverse // returns inverse for the comparison result
|
|
137
|
+
|
|
138
|
+
} = options;
|
|
139
|
+
let valueOneToUse = valueOne;
|
|
140
|
+
let valueTwoToUse = valueTwo;
|
|
141
|
+
|
|
142
|
+
if (allowDecimals === false) {
|
|
143
|
+
if (containsDecimal(valueOne) || containsDecimal(valueTwo)) {
|
|
144
|
+
return false;
|
|
145
|
+
}
|
|
146
|
+
} else if (allowDecimals === true) {
|
|
147
|
+
if (containsDecimal(valueOne) && decimalWithThousandSeparatorNumberRegex.test(valueOne)) {
|
|
148
|
+
valueOneToUse = valueOne.replace(decimalCommaRegex, '');
|
|
149
|
+
}
|
|
150
|
+
|
|
151
|
+
if (containsDecimal(valueTwo) && decimalWithThousandSeparatorNumberRegex.test(valueTwo)) {
|
|
152
|
+
valueTwoToUse = valueTwo.replace(decimalCommaRegex, '');
|
|
153
|
+
}
|
|
154
|
+
}
|
|
155
|
+
|
|
156
|
+
const preparedValueOne = prepareExpression(valueOneToUse, isLatex);
|
|
157
|
+
const preparedValueTwo = prepareExpression(valueTwoToUse, isLatex);
|
|
158
|
+
let one = shouldRationalizeEntireTree(preparedValueOne) ? mathjs.rationalize(preparedValueOne) : preparedValueOne;
|
|
159
|
+
let two = shouldRationalizeEntireTree(preparedValueTwo) ? mathjs.rationalize(preparedValueTwo) : preparedValueTwo;
|
|
160
|
+
one = simplify(one);
|
|
161
|
+
two = simplify(two);
|
|
162
|
+
const equals = one.equals(two);
|
|
163
|
+
return inverse ? !equals : equals;
|
|
164
|
+
};
|
|
165
|
+
|
|
166
|
+
const ave = (a, b) => {
|
|
167
|
+
const am = mathjs.parse(a);
|
|
168
|
+
const bm = mathjs.parse(b);
|
|
169
|
+
const arm = simplify(am);
|
|
170
|
+
const brm = simplify(bm);
|
|
171
|
+
return arm.equals(brm);
|
|
172
|
+
};
|
|
173
|
+
|
|
174
|
+
export { ave, areValuesEqual as default, latexToText, textToMathText };
|
|
175
|
+
//# sourceMappingURL=index.js.map
|
package/esm/index.js.map
ADDED
|
@@ -0,0 +1 @@
|
|
|
1
|
+
{"version":3,"file":"index.js","sources":["../src/index.js"],"sourcesContent":["/* eslint-disable no-console */\nimport * as mathjs from 'mathjs';\nimport me from '@pie-framework/math-expressions';\n\nconst decimalCommaRegex = /,/g;\nconst decimalRegex = /\\.|,/g;\nconst decimalWithThousandSeparatorNumberRegex = /^(?!0+\\.00)(?=.{1,9}(\\.|$))(?!0(?!\\.))\\d{1,3}(,\\d{3})*(\\.\\d+)?$/;\n\nconst rationalizeAllPossibleSubNodes = (expression) => rationalize(mathjs.parse(expression));\nconst rationalize = (tree) => {\n const transformedTree = tree.transform((node) => {\n try {\n const rationalizedNode = mathjs.rationalize(node);\n return rationalizedNode;\n } catch {\n return node;\n }\n });\n return transformedTree;\n};\n\nfunction prepareExpression(string, isLatex) {\n let returnValue = string ? string.trim() : '';\n\n returnValue = returnValue.replace(decimalCommaRegex, '.');\n\n returnValue = isLatex\n ? latexToText(`${returnValue}`)\n : textToMathText(`${returnValue}`, { unknownCommands: 'passthrough' }).toString();\n\n returnValue = returnValue.replace('=', '==');\n return rationalizeAllPossibleSubNodes(returnValue);\n}\n\nconst latexToAstOpts = {\n missingFactor: (token, e) => {\n console.warn('missing factor for: ', token.token_type);\n if (token.token_type === 'NUMBER') {\n throw e;\n }\n return 0;\n },\n unknownCommandBehavior: 'passthrough',\n};\n\nconst astToTextOpts = {\n unicode_operators: {\n ne: function(operands) {\n return operands.join(' != ');\n },\n '%': function(operands) {\n return `percent(${operands[0]})`;\n },\n },\n};\n\nexport const latexToText = (latex, extraOtps = {}) => {\n const la = new me.converters.latexToAstObj({ ...latexToAstOpts, ...extraOtps });\n\n const at = new me.converters.astToTextObj({ ...astToTextOpts, ...extraOtps });\n\n const ast = la.convert(latex);\n\n return at.convert(ast);\n};\n\nexport const textToMathText = (latex, extraOtps = {}) => {\n const la = new me.converters.textToAstObj({ ...latexToAstOpts, ...extraOtps });\n\n const at = new me.converters.astToTextObj({ ...astToTextOpts, ...extraOtps });\n\n const ast = la.convert(latex);\n\n return at.convert(ast);\n};\n\nfunction shouldRationalizeEntireTree(tree) {\n let shouldDoIt = true;\n\n // we need to iterate the entire tree to check for some conditions that might make rationalization impossible\n try {\n tree.traverse((node) => {\n // if we have a variable as an exponent for power operation, we should not rationalize\n // try to see if there are power operations with variable exponents\n if (node.type === 'OperatorNode' && node.fn === 'pow') {\n const exponent = node.args[1];\n\n // try to see if it can be compiled and evaluated - if it's a non-numerical value, it'll throw an error\n exponent.compile().eval();\n }\n\n // we cannot have variables for unresolved function calls either\n if (node.type === 'FunctionNode') {\n //try to see if the argument that the function is called with can be resolved as non-variable\n const functionParameter = node.args[0];\n\n // if it holds variables, this will throw an error\n functionParameter.compile().eval();\n }\n });\n\n mathjs.rationalize(tree);\n } catch {\n shouldDoIt = false;\n }\n\n return shouldDoIt;\n}\n\nfunction containsDecimal(expression = '') {\n return expression.match(decimalRegex);\n}\nconst SIMPLIFY_RULES = [\n { l: 'n1^(1/n2)', r: 'nthRoot(n1, n2)' },\n { l: 'sqrt(n1)', r: 'nthRoot(n1, 2)' },\n];\n\nconst simplify = (v) => mathjs.simplify(v, SIMPLIFY_RULES.concat(mathjs.simplify.rules)); //.concat(SIMPLIFY_RULES));\n\nconst areValuesEqual = (valueOne, valueTwo, options = {}) => {\n const {\n // if explicitly set to false, having a decimal value in either side will result in a false equality\n // regardless of mathematical correctness\n allowDecimals,\n isLatex, // if the passed in values are latex, they need to be escaped\n inverse, // returns inverse for the comparison result\n } = options;\n\n let valueOneToUse = valueOne;\n let valueTwoToUse = valueTwo;\n\n if (allowDecimals === false) {\n if (containsDecimal(valueOne) || containsDecimal(valueTwo)) {\n return false;\n }\n } else if (allowDecimals === true) {\n if (containsDecimal(valueOne) && decimalWithThousandSeparatorNumberRegex.test(valueOne)) {\n valueOneToUse = valueOne.replace(decimalCommaRegex, '');\n }\n\n if (containsDecimal(valueTwo) && decimalWithThousandSeparatorNumberRegex.test(valueTwo)) {\n valueTwoToUse = valueTwo.replace(decimalCommaRegex, '');\n }\n }\n\n const preparedValueOne = prepareExpression(valueOneToUse, isLatex, allowDecimals);\n const preparedValueTwo = prepareExpression(valueTwoToUse, isLatex, allowDecimals);\n\n let one = shouldRationalizeEntireTree(preparedValueOne) ? mathjs.rationalize(preparedValueOne) : preparedValueOne;\n let two = shouldRationalizeEntireTree(preparedValueTwo) ? mathjs.rationalize(preparedValueTwo) : preparedValueTwo;\n\n one = simplify(one);\n two = simplify(two);\n\n const equals = one.equals(two);\n\n return inverse ? !equals : equals;\n};\n\nexport const ave = (a, b) => {\n const am = mathjs.parse(a);\n const bm = mathjs.parse(b);\n\n const arm = simplify(am);\n const brm = simplify(bm);\n return arm.equals(brm);\n};\n\nexport default areValuesEqual;\n"],"names":["decimalCommaRegex","decimalRegex","decimalWithThousandSeparatorNumberRegex","rationalizeAllPossibleSubNodes","expression","rationalize","mathjs","parse","tree","transformedTree","transform","node","rationalizedNode","prepareExpression","string","isLatex","returnValue","trim","replace","latexToText","textToMathText","unknownCommands","toString","latexToAstOpts","missingFactor","token","e","console","warn","token_type","unknownCommandBehavior","astToTextOpts","unicode_operators","ne","operands","join","latex","extraOtps","la","me","converters","latexToAstObj","at","astToTextObj","ast","convert","textToAstObj","shouldRationalizeEntireTree","shouldDoIt","traverse","type","fn","exponent","args","compile","eval","functionParameter","containsDecimal","match","SIMPLIFY_RULES","l","r","simplify","v","concat","rules","areValuesEqual","valueOne","valueTwo","options","allowDecimals","inverse","valueOneToUse","valueTwoToUse","test","preparedValueOne","preparedValueTwo","one","two","equals","ave","a","b","am","bm","arm","brm"],"mappings":"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"}
|
package/package.json
CHANGED
|
@@ -3,7 +3,7 @@
|
|
|
3
3
|
"publishConfig": {
|
|
4
4
|
"access": "public"
|
|
5
5
|
},
|
|
6
|
-
"version": "2.
|
|
6
|
+
"version": "2.18.1",
|
|
7
7
|
"description": "Math evaluator tool for comparing expressions for equality",
|
|
8
8
|
"keywords": [
|
|
9
9
|
"math",
|
|
@@ -23,8 +23,15 @@
|
|
|
23
23
|
"mathjs": "^7.0.1"
|
|
24
24
|
},
|
|
25
25
|
"devDependencies": {
|
|
26
|
-
"@pie-lib/test-utils": "^0.
|
|
26
|
+
"@pie-lib/test-utils": "^0.19.1"
|
|
27
27
|
},
|
|
28
28
|
"scripts": {},
|
|
29
|
-
"gitHead": "
|
|
29
|
+
"gitHead": "be0b7951407a81d53b8b8b4861b8407b31728809",
|
|
30
|
+
"exports": {
|
|
31
|
+
".": {
|
|
32
|
+
"import": "./esm/index.js",
|
|
33
|
+
"require": "./lib/index.js",
|
|
34
|
+
"default": "./esm/index.js"
|
|
35
|
+
}
|
|
36
|
+
}
|
|
30
37
|
}
|