To run the benchmarks:
hop --no-server -- tools/runbench.js -v3 -e hop
hop --no-server -- tools/runbench.js -v3 -e hop -e nodejs micro -D /tmp hop --no-server -- tools/runbench.js -v3 -e hop -e nodejs octane/richards.js -D /tmpTo run all the "official" benchmarks
./hopstone.sh ./hopstone.sh icfp21 ./hopstone.sh --hopc=/tmp/HOP/bin/hopc -m "a message" ./hopstone.sh --hopc=/tmp/HOP/bin/hopc -O /tmp/HOPSTONE ./hopstone.sh -e hop -e nodejs -O /tmp/HOPSTONE ./hopstone.sh -O /tmp/HOPSTONE
To run the benchmarks with Hop only:
./hopstone.sh -O /tmp/HOPSTONE -e hop
To run them all shielded
./hopstoneshield.sh --hopc=/tmp/HOP/bin/hopc -O /tmp/HOPSTONE
To run hop profile guided optimization
./hopstone.sh --hopc=/tmp/HOP/bin/hopc -e hopfprof -O /tmp/HOPSTONE
To range benchmarks:
./hoprange.sh -e hop -e nodejs -O /tmp/HOPRANGE --benchmarks="octane/richards.js octane/deltablue.js octane/boyer.js octane/earley.js octane/splay.js" ./hoprange.sh -e hop -e nodejs -e js78 -e jsc -O /tmp/HOPRANGE other/minimatch.js ./hoprange.sh -e hop -e nodejs -e js60 -e jsc -O /tmp/HOPRANGE micro/concat.js
To range one benchmark family:
./hoprange.sh -O /tmp/HOPRANGE icfp21 ./hoprange.sh -e hop -e nodejs -O /tmp/HOPRANGE jetstream ./hoprange.sh -e hop -e hopfprof -e nodejs -O /tmp/HOPRANGE micro ./hoprange.sh -e hop -e hopfprof -e hopcprof -e nodejs -O /tmp/HOPRANGE octane
To range hop vs hopold:
./hoprange.sh -e hop -e hopold -O /tmp/HOPRANGE micro
The visualize a result:
hop --no-server -- tools/logbench.js xgraph.js file1 file2 | xgraph hop --no-server -- tools/logbench.js xgraph.js dir1 dir2 | xgraph
ex:
hop --no-server -- tools/logbench.js xgraph.js LOGS/arches/boyer.log.json | xgraph hop --no-server -- tools/logbench.js xgraph.js -e hop LOGS/arches/boyer.log.json | xgraph
hop --no-server -- tools/logbench.js text.js file1 file2 hop --no-server -- tools/logbench.js text.js dir1 dir2 hop --no-server -- tools/logbench.js summary.js dir1 dir2
ex:
hop --no-server -- tools/logbench.js text.js LOGS/arches/.log.json hop --no-server -- tools/logbench.js text.js -e hop LOGS/arches/.log.json
hop --no-server -- tools/logbench.js latex.js micro
hop --no-server -- tools/logbench.js latexrel.js micro
hop --no-server -- tools/logbench.js gnuplothistogram.js *.log.json hop --no-server -- tools/logbench.js gnuplothistogram.js --logscale=y *.log.json hop --no-server -- tools/logbench.js gnuplothistogram.js --format=pdf --logscale=y *.log.json
CPU shield enables better performance reproduction
To install (on debian)
sudo apt install cpuset
To shield one processors
cset shield --cpu 1
After this processor 0 can be used for monitoring.
To run a shielded program
cset shield --exec ./a.out -- -arg1 -arg2
To reset the shielding:
cset shield --reset
To collect runtime statistics
sudo sh -c "echo -1 > /proc/sys/kernel/perf_event_paranoid" perf stat ./a.out
for permanent perf:
sudo sh -c "echo "kernel.perf_event_paranoid = -1 >> /etc/sysctl.conf"
To collect shielded runtime statistics
sudo cset shield --exec /usr/bin/perf -- stat ./a.out
To get even more stable values, PIE can be disabled with:
sudo echo 0 > /proc/sys/kernel/randomize_va_space
hopstoneshield.sh is a mere wrapper that shields 1 processor and executes hopstone.sh in the shield.
./hopstoneshield.sh ./hopstoneshield.sh --hopc=/tmp/HOP/bin/hopc -m "a message" ./hopstoneshield.sh --hopc=/tmp/HOP/bin/hopc -O /tmp/HOPSTONE