mirror of
https://github.com/josdejong/mathjs.git
synced 2025-12-08 19:46:04 +00:00
144 lines
3.6 KiB
JavaScript
144 lines
3.6 KiB
JavaScript
import assert from 'assert'
|
|
import math from '../../../../src/defaultInstance.js'
|
|
import sinon from 'sinon'
|
|
|
|
const row = math.row
|
|
const matrix = math.matrix
|
|
|
|
describe('row', 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 row is out of range', function () {
|
|
assert.throws(function () {
|
|
const r = row(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 row is not an integer', function () {
|
|
assert.throws(function () {
|
|
const r = row(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 = row(m, 0)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0], [0], [0], [0], [0]]
|
|
)
|
|
}, /Error: Only two dimensional matrix is supported/)
|
|
})
|
|
|
|
it('should return the first matrix row', function () {
|
|
const r = row(m, 0)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0, 2, 0, 0, 0]]
|
|
)
|
|
})
|
|
|
|
it('should return the first array row', function () {
|
|
const r = row(a, 0)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0, 2, 0, 0, 0]]
|
|
)
|
|
})
|
|
|
|
it('should return the last matrix row', function () {
|
|
const r = row(m, 4)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0, 0, 0, 6, 0]]
|
|
)
|
|
})
|
|
|
|
it('should return the last array row', function () {
|
|
const r = row(a, 4)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0, 0, 0, 6, 0]]
|
|
)
|
|
})
|
|
|
|
it('should return an intermediate matrix row', function () {
|
|
const r = row(m, 1)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0, 1, 0, 2, 4]]
|
|
)
|
|
})
|
|
|
|
it('should return an intermediate array row', function () {
|
|
const r = row(a, 1)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0, 1, 0, 2, 4]]
|
|
)
|
|
})
|
|
|
|
it('should return the row of an 1x1 array', function () {
|
|
assert.deepStrictEqual(row([[5]], 0), [[5]])
|
|
assert.deepStrictEqual(row([[5], [6], [7]], 0), [[5]])
|
|
})
|
|
|
|
it('should return the row of an 1x1 matrix', function () {
|
|
assert.deepStrictEqual(row(matrix([[5]]), 0), matrix([[5]]))
|
|
assert.deepStrictEqual(row(matrix([[5], [6], [7]]), 0), matrix([[5]]))
|
|
})
|
|
|
|
it('should return an empty matrix row', function () {
|
|
const r = row(m, 2)
|
|
assert.deepStrictEqual(
|
|
r.valueOf(), [[0, 0, 0, 0, 0]]
|
|
)
|
|
})
|
|
|
|
it('should return an empty array row', function () {
|
|
const r = row(a, 2)
|
|
assert.deepStrictEqual(
|
|
r.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 row with legacySubset syntax
|
|
// This is not strictly necessary and should be removed after the deprecation period
|
|
assert.deepStrictEqual(
|
|
math2.row(a, 3).valueOf(), [[8, 4, 0, 3, 0]]
|
|
)
|
|
|
|
// Test row without legacySubset syntax
|
|
math2.config({ legacySubset: false })
|
|
|
|
assert.deepStrictEqual(
|
|
math2.row(a, 3).valueOf(), [[8, 4, 0, 3, 0]]
|
|
)
|
|
|
|
// Restore console.warn
|
|
warnStub.restore()
|
|
})
|
|
})
|