https://github.com/probmods/webppl
Tip revision: 7aa98ff86162a90471b7d2e651d207237a2e29ae authored by Andreas Stuhlmüller on 13 April 2015, 15:23:03 UTC
Merge branch 'dev'
Merge branch 'dev'
Tip revision: 7aa98ff
test-util.js
'use strict';
var util = require('../src/util.js');
function testAlmostEqual(test, x, y, epsilon) {
if (x === y) {
test.equal(x, y);
} else {
test.ok(Math.abs(x - y) < epsilon);
}
}
module.exports = {
testLogSumExp: {
test1: function(test) {
var epsilon = 0.0000000001;
var xs = [-Infinity, -100, -30, -1, 0, 1, 10];
xs.forEach(
function(x) {
testAlmostEqual(test, x, util.logsumexp([x]), epsilon);
xs.forEach(
function(y) {
var targetVal = Math.log(Math.exp(x) + Math.exp(y));
var actualVal = util.logsumexp([x, y]);
testAlmostEqual(test, targetVal, actualVal, epsilon);
});
});
test.done();
}
}
};