88 lines
3.3 KiB
JavaScript
88 lines
3.3 KiB
JavaScript
|
"use strict";
|
||
|
|
||
|
Object.defineProperty(exports, "__esModule", {
|
||
|
value: true
|
||
|
});
|
||
|
exports.createSymbolicEqual = void 0;
|
||
|
|
||
|
var _is = require("../../utils/is.js");
|
||
|
|
||
|
var _factory = require("../../utils/factory.js");
|
||
|
|
||
|
var name = 'symbolicEqual';
|
||
|
var dependencies = ['parse', 'simplify', 'typed', 'OperatorNode'];
|
||
|
var createSymbolicEqual = /* #__PURE__ */(0, _factory.factory)(name, dependencies, function (_ref) {
|
||
|
var parse = _ref.parse,
|
||
|
simplify = _ref.simplify,
|
||
|
typed = _ref.typed,
|
||
|
OperatorNode = _ref.OperatorNode;
|
||
|
|
||
|
/**
|
||
|
* Attempts to determine if two expressions are symbolically equal, i.e.
|
||
|
* one is the result of valid algebraic manipulations on the other.
|
||
|
* Currently, this simply checks if the difference of the two expressions
|
||
|
* simplifies down to 0. So there are two important caveats:
|
||
|
* 1. whether two expressions are symbolically equal depends on the
|
||
|
* manipulations allowed. Therefore, this function takes an optional
|
||
|
* third argument, which are the options that control the behavior
|
||
|
* as documented for the `simplify()` function.
|
||
|
* 2. it is in general intractable to find the minimal simplification of
|
||
|
* an arbitrarily complicated expression. So while a `true` value
|
||
|
* of `symbolicEqual` ensures that the two expressions can be manipulated
|
||
|
* to match each other, a `false` value does not absolutely rule this out.
|
||
|
*
|
||
|
* Syntax:
|
||
|
*
|
||
|
* symbolicEqual(expr1, expr2)
|
||
|
* symbolicEqual(expr1, expr2, options)
|
||
|
*
|
||
|
* Examples:
|
||
|
*
|
||
|
* symbolicEqual('x*y', 'y*x') // true
|
||
|
* symbolicEqual('x*y', 'y*x', {context: {multiply: {commutative: false}}})
|
||
|
* //false
|
||
|
* symbolicEqual('x/y', '(y*x^(-1))^(-1)') // true
|
||
|
* symbolicEqual('abs(x)','x') // false
|
||
|
* symbolicEqual('abs(x)','x', simplify.positiveContext) // true
|
||
|
*
|
||
|
* See also:
|
||
|
*
|
||
|
* simplify, evaluate
|
||
|
*
|
||
|
* @param {Node|string} expr1 The first expression to compare
|
||
|
* @param {Node|string} expr2 The second expression to compare
|
||
|
* @param {Object} [options] Optional option object, passed to simplify
|
||
|
* @returns {boolean}
|
||
|
* Returns true if a valid manipulation making the expressions equal
|
||
|
* is found.
|
||
|
*/
|
||
|
return typed(name, {
|
||
|
'string, string': function stringString(s1, s2) {
|
||
|
return this(parse(s1), parse(s2), {});
|
||
|
},
|
||
|
'string, string, Object': function stringStringObject(s1, s2, options) {
|
||
|
return this(parse(s1), parse(s2), options);
|
||
|
},
|
||
|
'Node, string': function NodeString(e1, s2) {
|
||
|
return this(e1, parse(s2), {});
|
||
|
},
|
||
|
'Node, string, Object': function NodeStringObject(e1, s2, options) {
|
||
|
return this(e1, parse(s2), options);
|
||
|
},
|
||
|
'string, Node': function stringNode(s1, e2) {
|
||
|
return this(parse(s1), e2, {});
|
||
|
},
|
||
|
'string, Node, Object': function stringNodeObject(s1, e2, options) {
|
||
|
return this(parse(s1), e2, options);
|
||
|
},
|
||
|
'Node, Node': function NodeNode(e1, e2) {
|
||
|
return this(e1, e2, {});
|
||
|
},
|
||
|
'Node, Node, Object': function NodeNodeObject(e1, e2, options) {
|
||
|
var diff = new OperatorNode('-', 'subtract', [e1, e2]);
|
||
|
var simplified = simplify(diff, {}, options);
|
||
|
return (0, _is.isConstantNode)(simplified) && !simplified.value;
|
||
|
}
|
||
|
});
|
||
|
});
|
||
|
exports.createSymbolicEqual = createSymbolicEqual;
|