mathjs
Version:
Math.js is an extensive math library for JavaScript and Node.js. It features a flexible expression parser with support for symbolic computation, comes with a large set of built-in functions and constants, and offers an integrated solution to work with dif
54 lines (43 loc) • 1.79 kB
JavaScript
// test matrix construction
var assert = require('assert'),
math = require('../../../../index'),
sparse = math.sparse;
describe('sparse', function() {
it('should create empty matrix', function() {
var a = sparse();
assert.ok(a instanceof math.type.Matrix);
});
it('should create empty matrix, number datatype', function() {
var a = sparse('number');
assert.ok(a instanceof math.type.Matrix);
assert.ok(a.datatype() === 'number');
});
it('should be the identity if called with a matrix', function() {
var b = sparse([[1,2],[3,4]]);
var c = sparse(b);
assert.ok(c._values != b._values); // data should be cloned
assert.deepEqual(c, sparse([[1,2],[3,4]]));
});
it('should be the identity if called with a matrix, number datatype', function() {
var b = sparse([[1,2],[3,4]], 'number');
var c = sparse(b);
assert.ok(c._values != b._values); // data should be cloned
assert.deepEqual(c.valueOf(), b.valueOf());
assert.ok(c.datatype() === 'number');
});
it('should throw an error if called with an invalid argument', function() {
assert.throws(function () { sparse(new Date()); }, TypeError);
});
it('should throw an error if called with a unit', function() {
assert.throws(function () { sparse(math.unit('5cm')); }, TypeError);
});
it('should throw an error if called with too many arguments', function() {
assert.throws(function () {sparse([], 3, 3);}, /TypeError: Too many arguments/);
});
it('should LaTeX matrix', function () {
var expr1 = math.parse('sparse()');
var expr2 = math.parse('sparse([1])');
assert.equal(expr1.toTex(), '\\begin{bsparse}\\end{bsparse}');
assert.equal(expr2.toTex(), '\\left(\\begin{bmatrix}1\\\\\\end{bmatrix}\\right)');
});
});