mathjs/test/function/probability/kldivergence.test.js
2015-08-01 17:26:05 +05:00

48 lines
1.6 KiB
JavaScript

var assert = require('assert');
var math = require('../../../index');
describe('kldivergence', function(){
it('should return 0, cause distributions is equals', function(){
var q = [0.1,0.4,0.5,0.2];
assert.equal(math.kldivergence(q, q), 0);
assert.equal(math.kldivergence(math.matrix(q), q), 0);
assert.equal(math.kldivergence(q, math.matrix(q)), 0);
assert.equal(math.kldivergence(math.matrix(q), math.matrix(q)), 0);
});
it('should return distance between two distrubutions', function(){
var q = [0.5,0.6,0.7];
var p = [0.4,0.5,0.6];
assert.equal(math.kldivergence(q, p), 0.00038410187968898266);
var q2 = [0.9,0.2,0.8,0.4];
var p2 = [0.1,0.8,0.7,0.6];
assert.equal(math.kldivergence(q2, p2), 0.6707144627487189);
});
it('should return normalized distance between two distributions', function(){
var q = [1,2,3,4,5,6,7,8];
var p = [2,3,4,5,6,7,8,9];
assert.equal(math.kldivergence(q, p), 0.006970870019248255);
});
it('should return infinity', function(){
var q = [1,2];
var p = [0,1];
assert.equal(math.kldivergence(q, p), Infinity);
});
it('should return NaN', function(){
var q = [-1,2];
var p = [0.4,1];
assert.equal(isNaN(parseFloat(math.kldivergence(q, p))), true);
});
it('should return bignumber', function(){
var result = math.kldivergence([math.bignumber(4),math.bignumber(7)], [math.bignumber(1), math.bignumber(4)]);
assert.equal(result.toString(), '0.0717688178200499468328227075658945850681301640503275280115029999');
});
});