mirror of
https://github.com/josdejong/mathjs.git
synced 2026-01-18 14:59:29 +00:00
165 lines
5.6 KiB
JavaScript
165 lines
5.6 KiB
JavaScript
// test transpose
|
|
var assert = require('assert'),
|
|
math = require('../../../src/index'),
|
|
ctranspose = math.ctranspose;
|
|
|
|
describe('ctranspose', function() {
|
|
|
|
it('should transpose a real scalar', function() {
|
|
assert.deepEqual(ctranspose(3), 3);
|
|
});
|
|
|
|
it('should conjugate a complex scalar', function() {
|
|
assert.deepEqual(ctranspose(math.complex(3,4)), math.complex(3,-4));
|
|
});
|
|
|
|
it('should transpose a vector', function() {
|
|
assert.deepEqual(ctranspose([1,2,3]), [1,2,3]);
|
|
assert.deepEqual(ctranspose(math.matrix([1,2,3]).toArray()), [1,2,3]);
|
|
});
|
|
|
|
it('should conjgate a complex vector', function() {
|
|
var a = math.complex(1,2);
|
|
var b = math.complex(3,4);
|
|
var c = math.complex(5,6);
|
|
var aH = math.complex(1,-2);
|
|
var bH = math.complex(3,-4);
|
|
var cH = math.complex(5,-6);
|
|
assert.deepEqual(ctranspose([a,b,c]),[aH,bH,cH]);
|
|
assert.deepEqual(ctranspose(math.matrix([a,b,c])).toArray(), [aH,bH,cH]);
|
|
});
|
|
|
|
it('should transpose a 2d matrix', function() {
|
|
assert.deepEqual(ctranspose([[1,2,3],[4,5,6]]), [[1,4],[2,5],[3,6]]);
|
|
assert.deepEqual(ctranspose(math.matrix([[1,2,3],[4,5,6]]).toArray()), [[1,4],[2,5],[3,6]]);
|
|
assert.deepEqual(ctranspose([[1,2],[3,4]]), [[1,3],[2,4]]);
|
|
assert.deepEqual(ctranspose([[1,2,3,4]]), [[1],[2],[3],[4]]);
|
|
});
|
|
|
|
it('should conjugate transpose a 2d complex matrix', function() {
|
|
var a = math.complex(1,2);
|
|
var b = math.complex(3,4);
|
|
var c = math.complex(5,6);
|
|
var d = math.complex(7,8);
|
|
var e = math.complex(9,10);
|
|
var f = math.complex(11,12);
|
|
var aH = math.complex(1,-2);
|
|
var bH = math.complex(3,-4);
|
|
var cH = math.complex(5,-6);
|
|
var dH = math.complex(7,-8);
|
|
var eH = math.complex(9,-10);
|
|
var fH = math.complex(11,-12);
|
|
assert.deepEqual(ctranspose([[a,b,c],[d,e,f]]), [[aH,dH],[bH,eH],[cH,fH]]);
|
|
assert.deepEqual(ctranspose(math.matrix([[a,b,c],[d,e,f]])).toArray(), [[aH,dH],[bH,eH],[cH,fH]]);
|
|
assert.deepEqual(ctranspose([[a,b],[c,d]]), [[aH,cH],[bH,dH]]);
|
|
assert.deepEqual(ctranspose([[a,b,c,d]]), [[aH],[bH],[cH],[dH]]);
|
|
});
|
|
|
|
it('should throw an error for invalid matrix transpose', function() {
|
|
assert.throws(function () {
|
|
assert.deepEqual(ctranspose([[]]), [[]]); // size [2,0]
|
|
});
|
|
assert.throws(function () {
|
|
ctranspose([[[1],[2]],[[3],[4]]]); // size [2,2,1]
|
|
});
|
|
});
|
|
|
|
it('should throw an error if called with an invalid number of arguments', function() {
|
|
assert.throws(function () {ctranspose();}, /TypeError: Too few arguments/);
|
|
assert.throws(function () {ctranspose([1,2],2);}, /TypeError: Too many arguments/);
|
|
});
|
|
|
|
describe('DenseMatrix', function () {
|
|
|
|
it('should transpose a 2d matrix', function() {
|
|
var a = math.complex(1,2);
|
|
var b = math.complex(3,4);
|
|
var c = math.complex(5,6);
|
|
var d = math.complex(7,8);
|
|
var e = math.complex(9,10);
|
|
var f = math.complex(11,12);
|
|
var aH = math.complex(1,-2);
|
|
var bH = math.complex(3,-4);
|
|
var cH = math.complex(5,-6);
|
|
var dH = math.complex(7,-8);
|
|
var eH = math.complex(9,-10);
|
|
var fH = math.complex(11,-12);
|
|
var m = math.matrix([[a,b,c],[d,e,f]])
|
|
var t = ctranspose(m);
|
|
assert.deepEqual(t.valueOf(), [[aH,dH],[bH,eH],[cH,fH]]);
|
|
|
|
m = math.matrix([[a,b],[c,d],[e,f]])
|
|
t = ctranspose(m);
|
|
assert.deepEqual(t.toArray(), [[aH,cH,eH],[bH,dH,fH]]);
|
|
|
|
m = math.matrix([[a,b],[c,d]])
|
|
t = ctranspose(m);
|
|
assert.deepEqual(t.valueOf(), [[aH,cH],[bH,dH]]);
|
|
|
|
m = math.matrix([[a,b,c,d]])
|
|
t = ctranspose(m);
|
|
assert.deepEqual(t.valueOf(), [[aH],[bH],[cH],[dH]]);
|
|
|
|
m = math.matrix([[a,b],[c,d]], 'dense', 'number');
|
|
t = ctranspose(m);
|
|
assert.deepEqual(t.valueOf(), [[aH,cH],[bH,dH]]);
|
|
assert.ok(t.datatype() === 'number');
|
|
});
|
|
|
|
it('should throw an error for invalid matrix transpose', function() {
|
|
var m = math.matrix([[]]);
|
|
assert.throws(function () { transpose(m); });
|
|
|
|
m = math.matrix([[[1],[2]],[[3],[4]]]);
|
|
assert.throws(function () { transpose(m); });
|
|
});
|
|
});
|
|
|
|
describe('SparseMatrix', function () {
|
|
|
|
it('should transpose a 2d matrix', function() {
|
|
var a = math.complex(1,2);
|
|
var b = math.complex(3,4);
|
|
var c = math.complex(5,6);
|
|
var d = math.complex(7,8);
|
|
var e = math.complex(9,10);
|
|
var f = math.complex(11,12);
|
|
var aH = math.complex(1,-2);
|
|
var bH = math.complex(3,-4);
|
|
var cH = math.complex(5,-6);
|
|
var dH = math.complex(7,-8);
|
|
var eH = math.complex(9,-10);
|
|
var fH = math.complex(11,-12);
|
|
var m = math.sparse([[a,b,c],[d,e,f]]);
|
|
var t = ctranspose(m);
|
|
assert.deepEqual(t.valueOf(), [[aH,dH],[bH,eH],[cH,fH]]);
|
|
|
|
m = math.sparse([[a,b],[c,d],[e,f]]);
|
|
t = ctranspose(m);
|
|
assert.deepEqual(t.toArray(), [[aH,cH,eH],[bH,dH,fH]]);
|
|
|
|
m = math.sparse([[a,b],[c,d]])
|
|
t = ctranspose(m);
|
|
assert.deepEqual(t.valueOf(), [[aH,cH],[bH,dH]]);
|
|
|
|
/* Failing test, but I'm not sure if would be expected to pass */
|
|
/*
|
|
m = math.sparse([[1,2,3,4]], 'number');
|
|
t = ctranspose(m);
|
|
assert.deepEqual(t.valueOf(), [[1],[2],[3],[4]]);
|
|
assert.ok(t.datatype() === 'number');
|
|
*/
|
|
});
|
|
|
|
it('should throw an error for invalid matrix transpose', function() {
|
|
var m = math.matrix([[]], 'sparse');
|
|
assert.throws(function () { transpose(m); });
|
|
});
|
|
});
|
|
|
|
it('should LaTeX transpose', function () {
|
|
var expression = math.parse('ctranspose([[1+2i,3+4i],[5+6i,7+8i]])');
|
|
assert.equal(expression.toTex(), '\\left(\\begin{bmatrix}1+2~ i&3+4~ i\\\\5+6~ i&7+8~ i\\\\\\end{bmatrix}\\right)^H');
|
|
});
|
|
});
|