
File name
Commit message
Commit date
File name
Commit message
Commit date
File name
Commit message
Commit date
/**
* Tests for numeric stability
*/
var algorithm = require('./')
, test = require('tape')
, badVector
badVector = [0.1, 0.2, 0.3, 0.4, 0.5, 0.6, 0.7, 0.8, 0.9, 1.0, 1.1, 1.2, 1.3, 1.4, 1.5, 1.6, 1.7]
test('fastSum', function (t) {
t.plan(1);
t.deepEqual(algorithm.fastTwoSum(1/3, 1/6)
, [0.5, -2.7755575615628914e-17, null]
, 'Result and error should have been returned')
});
test('nextPowerTwo', function (t) {
t.plan(1)
t.equal(algorithm.nextPowerTwo(1534)
, 2048
, 'Should be Math.pow(2, Math.ceil(algorithm.logBase2(Math.abs(1534))))')
})
test('accumulate', function (t) {
t.plan(5)
t.equal(algorithm([1,2,3,4]), 10, 'Integer sum should work')
t.equal(algorithm.dumbSum(badVector), 15.299999999999999, 'Inaccurate summation using naive method')
t.equal(algorithm(badVector), 15.3, 'Rump-Ogita-Oishi summation of insidious sum')
t.equal(algorithm([0, 0, 0]), 0, 'Rump-Ogita-Oishi summation of zero array')
t.equal(algorithm([]), 0, 'Rump-Ogita-Oishi summation of empty array')
})