wordpos/bench/wordpos-bench.js

108 lines
2.2 KiB
JavaScript

var uubench = require('uubench'), // from: https://github.com/moos/uubench
fs = require('fs'),
_ = require('underscore')._,
WordPOS = require('../src/wordpos'),
wordpos = new WordPOS();
suite = new uubench.Suite({
type: 'fixed',
iterations: 10,
sync: true, // important!
start: function(tests){
console.log('starting %d tests', tests.length);
},
result: function(name, stats){
var persec = 1000 / stats.elapsed
, ops = .5 + stats.iterations * persec;
console.log(' \033[90m%s : \033[36m%d \033[90mops/s\033[0m', name, ops | 0, stats);
pos && console.log(out(pos));
},
done: function(time){
console.log('looked up %d words', nwords);
console.log('done in %d msecs', time );
},
section: function(name, stats) {
console.log('\033[35m%s\033[0m',name);
}
});
function out(res){
return _(res).keys().map(function(k){ return k + ':' + res[k].length });
}
var text1 = 'laksasdf',
// text128 = fs.readFileSync('text-128.txt', 'utf8'),
text512 = fs.readFileSync('text-512.txt', 'utf8'),
text, nwords,
pos;
function getPOS(next){
nwords = wordpos.getPOS(text, function(res){
pos = res;
next();
});
}
function getNouns(next){
wordpos.getNouns(text, function(res){
pos = {nouns: res};
next();
});
}
function getVerbs(next){
wordpos.getVerbs(text, function(res){
pos = {verbs: res};
next();
});
}
function getAdjectives(next){
wordpos.getAdjectives(text, function(res){
pos = {adjectives: res};
next();
});
}
function getAdverbs(next){
wordpos.getAdverbs(text, function(res){
pos = {adverbs: res};
next();
});
}
suite.section('--1 word--', function(next){
text = text1;
next();
});
suite.bench('getPOS', getPOS);
suite.bench('getNouns', getNouns);
suite.bench('getVerbs', getVerbs);
suite.bench('getAdjectives', getAdjectives);
suite.bench('getAdverbs', getAdverbs);
suite.section('--512 words--', function(next){
suite.options.iterations = 1;
text = text512;
next();
});
suite.bench('getPOS', getPOS);
suite.bench('getNouns', getNouns);
suite.bench('getVerbs', getVerbs);
suite.bench('getAdjectives', getAdjectives);
suite.bench('getAdverbs', getAdverbs);
suite.run();