mathjs/test/function/matrix/det.test.js
jos 6e96d5a808 Merge branch 'develop' into v2
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
2015-04-22 21:43:56 +02:00

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)');
});
});