time-to-botec/squiggle/node_modules/jstat/test/distribution/normal-test.js
NunoSempere b6addc7f05 feat: add the node modules
Necessary in order to clearly see the squiggle hotwiring.
2022-12-03 12:44:49 +00:00

32 lines
923 B
JavaScript

var vows = require('vows');
var assert = require('assert');
var suite = vows.describe('jStat.distribution');
require('../env.js');
suite.addBatch({
'normal pdf': {
'topic': function() {
return jStat;
},
//Checked against R's dnorm(x, mean, sd)
'check pdf calculation': function(jStat) {
var tol = 0.000001;
assert.epsilon(tol, jStat.normal.pdf(0, 0, 1.0), 0.3989423);
assert.epsilon(tol, jStat.normal.pdf(5, 10, 3.0), 0.03315905);
assert.epsilon(tol, jStat.normal.pdf(-1, 1, 0.5), 0.00026766);
},
//Checked against R's qnorm(p, mean, sd)
'check inv calculation': function(jStat) {
var tol = 0.000001;
assert.epsilon(tol, jStat.normal.inv(0.3989423, 0, 1.0), -0.2560858);
assert.epsilon(tol, jStat.normal.inv(0.05, 10, 3.0), 5.065439);
assert.epsilon(tol, jStat.normal.inv(0.65, -2, .5), -1.80734);
}
}
});
suite.export(module);