# for a given node version run: | |
# for i in {0..9}; do node benchmark.js >> bench_0.6.2.log; done; | |
PATTERNS=('nodeuuid.v1()' "nodeuuid.v1('binary'," 'nodeuuid.v4()' "nodeuuid.v4('binary'," "uuid()" "uuid('binary')" 'uuidjs.create(1)' 'uuidjs.create(4)' '140byte') | |
FILES=(node_uuid_v1_string node_uuid_v1_buf node_uuid_v4_string node_uuid_v4_buf libuuid_v4_string libuuid_v4_binary uuidjs_v1_string uuidjs_v4_string 140byte_es) | |
INDICES=(2 3 2 3 2 2 2 2 2) | |
VERSIONS=$( ls bench_*.log | sed -e 's/^bench_\([0-9\.]*\)\.log/\1/' | tr "\\n" " " ) | |
TMPJOIN="tmp_join" | |
OUTPUT="bench_results.txt" | |
for I in ${!FILES[*]}; do | |
F=${FILES[$I]} | |
P=${PATTERNS[$I]} | |
INDEX=${INDICES[$I]} | |
echo "version $F" > $F | |
for V in $VERSIONS; do | |
(VAL=$( grep "$P" bench_$V.log | LC_ALL=en_US awk '{ sum += $'$INDEX' } END { print sum/NR }' ); echo $V $VAL) >> $F | |
done | |
if [ $I == 0 ]; then | |
cat $F > $TMPJOIN | |
else | |
join $TMPJOIN $F > $OUTPUT | |
cp $OUTPUT $TMPJOIN | |
fi | |
rm $F | |
done | |
rm $TMPJOIN | |
gnuplot bench.gnu | |
convert -density 200 -resize 800x560 -flatten bench.eps bench.png | |
rm bench.eps | |