mirror of
https://github.com/josdejong/mathjs.git
synced 2026-01-18 14:59:29 +00:00
* chore(package): update standard to version 12.0.0
* update to new lint version with --fix
I believe this mainly adds whitespace to `{}`'s.
* Replace assert.equal with assert.strictEqual
This breaks a lot of tests which I will endevour to fix in the next
commits.
* Fix most errors due to assert.strictEquals
Some instances of `strictEquals` are replaced by `deepEquals`.
`toString` has been used to make some string comparisions explicit.
Tests will still fail untill #1236 and #1237 are fixed.
* Fix assertion erros due to -0
With node 10, assert.strictEqual no longer considers `0 === -0`.
I missed these first time round as I was using node 8.
* Put toString correct side of bracket
I was converting the constructor to a string rather
than the result of the computation. Oops.
* Fixed #1236: quantileSeq has inconsistant return
* Update package-lock
* Fixed #1237: norm sometimes returning a complex number instead of number
* Fix cli tests
* More changes for standardjs, and fixes in unit tests
103 lines
4.2 KiB
JavaScript
103 lines
4.2 KiB
JavaScript
const assert = require('assert')
|
|
const error = require('../../../src/error/index')
|
|
const math = require('../../../src/main')
|
|
|
|
describe('reshape', function () {
|
|
it('should reshape an array', function () {
|
|
const array = [[0, 1, 2], [3, 4, 5]]
|
|
assert.deepStrictEqual(math.reshape(array, [3, 2]), [[0, 1], [2, 3], [4, 5]])
|
|
})
|
|
|
|
it('should reshape an array with bignumbers', function () {
|
|
const zero = math.bignumber(0)
|
|
const one = math.bignumber(1)
|
|
const two = math.bignumber(2)
|
|
const three = math.bignumber(3)
|
|
const array = [zero, one, two, three]
|
|
assert.deepStrictEqual(math.reshape(array, [two, two]),
|
|
[[zero, one], [two, three]])
|
|
})
|
|
|
|
it('should reshape a matrix', function () {
|
|
const matrix = math.matrix([[0, 1, 2], [3, 4, 5]])
|
|
assert.deepStrictEqual(math.reshape(matrix, [3, 2]),
|
|
math.matrix([[0, 1], [2, 3], [4, 5]]))
|
|
assert.deepStrictEqual(math.reshape(matrix, math.matrix([3, 2])),
|
|
math.matrix([[0, 1], [2, 3], [4, 5]]))
|
|
})
|
|
|
|
it('should reshape a flat single-element array into multiple dimensions', function () {
|
|
const array = [3]
|
|
assert.deepStrictEqual(math.reshape(array, [1, 1, 1]), [[[3]]])
|
|
})
|
|
|
|
it('should reshape a vector into a 2d matrix', function () {
|
|
const math2 = math.create({ matrix: 'Array' })
|
|
assert.deepStrictEqual(math2.reshape([1, 2, 3, 4, 5, 6], [3, 2]), [[1, 2], [3, 4], [5, 6]])
|
|
})
|
|
|
|
it('should reshape 2d matrix into a vector', function () {
|
|
const math2 = math.create({ matrix: 'Array' })
|
|
assert.deepStrictEqual(math2.reshape([[1, 2], [3, 4], [5, 6]], [6]), [1, 2, 3, 4, 5, 6])
|
|
})
|
|
|
|
it('should throw an error on invalid arguments', function () {
|
|
assert.throws(function () { math.reshape() }, /Too few arguments/)
|
|
assert.throws(function () { math.reshape([]) }, /Too few arguments/)
|
|
assert.throws(function () { math.reshape([], 2) }, TypeError)
|
|
assert.throws(function () { math.reshape([], [], 4) }, /Too many arguments/)
|
|
|
|
assert.throws(function () { math.reshape([], ['no number']) }, /Cannot convert/)
|
|
assert.throws(function () { math.reshape([], [2.3]) }, /Invalid size/)
|
|
|
|
assert.throws(function () { math.reshape([1, 2], []) }, error.DimensionError)
|
|
assert.throws(function () { math.reshape([1, 2], [0]) }, error.DimensionError)
|
|
assert.throws(function () { math.reshape([1, 2], [0, 0]) }, error.DimensionError)
|
|
assert.throws(function () { math.reshape([[1, 2]], [0]) }, error.DimensionError)
|
|
assert.doesNotThrow(function () { math.reshape([[1, 2]], [2, 1]) })
|
|
assert.doesNotThrow(function () { math.reshape([[1, 2]], [2]) })
|
|
})
|
|
|
|
it('should LaTeX reshape', function () {
|
|
const expression = math.parse('reshape([1,2],1)')
|
|
assert.strictEqual(expression.toTex(), '\\mathrm{reshape}\\left(\\begin{bmatrix}1\\\\2\\\\\\end{bmatrix},1\\right)')
|
|
})
|
|
|
|
it('should reshape a SparseMatrix', function () {
|
|
/*
|
|
* Must use toArray because SparseMatrix.reshape currently does not preserve
|
|
* the order of the _index and _values arrays (this does not matter?)
|
|
*/
|
|
|
|
let matrix = math.matrix([[0, 1, 2], [3, 4, 5]], 'sparse')
|
|
assert.deepStrictEqual(math.reshape(matrix, [3, 2]).toArray(),
|
|
[[0, 1], [2, 3], [4, 5]])
|
|
|
|
assert.deepStrictEqual(math.reshape(matrix, [6, 1]).toArray(),
|
|
[[0], [1], [2], [3], [4], [5]])
|
|
|
|
assert.deepStrictEqual(math.reshape(matrix, [1, 6]).toArray(),
|
|
[[0, 1, 2, 3, 4, 5]])
|
|
|
|
matrix = math.matrix([[0, 1, 2, 3, 4, 5]], 'sparse')
|
|
assert.deepStrictEqual(math.reshape(matrix, [3, 2]).toArray(),
|
|
[[0, 1], [2, 3], [4, 5]])
|
|
|
|
matrix = math.matrix([[0], [1], [2], [3], [4], [5]], 'sparse')
|
|
assert.deepStrictEqual(math.reshape(matrix, [3, 2]).toArray(),
|
|
[[0, 1], [2, 3], [4, 5]])
|
|
})
|
|
|
|
it('should throw on attempting to reshape an ImmutableDenseMatrix', function () {
|
|
const immutableMatrix = new math.type.ImmutableDenseMatrix([[1, 2], [3, 4]])
|
|
assert.throws(function () { math.reshape(immutableMatrix, [1, 4]) },
|
|
/Cannot invoke reshape on an Immutable Matrix instance/)
|
|
})
|
|
|
|
it('should throw on attempting to reshape a Matrix (abstract type)', function () {
|
|
const matrix = new math.type.Matrix([[1, 2], [3, 4]])
|
|
assert.throws(function () { math.reshape(matrix, [1, 4]) },
|
|
/Cannot invoke reshape on a Matrix interface/)
|
|
})
|
|
})
|