mirror of
https://github.com/josdejong/mathjs.git
synced 2025-12-08 19:46:04 +00:00
145 lines
3.8 KiB
JavaScript
145 lines
3.8 KiB
JavaScript
import assert from 'assert'
|
|
import math from '../../../../src/defaultInstance.js'
|
|
import sinon from 'sinon'
|
|
|
|
const column = math.column
|
|
const matrix = math.matrix
|
|
|
|
describe('column', function () {
|
|
const a = [
|
|
[0, 2, 0, 0, 0],
|
|
[0, 1, 0, 2, 4],
|
|
[0, 0, 0, 0, 0],
|
|
[8, 4, 0, 3, 0],
|
|
[0, 0, 0, 6, 0]
|
|
]
|
|
const m = matrix(a)
|
|
|
|
it('should throw an error if the column is out of range', function () {
|
|
assert.throws(function () {
|
|
const r = column(m, 9)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0], [0], [0], [0], [0]]
|
|
)
|
|
}, /IndexError: Index out of range \(9 > 4\)/)
|
|
})
|
|
|
|
it('should throw an error if the column is not an integer', function () {
|
|
assert.throws(function () {
|
|
const r = column(m, 'x')
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0], [0], [0], [0], [0]]
|
|
)
|
|
}, /Error: Cannot convert "x" to a number/)
|
|
})
|
|
|
|
it('should throw an error if the matrix does not have two dimensions', function () {
|
|
assert.throws(function () {
|
|
const m = matrix([[[1, 2, 3]]])
|
|
const r = column(m, 0)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0], [0], [0], [0], [0]]
|
|
)
|
|
}, /Error: Only two dimensional matrix is supported/)
|
|
})
|
|
|
|
it('should return the first matrix column', function () {
|
|
const c = column(m, 0)
|
|
assert.deepStrictEqual(
|
|
c.valueOf(), [[0], [0], [0], [8], [0]]
|
|
)
|
|
})
|
|
|
|
it('should return the first array column', function () {
|
|
const c = column(a, 0)
|
|
assert.deepStrictEqual(
|
|
c.valueOf(), [[0], [0], [0], [8], [0]]
|
|
)
|
|
})
|
|
|
|
it('should return the last matrix column', function () {
|
|
const c = column(m, 4)
|
|
assert.deepStrictEqual(
|
|
c.valueOf(), [[0], [4], [0], [0], [0]]
|
|
)
|
|
})
|
|
|
|
it('should return the last array column', function () {
|
|
const c = column(a, 4)
|
|
assert.deepStrictEqual(
|
|
c.valueOf(), [[0], [4], [0], [0], [0]]
|
|
)
|
|
})
|
|
|
|
it('should return an intermediate matrix column', function () {
|
|
const c = column(m, 1)
|
|
assert.deepStrictEqual(
|
|
c.valueOf(), [[2], [1], [0], [4], [0]]
|
|
)
|
|
})
|
|
|
|
it('should return an intermediate array column', function () {
|
|
const c = column(a, 1)
|
|
assert.deepStrictEqual(
|
|
c.valueOf(), [[2], [1], [0], [4], [0]]
|
|
)
|
|
})
|
|
|
|
it('should return the column of an 1x1 array', function () {
|
|
assert.deepStrictEqual(column([[5]], 0), [[5]])
|
|
assert.deepStrictEqual(column([[5, 6, 7]], 0), [[5]])
|
|
})
|
|
|
|
it('should return the column of an 1x1 matrix', function () {
|
|
assert.deepStrictEqual(column(matrix([[5]]), 0), matrix([[5]]))
|
|
assert.deepStrictEqual(column(matrix([[5, 6, 7]]), 0), matrix([[5]]))
|
|
})
|
|
|
|
it('should return an empty matrix column', function () {
|
|
const c = column(m, 2)
|
|
assert.deepStrictEqual(
|
|
c.valueOf(), [[0], [0], [0], [0], [0]]
|
|
)
|
|
})
|
|
|
|
it('should return an empty array column', function () {
|
|
const c = column(a, 2)
|
|
assert.deepStrictEqual(
|
|
c.valueOf(), [[0], [0], [0], [0], [0]]
|
|
)
|
|
})
|
|
|
|
it('should work with config legacySubset during deprecation', function () {
|
|
const math2 = math.create()
|
|
// Add a spy to temporarily disable console.warn
|
|
const warnStub = sinon.stub(console, 'warn')
|
|
|
|
math2.config({ legacySubset: true })
|
|
|
|
const a = [
|
|
[0, 2, 0, 0, 0],
|
|
[0, 1, 0, 2, 4],
|
|
[0, 0, 0, 0, 0],
|
|
[8, 4, 0, 3, 0],
|
|
[0, 0, 0, 6, 0]
|
|
]
|
|
// Test column with legacySubset syntax
|
|
// This is not strictly necessary and shoudl be removed after the deprecation period
|
|
|
|
assert.deepStrictEqual(
|
|
math2.column(a, 4).valueOf(), [[0], [4], [0], [0], [0]]
|
|
)
|
|
|
|
// Test column with legacySubset syntax
|
|
math2.config({ legacySubset: false })
|
|
|
|
// Test column without legacySubset syntax
|
|
assert.deepStrictEqual(
|
|
math2.column(a, 4).valueOf(), [[0], [4], [0], [0], [0]]
|
|
)
|
|
|
|
// Restore console.warn
|
|
warnStub.restore()
|
|
})
|
|
})
|