mirror of
https://github.com/josdejong/mathjs.git
synced 2025-12-08 19:46:04 +00:00
48 lines
1.6 KiB
JavaScript
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');
|
|
});
|
|
});
|