Compare commits

..

No commits in common. "5e084b9a7143f76b51341c9261c8e47a7d63ca15" and "7dd97f6543fe53e92c5b671c49f3f021d75ff602" have entirely different histories.

3 changed files with 48 additions and 73 deletions

View file

@ -1,7 +0,0 @@
test :
node speci.js x-first
node speci.js y-first
node speci.js mixed
node speci.js rand-suffix
node speci.js rand-prefix

View file

@ -9,59 +9,44 @@ handle a couple of different variants -- but this might not be true of all
possibilities. 256 randomized variants is linearly slower. possibilities. 256 randomized variants is linearly slower.
``` ```
% make test % node speci.js
node speci.js x-first ** x_first
** x-first
run 1 run 1
189 ms 72 ms
run 2 run 2
293 ms 15 ms
run 3 run 3
178 ms 22 ms
node speci.js y-first ** y_first
** y-first
run 1 run 1
196 ms 73 ms
run 2 run 2
175 ms 23 ms
run 3 run 3
174 ms 20 ms
node speci.js mixed
** mixed ** mixed
run 1 run 1
732 ms 2766 ms
run 2 run 2
716 ms 52 ms
run 3 run 3
912 ms 53 ms
node speci.js rand-suffix ** randomized
** rand-suffix
run 1 run 1
15596 ms 464 ms
run 2 run 2
15636 ms 445 ms
run 3 run 3
15501 ms 445 ms
node speci.js rand-prefix
** rand-prefix
run 1
18896 ms
run 2
18883 ms
run 3
18784 ms
``` ```

View file

@ -1,4 +1,4 @@
function doit(mode) { function doit() {
function make_x_first(x,y) { function make_x_first(x,y) {
return {x, y}; return {x, y};
@ -16,23 +16,23 @@ function doit(mode) {
} }
} }
function make_rand_prefix(x, y) { function make_randomized(x, y) {
let rando = (Math.random() * (2 ** 32 - 1)) | 0; let rando = (Math.random() * (2 ** 32 - 1)) | 0;
let r = 'random' + rando; let buckets = 256;
let o = {[r]: r, x, y}; let r = 'random' + (rando % buckets);
return o; let o = {[r]: r};
if (Math.random() > 0.5) {
o.y = y;
o.x = x;
} else {
o.x = x;
o.y = y;
} }
function make_rand_suffix(x, y) {
let rando = (Math.random() * (2 ** 32 - 1)) | 0;
let r = 'random' + rando;
let o = {x, y, [r]: r};
return o; return o;
} }
const million = 1000 * 1000; const million = 1000 * 1000;
const n = 1 * million; const n = 10 * million;
const runs = 100 * n;
function bulk(filler) { function bulk(filler) {
let a = []; let a = [];
@ -42,22 +42,10 @@ function doit(mode) {
return a; return a;
} }
let funcMap = { const x_first = bulk(make_x_first);
'x-first': make_x_first, const y_first = bulk(make_y_first);
'y-first': make_y_first, const mixed = bulk(make_mixed);
'mixed': make_mixed, const randomized = bulk(make_randomized);
'rand-prefix': make_rand_prefix,
'rand-suffix': make_rand_suffix,
};
let func = funcMap[mode];
if (!func) {
console.log(`Pass as parameter one of:`);
for (let key of Object.keys(funcMap)) {
console.log(` ${key}`);
}
process.exit(1);
}
const data = bulk(func);
function time(func) { function time(func) {
const start = Date.now(); const start = Date.now();
@ -76,8 +64,8 @@ function doit(mode) {
console.log(`run ${i+1}`); console.log(`run ${i+1}`);
report(() => { report(() => {
let sumX = 0, sumY = 0; let sumX = 0, sumY = 0;
for (let i = 0; i < runs; i++) { for (let i = 0; i < dataSet.length; i++) {
let item = dataSet[i % dataSet.length]; let item = dataSet[i];
sumX += item.x; sumX += item.x;
sumY += item.y; sumY += item.y;
} }
@ -87,9 +75,18 @@ function doit(mode) {
} }
} }
console.log(`** ${mode}`); console.log(`** x_first`);
demo(data); demo(x_first);
console.log(`** y_first`);
demo(y_first);
console.log(`** mixed`);
demo(mixed);
console.log(`** randomized`);
demo(randomized);
} }
let mode = String(process.argv[2]); doit();
doit(mode);