mirror of
https://github.com/josdejong/mathjs.git
synced 2025-12-08 19:46:04 +00:00
139 lines
4.2 KiB
JavaScript
139 lines
4.2 KiB
JavaScript
'use strict';
|
|
|
|
function factory (type, config, load, typed) {
|
|
|
|
var matrix = load(require('../../type/matrix/function/matrix'));
|
|
var equalScalar = load(require('./equalScalar'));
|
|
|
|
var algorithm03 = load(require('../../type/matrix/utils/algorithm03'));
|
|
var algorithm07 = load(require('../../type/matrix/utils/algorithm07'));
|
|
var algorithm12 = load(require('../../type/matrix/utils/algorithm12'));
|
|
var algorithm13 = load(require('../../type/matrix/utils/algorithm13'));
|
|
var algorithm14 = load(require('../../type/matrix/utils/algorithm14'));
|
|
|
|
var latex = require('../../utils/latex');
|
|
|
|
/**
|
|
* Test whether two values are equal.
|
|
*
|
|
* The function tests whether the relative difference between x and y is
|
|
* smaller than the configured epsilon. The function cannot be used to
|
|
* compare values smaller than approximately 2.22e-16.
|
|
*
|
|
* For matrices, the function is evaluated element wise.
|
|
* In case of complex numbers, x.re must equal y.re, and x.im must equal y.im.
|
|
*
|
|
* Values `null` and `undefined` are compared strictly, thus `null` is only
|
|
* equal to `null` and nothing else, and `undefined` is only equal to
|
|
* `undefined` and nothing else. Strings are compared by their numerical value.
|
|
*
|
|
* Syntax:
|
|
*
|
|
* math.equal(x, y)
|
|
*
|
|
* Examples:
|
|
*
|
|
* math.equal(2 + 2, 3); // returns false
|
|
* math.equal(2 + 2, 4); // returns true
|
|
*
|
|
* var a = math.unit('50 cm');
|
|
* var b = math.unit('5 m');
|
|
* math.equal(a, b); // returns true
|
|
*
|
|
* var c = [2, 5, 1];
|
|
* var d = [2, 7, 1];
|
|
*
|
|
* math.equal(c, d); // returns [true, false, true]
|
|
* math.deepEqual(c, d); // returns false
|
|
*
|
|
* math.equal("1000", "1e3"); // returns true
|
|
* math.equal(0, null); // returns false
|
|
*
|
|
* See also:
|
|
*
|
|
* unequal, smaller, smallerEq, larger, largerEq, compare, deepEqual
|
|
*
|
|
* @param {number | BigNumber | boolean | Complex | Unit | string | Array | Matrix} x First value to compare
|
|
* @param {number | BigNumber | boolean | Complex | Unit | string | Array | Matrix} y Second value to compare
|
|
* @return {boolean | Array | Matrix} Returns true when the compared values are equal, else returns false
|
|
*/
|
|
var equal = typed('equal', {
|
|
|
|
'any, any': function (x, y) {
|
|
// strict equality for null and undefined?
|
|
if (x === null) { return y === null; }
|
|
if (y === null) { return x === null; }
|
|
if (x === undefined) { return y === undefined; }
|
|
if (y === undefined) { return x === undefined; }
|
|
|
|
return equalScalar(x, y);
|
|
},
|
|
|
|
'SparseMatrix, SparseMatrix': function(x, y) {
|
|
return algorithm07(x, y, equalScalar);
|
|
},
|
|
|
|
'SparseMatrix, DenseMatrix': function(x, y) {
|
|
return algorithm03(y, x, equalScalar, true);
|
|
},
|
|
|
|
'DenseMatrix, SparseMatrix': function(x, y) {
|
|
return algorithm03(x, y, equalScalar, false);
|
|
},
|
|
|
|
'DenseMatrix, DenseMatrix': function(x, y) {
|
|
return algorithm13(x, y, equalScalar);
|
|
},
|
|
|
|
'Array, Array': function (x, y) {
|
|
// use matrix implementation
|
|
return equal(matrix(x), matrix(y)).valueOf();
|
|
},
|
|
|
|
'Array, Matrix': function (x, y) {
|
|
// use matrix implementation
|
|
return equal(matrix(x), y);
|
|
},
|
|
|
|
'Matrix, Array': function (x, y) {
|
|
// use matrix implementation
|
|
return equal(x, matrix(y));
|
|
},
|
|
|
|
'SparseMatrix, any': function (x, y) {
|
|
return algorithm12(x, y, equalScalar, false);
|
|
},
|
|
|
|
'DenseMatrix, any': function (x, y) {
|
|
return algorithm14(x, y, equalScalar, false);
|
|
},
|
|
|
|
'any, SparseMatrix': function (x, y) {
|
|
return algorithm12(y, x, equalScalar, true);
|
|
},
|
|
|
|
'any, DenseMatrix': function (x, y) {
|
|
return algorithm14(y, x, equalScalar, true);
|
|
},
|
|
|
|
'Array, any': function (x, y) {
|
|
// use matrix implementation
|
|
return algorithm14(matrix(x), y, equalScalar, false).valueOf();
|
|
},
|
|
|
|
'any, Array': function (x, y) {
|
|
// use matrix implementation
|
|
return algorithm14(matrix(y), x, equalScalar, true).valueOf();
|
|
}
|
|
});
|
|
|
|
equal.toTex = {
|
|
2: '\\left(${args[0]}' + latex.operators['equal'] + '${args[1]}\\right)'
|
|
};
|
|
|
|
return equal;
|
|
}
|
|
|
|
exports.name = 'equal';
|
|
exports.factory = factory;
|