StackGenVis: Alignment of Data, Algorithms, and Models for Stacking Ensemble Learning Using Performance Metrics https://doi.org/10.1109/TVCG.2020.3030352
You can not select more than 25 topics Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
 
 
 
 
StackGenVis/frontend/node_modules/bit-twiddle/test/test.js

136 lines
3.1 KiB

var test = require("tape")
, bits = require("../twiddle.js");
var INT_MAX = bits.INT_MAX
, INT_MIN = bits.INT_MIN;
test("sign", function(t) {
t.equal(bits.sign(-100), -1)
t.equal(bits.sign(100), 1);
t.equal(bits.sign(0), 0);
t.equal(bits.sign(bits.INT_MAX), 1);
t.equal(bits.sign(bits.INT_MIN), -1);
t.end();
});
test("abs", function(t) {
t.equal(bits.abs(0), 0);
t.equal(bits.abs(1), 1);
t.equal(bits.abs(-1), 1);
t.equal(bits.abs(bits.INT_MAX), bits.INT_MAX);
t.equal(bits.abs(-bits.INT_MAX), bits.INT_MAX);
t.end();
});
test("min", function(t) {
t.equal(bits.min(0,0), 0);
t.equal(bits.min(-1,1), -1);
t.equal(bits.min(INT_MAX, INT_MAX), INT_MAX);
t.equal(bits.min(INT_MIN, INT_MIN), INT_MIN);
t.equal(bits.min(INT_MAX, INT_MIN), INT_MIN);
t.end();
});
test("max", function(t) {
t.equal(bits.max(0,0), 0);
t.equal(bits.max(-1,1), 1);
t.equal(bits.max(INT_MAX, INT_MAX), INT_MAX);
t.equal(bits.max(INT_MIN, INT_MIN), INT_MIN);
t.equal(bits.max(INT_MAX, INT_MIN), INT_MAX);
t.end();
});
test("isPow2", function(t) {
t.ok(!bits.isPow2(0));
for(var i=0; i<31; ++i) {
t.ok(bits.isPow2((1<<i)));
}
t.ok(!bits.isPow2(100));
t.ok(!bits.isPow2(0x7fffffff));
t.ok(!bits.isPow2(-1000000));
t.end();
});
test("log2", function(t) {
for(var i=0; i<31; ++i) {
if(i > 0) {
t.equal(bits.log2((1<<i)-1), i-1);
t.equal(bits.log2((1<<i)+1), i);
}
t.equal(bits.log2((1<<i)), i);
}
t.end();
});
test("popCount", function(t) {
t.equal(bits.popCount(0), 0);
t.equal(bits.popCount(1), 1);
t.equal(bits.popCount(-1), 32);
for(var i=0; i<31; ++i) {
t.equal(bits.popCount(1<<i), 1);
t.equal(bits.popCount((1<<i)-1), i);
}
t.equal(bits.popCount(0xf0f00f0f), 16);
t.end();
});
test("countTrailingZeros", function(t) {
t.equal(bits.countTrailingZeros(0), 32);
t.equal(bits.countTrailingZeros(1), 0);
t.equal(bits.countTrailingZeros(-1), 0);
for(var i=0; i<31; ++i) {
t.equal(bits.countTrailingZeros(1<<i), i);
if(i > 0) {
t.equal(bits.countTrailingZeros((1<<i)-1), 0)
}
}
t.equal(bits.countTrailingZeros(0xf81700), 8);
t.end();
});
test("nextPow2", function(t) {
for(var i=0; i<31; ++i) {
if(i !== 1) {
t.equal(bits.nextPow2((1<<i)-1), 1<<i);
}
t.equal(bits.nextPow2((1<<i)), 1<<i);
if(i < 30) {
t.equal(bits.nextPow2((1<<i)+1), 1<<(i+1));
}
}
t.end();
});
test("prevPow2", function(t) {
for(var i=0; i<31; ++i) {
if(i > 0) {
t.equal(bits.prevPow2((1<<i)-1), 1<<(i-1));
}
t.equal(bits.prevPow2((1<<i)), 1<<i);
if(0<i && i < 30) {
t.equal(bits.prevPow2((1<<i)+1), 1<<i, "i=" + i + ", " + ((1<<i)+1));
}
}
t.end();
});
test("parity", function(t) {
t.equal(bits.parity(1), 1);
t.equal(bits.parity(0), 0);
t.equal(bits.parity(0xf), 0);
t.equal(bits.parity(0x10f), 1);
t.end();
});
test("reverse", function(t) {
t.equal(bits.reverse(0), 0);
t.equal(bits.reverse(-1), -1);
t.end();
});
test("nextCombination", function(t) {
t.equal(bits.nextCombination(1), 2);
t.equal(bits.nextCombination(0x300), 0x401);
t.end();
});