jos 6e96d5a808 Merge branch 'develop' into v2
Conflicts:
	HISTORY.md
	bower.json
	component.json
	dist/math.js
	dist/math.map
	dist/math.min.js
	lib/function/arithmetic/abs.js
	lib/function/probability/gamma.js
	lib/version.js
	package.json
2015-04-22 21:43:56 +02:00

110 lines
3.3 KiB
JavaScript

var assert = require('assert');
var math = require('../../../index');
var BigNumber = math.type.BigNumber;
var Complex = math.type.Complex;
var DenseMatrix = math.type.DenseMatrix;
var Unit = math.type.Unit;
var min = math.min;
describe('min', function() {
it('should return the min between several numbers', function() {
assert.equal(min(5), 5);
assert.equal(min(1,3), 1);
assert.equal(min(3,1), 1);
assert.equal(min(1,3,5,-5,2), -5);
assert.equal(min(0,0,0,0), 0);
});
it('should return the min string following lexical order', function() {
assert.equal(min('A', 'C', 'D', 'B'), 'A');
});
it('should return the min element from a vector', function() {
assert.equal(min([1,3,5,-5,2]), -5);
});
it('should return the min of big numbers', function() {
assert.deepEqual(min(new BigNumber(1),new BigNumber(3),new BigNumber(5),new BigNumber(2),new BigNumber(-5)),
new BigNumber(-5));
});
it('should return the min element from a vector array', function() {
assert.equal(min(new DenseMatrix([1,3,5,-5,2])), -5);
});
it('should return the max element from a 2d matrix', function() {
assert.deepEqual(min([
[ 1, 4, 7],
[ 3, 0, 5],
[-1, 9, 11]
]), -1);
assert.deepEqual(min(new DenseMatrix([
[ 1, 4, 7],
[ 3, 0, 5],
[-1, 9, 11]
])), -1);
});
it('should return a reduced n-1 matrix from a n matrix', function() {
assert.deepEqual(min([
[ 1, 2, 3],
[ 4, 5, 6],
[ 7, 8, 9]], 0), [1, 2, 3]);
assert.deepEqual(min([
[ 1, 2, 3],
[ 4, 5, 6],
[ 7, 8, 9]], 1), [1, 4, 7]);
assert.deepEqual(min([
[ 1, 2, 3],
[ 6, 5, 4],
[ 8, 7, 9]], 1), [1, 4, 7]);
assert.deepEqual(min([
[ [1,2], [3,4], [5,6]],
[ [6,7], [8,9], [10,11]]], 2),
[[1, 3, 5], [6, 8, 10]]);
assert.deepEqual(min([
[ [1,2], [3,4], [5,6]],
[ [6,7], [8,9], [10,11]]], 1),
[[1, 2], [6,7]]);
assert.deepEqual(min([
[ [1,2], [3,4], [5,6]],
[ [6,7], [8,9], [10,11]]], 0),
[[1, 2], [3,4], [5,6]]);
});
it('should throw an error when called with complex numbers', function() {
assert.throws(function () {min(new Complex(2,3), new Complex(2,1))}, TypeError);
assert.throws(function () {min(new Complex(2,3), new Complex(2,5))}, TypeError);
assert.throws(function () {min(new Complex(3,4), 4)}, TypeError);
assert.throws(function () {min(new Complex(3,4), 5)}, TypeError);
assert.throws(function () {min(5, new Complex(3,4))}, TypeError);
assert.throws(function () {min(new Complex(3,4), 6)}, TypeError);
});
it('should throw an error if called a dimension out of range', function() {
assert.throws(function() {min([1,2,3], -1)}, /IndexError: Index out of range \(-1 < 0\)/);
assert.throws(function() {min([1,2,3], 1)}, /IndexError: Index out of range \(1 > 0\)/);
});
it('should throw an error if called with invalid number of arguments', function() {
assert.throws(function() {min()});
assert.throws(function() {min([], 2, 3)});
});
it('should throw an error if called with an empty array', function() {
assert.throws(function() {min([])});
});
it('should LaTeX min', function () {
var expression = math.parse('min(1,2,3)');
assert.equal(expression.toTex(), '\\min\\left(1,2,3\\right)');
});
});