mirror of
https://github.com/josdejong/mathjs.git
synced 2025-12-08 19:46:04 +00:00
Depending on the input vectors' dimensions, either a 1-d vector or a 2-d matrix should be returned.
53 lines
2.1 KiB
JavaScript
53 lines
2.1 KiB
JavaScript
var assert = require('assert');
|
|
var error = require('../../../lib/error/index');
|
|
var math = require('../../../index');
|
|
|
|
describe('cross', function() {
|
|
|
|
it('should calculate cross product for two arrays', function() {
|
|
assert.deepEqual(math.cross([1, 1, 0], [0, 1, 1]), [1, -1, 1]);
|
|
assert.deepEqual(math.cross([3, -3, 1], [4, 9, 2]), [-15, -2, 39]);
|
|
assert.deepEqual(math.cross([2, 3, 4], [5, 6, 7]), [-3, 6, -3]);
|
|
});
|
|
|
|
it('should calculate cross product for two matrices', function() {
|
|
assert.deepEqual(math.cross(math.matrix([1, 1, 0]), math.matrix([0, 1, 1])),
|
|
math.matrix([1, -1, 1]));
|
|
});
|
|
|
|
it('should calculate cross product for mixed arrays and matrices', function() {
|
|
assert.deepEqual(math.cross([1, 1, 0], math.matrix([0, 1, 1])),
|
|
math.matrix([1, -1, 1]));
|
|
assert.deepEqual(math.cross(math.matrix([1, 1, 0]), [0, 1, 1]),
|
|
math.matrix([1, -1, 1]));
|
|
});
|
|
|
|
it('should calculate cross product for n-d arrays and matrices', function () {
|
|
assert.deepEqual(math.cross([[1, 2, 3]], [[4, 5, 6]]), [[-3, 6, -3]]);
|
|
assert.deepEqual(math.cross([[1], [2], [3]], [4, 5, 6]), [[-3, 6, -3]]);
|
|
assert.deepEqual(math.cross([[[[1, 2, 3]]]], [[4, 5, 6]]), [[-3, 6, -3]]);
|
|
});
|
|
|
|
it('should throw an error for unsupported types of arguments', function() {
|
|
assert.throws(function () {math.cross([2, 4, 1], 2)}, TypeError);
|
|
});
|
|
|
|
it('should throw an error for multi dimensional matrix input', function() {
|
|
assert.throws(function () {math.cross([[1,2],[3,4]], [[1,2],[3,4]])}, /Vectors with length 3 expected/);
|
|
});
|
|
|
|
it('should throw an error in case of vectors with unequal length', function() {
|
|
assert.throws(function () {math.cross([2, 3], [1,2,3])}, /Vectors with length 3 expected/);
|
|
});
|
|
|
|
it('should throw an error in case of empty vectors', function() {
|
|
assert.throws(function () {math.cross([], [])}, /Vectors with length 3 expected/);
|
|
});
|
|
|
|
it('should LaTeX cross', function () {
|
|
var expression = math.parse('cross([1],[2])');
|
|
assert.equal(expression.toTex(), '\\left(\\begin{bmatrix}1\\\\\\end{bmatrix}\\right)\\times\\left(\\begin{bmatrix}2\\\\\\end{bmatrix}\\right)');
|
|
});
|
|
|
|
});
|