mirror of
https://github.com/josdejong/mathjs.git
synced 2026-01-18 14:59:29 +00:00
89 lines
3.9 KiB
JavaScript
89 lines
3.9 KiB
JavaScript
// test data type Complex
|
|
|
|
var assert = require('assert');
|
|
var math = require('../../math.js'),
|
|
Complex = math.Complex;
|
|
|
|
var complex1 = new Complex(3, -4);
|
|
assert.equal(complex1.re, 3);
|
|
assert.equal(complex1.im, -4);
|
|
assert.equal(complex1, '3 - 4i');
|
|
assert.throws(function () { Complex(3, -4); });
|
|
|
|
// test constructor and parser
|
|
assert.equal(new Complex().toString(), '0');
|
|
assert.equal(new Complex(2, 3).toString(), '2 + 3i');
|
|
assert.equal(new Complex(2, 0).toString(), '2');
|
|
assert.equal(new Complex(0, 3).toString(), '3i');
|
|
assert.equal(new Complex('2 + 3i').toString(), '2 + 3i');
|
|
assert.equal(new Complex('2 +3i').toString(), '2 + 3i');
|
|
assert.equal(new Complex('2+3i').toString(), '2 + 3i');
|
|
assert.equal(new Complex(' 2+3i ').toString(), '2 + 3i');
|
|
assert.equal(new Complex('2-3i').toString(), '2 - 3i');
|
|
assert.equal(new Complex('2 + i').toString(), '2 + i');
|
|
assert.equal(new Complex('-2-3i').toString(), '-2 - 3i');
|
|
assert.equal(new Complex('-2+3i').toString(), '-2 + 3i');
|
|
assert.equal(new Complex('-2+-3i').toString(), '-2 - 3i');
|
|
assert.equal(new Complex('-2-+3i').toString(), '-2 - 3i');
|
|
assert.equal(new Complex('+2-+3i').toString(), '2 - 3i');
|
|
assert.equal(new Complex('+2-+3i').toString(), '2 - 3i');
|
|
assert.equal(new Complex('2 + 3i').toString(), '2 + 3i');
|
|
assert.equal(new Complex('2 - -3i').toString(), '2 + 3i');
|
|
assert.equal(new Complex(' 2 + 3i ').toString(), '2 + 3i');
|
|
assert.equal(new Complex('2 + i').toString(), '2 + i');
|
|
assert.equal(new Complex('2 - i').toString(), '2 - i');
|
|
assert.equal(new Complex('2 + -i').toString(), '2 - i');
|
|
assert.equal(new Complex('-2+3e-1i').toString(), '-2 + 0.3i');
|
|
assert.equal(new Complex('-2+3e+1i').toString(), '-2 + 30i');
|
|
assert.equal(new Complex('2+3e2i').toString(), '2 + 300i');
|
|
assert.equal(new Complex('2.2e-1-3.2e-1i').toString(), '0.22 - 0.32i');
|
|
assert.equal(new Complex('2.2e-1-+3.2e-1i').toString(), '0.22 - 0.32i');
|
|
assert.equal(new Complex('2').toString(), '2');
|
|
assert.equal(new Complex('i').toString(), 'i');
|
|
assert.equal(new Complex(' i ').toString(), 'i');
|
|
assert.equal(new Complex('-i').toString(), '-i');
|
|
assert.equal(new Complex(' -i ').toString(), '-i');
|
|
assert.equal(new Complex('+i').toString(), 'i');
|
|
assert.equal(new Complex(' +i ').toString(), 'i');
|
|
assert.equal(new Complex('-2').toString(), '-2');
|
|
assert.equal(new Complex('3I').toString(), '3i');
|
|
assert.equal(new Complex('-3i').toString(), '-3i');
|
|
assert.throws(function () { new Complex(1, 2, 3); });
|
|
assert.throws(function () { new Complex('str', 2); });
|
|
assert.throws(function () { new Complex(1, true); });
|
|
assert.throws(function () { new Complex(2); });
|
|
assert.throws(function () { new Complex(''); });
|
|
assert.throws(function () { new Complex('2r'); });
|
|
assert.throws(function () { new Complex('str'); });
|
|
assert.throws(function () { new Complex('2i+3i'); });
|
|
assert.throws(function () { new Complex('2ia'); });
|
|
assert.throws(function () { new Complex('3+4'); });
|
|
assert.throws(function () { new Complex('3i+4'); });
|
|
assert.throws(function () { new Complex('3e + 4i'); });
|
|
assert.throws(function () { new Complex('3e1.2 + 4i'); });
|
|
assert.throws(function () { new Complex('3e1.2i'); });
|
|
assert.throws(function () { new Complex('3e1.2i'); });
|
|
assert.throws(function () { new Complex('- i'); });
|
|
assert.throws(function () { new Complex('+ i'); });
|
|
|
|
// test toString
|
|
assert.equal(new Complex().toString(), '0');
|
|
assert.equal(new Complex(0, 2).toString(), '2i');
|
|
assert.equal(new Complex(1, 1).toString(), '1 + i');
|
|
assert.equal(new Complex(1, 2).toString(), '1 + 2i');
|
|
assert.equal(new Complex(1, -1).toString(), '1 - i');
|
|
assert.equal(new Complex(1, -2).toString(), '1 - 2i');
|
|
assert.equal(new Complex(1, 0).toString(), '1');
|
|
assert.equal(new Complex(-1, 2).toString(), '-1 + 2i');
|
|
assert.equal(new Complex(-1, 1).toString(), '-1 + i');
|
|
|
|
// test clone
|
|
var clone = complex1.clone();
|
|
clone.re = 100;
|
|
clone.im = 200;
|
|
assert.notEqual(complex1, clone);
|
|
assert.equal(complex1.re, 3);
|
|
assert.equal(complex1.im, -4);
|
|
assert.equal(clone.re, 100);
|
|
assert.equal(clone.im, 200);
|