mirror of
https://github.com/josdejong/mathjs.git
synced 2026-01-18 14:59:29 +00:00
Conflicts: HISTORY.md bower.json component.json dist/math.js dist/math.map dist/math.min.js lib/function/arithmetic/abs.js lib/function/probability/gamma.js lib/version.js package.json
142 lines
3.8 KiB
JavaScript
142 lines
3.8 KiB
JavaScript
var assert = require('assert');
|
|
var approx = require('../../../tools/approx');
|
|
var error = require('../../../lib/error/index');
|
|
var math = require('../../../index');
|
|
var BigNumber = math.type.BigNumber;
|
|
var Complex = math.type.Complex;
|
|
var DenseMatrix = math.type.DenseMatrix;
|
|
var det = math.det;
|
|
var diag = math.diag;
|
|
var eye = math.eye;
|
|
|
|
describe('det', function() {
|
|
|
|
it('should calculate correctly the determinant of a NxN matrix', function() {
|
|
assert.equal(det([5]), 5);
|
|
assert.equal(det([[1,2],[3,4]]), -2);
|
|
assert.equal(det(new DenseMatrix([[1,2],[3,4]])), -2);
|
|
approx.equal(det([
|
|
[-2, 2, 3],
|
|
[-1, 1, 3],
|
|
[ 2, 0, -1]
|
|
]), 6);
|
|
approx.equal(det([
|
|
[ 1, 4, 7],
|
|
[ 3, 0, 5],
|
|
[-1, 9, 11]
|
|
]), -8);
|
|
approx.equal(det([
|
|
[1,7,4,3,7],
|
|
[0,7,0,3,7],
|
|
[0,7,4,3,0],
|
|
[1,7,5,9,7],
|
|
[2,7,4,3,7]
|
|
]), -1176);
|
|
approx.equal(det(diag([4,-5,6])), -120);
|
|
});
|
|
|
|
it('should return 1 for the identity matrix',function() {
|
|
assert.equal(det(eye(7)), 1);
|
|
assert.equal(det(eye(2)), 1);
|
|
assert.equal(det(eye(1)), 1);
|
|
});
|
|
|
|
it('should return 0 for a singular matrix',function() {
|
|
assert.equal(det([
|
|
[1, 0],
|
|
[0, 0]
|
|
]), 0);
|
|
assert.equal(det([
|
|
[1, 0],
|
|
[1, 0]
|
|
]), 0);
|
|
assert.equal(det([
|
|
[2, 6],
|
|
[1, 3]
|
|
]), 0);
|
|
assert.equal(det([
|
|
[1, 0, 0],
|
|
[0, 0, 0],
|
|
[1, 0, 0]
|
|
]), 0);
|
|
});
|
|
|
|
it('should calculate the determinant for a scalar',function() {
|
|
assert.equal(det(7), 7);
|
|
|
|
var c1 = new Complex(2, 3);
|
|
var c2 = det(c1);
|
|
assert.deepEqual(c1, c2);
|
|
|
|
// c2 should be a clone
|
|
c1.re = 0;
|
|
assert.equal(c1.re, 0);
|
|
assert.equal(c2.re, 2);
|
|
});
|
|
|
|
it('should calculate the determinant for a 1x1 matrix',function() {
|
|
var c1 = new Complex(2, 3);
|
|
var c2 = det([[c1]]);
|
|
assert.deepEqual(c1, c2);
|
|
|
|
// c2 should be a clone
|
|
c1.re = 0;
|
|
assert.equal(c1.re, 0);
|
|
assert.equal(c2.re, 2);
|
|
});
|
|
|
|
it('should calculate correctly the determinant of a matrix with bignumbers', function() {
|
|
// 1x1
|
|
assert.deepEqual(det([new BigNumber(5)]), new BigNumber(5));
|
|
|
|
// 2x2
|
|
assert.deepEqual(det([
|
|
[new BigNumber(1), new BigNumber(2)],
|
|
[new BigNumber(3), new BigNumber(4)]
|
|
]), new BigNumber(-2));
|
|
|
|
// 3x3
|
|
assert.deepEqual(det([
|
|
[new BigNumber(-2), new BigNumber(2), new BigNumber( 3)],
|
|
[new BigNumber(-1), new BigNumber(1), new BigNumber( 3)],
|
|
[new BigNumber( 2), new BigNumber(0), new BigNumber(-1)]
|
|
]), new math.type.BigNumber(6));
|
|
|
|
// the following would fail with regular Numbers due to a precision overflow
|
|
assert.deepEqual(det([
|
|
[new BigNumber(1e10+1), new BigNumber(1e10)],
|
|
[new BigNumber(1e10), new BigNumber(1e10-1)]
|
|
]), new BigNumber(-1));
|
|
});
|
|
|
|
it('should calculate the determinant of a matrix with mixed numbers and bignumbers', function() {
|
|
assert.deepEqual(det([
|
|
[1, new BigNumber(2)],
|
|
[new BigNumber(3), 4]
|
|
]), new math.type.BigNumber(-2));
|
|
});
|
|
|
|
it('should not change the value of the initial matrix', function() {
|
|
var m_test = [[1,2,3],[4,5,6],[7,8,9]];
|
|
det(m_test);
|
|
assert.deepEqual(m_test, [[1,2,3],[4,5,6],[7,8,9]]);
|
|
});
|
|
|
|
it('should not accept a non-square matrix', function() {
|
|
assert.throws(function() { det([1,2]); });
|
|
assert.throws(function() { det([[1,2,3],[1,2,3]]); });
|
|
assert.throws(function() { det([0,1],[0,1],[0,1]); });
|
|
});
|
|
|
|
it('should not accept arrays with dimensions higher than 2', function() {
|
|
assert.throws(function() { det([[[1]]]); }, RangeError);
|
|
assert.throws(function() { det(new DenseMatrix([[[1]]])); }, RangeError);
|
|
});
|
|
|
|
it('should LaTeX det', function () {
|
|
var expression = math.parse('det([1])');
|
|
assert.equal(expression.toTex(), '\\det\\left(\\begin{bmatrix}1\\\\\\end{bmatrix}\\right)');
|
|
});
|
|
|
|
});
|