50 lines
2.1 KiB
JavaScript

import assert from 'assert'
import math from '../../../../src/bundleAny'
describe('cross', function () {
it('should calculate cross product for two arrays', function () {
assert.deepStrictEqual(math.cross([1, 1, 0], [0, 1, 1]), [1, -1, 1])
assert.deepStrictEqual(math.cross([3, -3, 1], [4, 9, 2]), [-15, -2, 39])
assert.deepStrictEqual(math.cross([2, 3, 4], [5, 6, 7]), [-3, 6, -3])
})
it('should calculate cross product for two matrices', function () {
assert.deepStrictEqual(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.deepStrictEqual(math.cross([1, 1, 0], math.matrix([0, 1, 1])),
math.matrix([1, -1, 1]))
assert.deepStrictEqual(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.deepStrictEqual(math.cross([[1, 2, 3]], [[4, 5, 6]]), [[-3, 6, -3]])
assert.deepStrictEqual(math.cross([[1], [2], [3]], [4, 5, 6]), [[-3, 6, -3]])
assert.deepStrictEqual(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 () {
const expression = math.parse('cross([1],[2])')
assert.strictEqual(expression.toTex(), '\\left(\\begin{bmatrix}1\\\\\\end{bmatrix}\\right)\\times\\left(\\begin{bmatrix}2\\\\\\end{bmatrix}\\right)')
})
})