mathjs/test/function/combinatorics/bellNumbers.test.js

38 lines
1.4 KiB
JavaScript

var assert = require('assert'),
error = require('../../../lib/error/index'),
math = require('../../../index'),
bellNumbers = math.bellNumbers;
describe('bellNumbers', function() {
it('should calculate the number of partitions of a set', function() {
assert.equal(bellNumbers(3), 5);
assert.equal(bellNumbers(0), 1);
assert.equal(bellNumbers(8), 4140);
});
// it('should calculate the bellNumbers of n items with BigNumbers', function(){
// assert.deepEqual(bellNumbers(math.bignumber(2)), math.bignumber(2));
// // assert.deepEqual(bellNumbers(math.bignumber(10), math.bignumber(4)),math.bignumber(34105));
// // assert.deepEqual(bellNumbers(math.bignumber(8), math.bignumber(6)),math.bignumber(266));
// });
it('should not work with non-integer and negative input', function() {
assert.throws(function() {bellNumbers(0.5)}, TypeError);
assert.throws(function() {bellNumbers(-1)}, TypeError);
// assert.throws(function() {bellNumbers(math.bignumber(-3))}, TypeError);
// assert.throws(function() {bellNumbers(math.bignumber(3.5))}, TypeError);
});
it('should not work with the wrong number or type of arguments', function() {
assert.throws(function() {bellNumbers(5, 3, 2)});
assert.throws(function() {bellNumbers(true, "hello world")});
});
it('should LaTeX bellNumbers', function () {
var expression = math.parse('bellNumbers(3)');
assert.equal(expression.toTex(), '\\mathrm{B}_{3}');
});
});