From f4b2f2a329f750a6d1e4db54c0eccfa2bde701b7 Mon Sep 17 00:00:00 2001 From: Leandro Lucarella Date: Sun, 11 Jul 2010 11:42:37 -0300 Subject: [PATCH] Collect micro benchmarks run time statistics Run the micro benchmarks several times to collect timing statistics. Only the total run time is collected (in CSV format) and then the minimum, mean, maximum and standard deviation are calculated based on the collected values. Add arguments to some micro benchmarks that needed them too. --- Makefile | 56 +++++++++++++++++++++++++++++++++++++++++++------------- stats.py | 12 ++++++++++++ 2 files changed, 55 insertions(+), 13 deletions(-) create mode 100755 stats.py diff --git a/Makefile b/Makefile index 2ba5804..5ff8b62 100644 --- a/Makefile +++ b/Makefile @@ -22,28 +22,21 @@ P_LN = @printf ' LN %- 40s <- %s\n' '$@' '$<'; endif # create build directories if they don't already exist -ifneq ($(wildcard $O),$O) -dummy_mkdir := $(shell mkdir -p $O $O/bin $O/stats) -endif - -# don't use Gold with old DMDs -ifeq ($(subst dmd,,$(DC)),) -ifneq ($(strip $(shell ld --version | grep gold)),) -export LD_ := /usr/bin/ld.single -endif -endif +dummy_mkdir := $(shell mkdir -p $O $O/bin $O/time $O/stats) .PHONY: all all: cdgc basic .PHONY: cdgc basic cdgc basic: - $(P_MAKE) $(MAKE) --no-print-directory micro-build dil-build GC=$@ + $(P_MAKE) $(MAKE) --no-print-directory micro-time dil-build GC=$@ # micro ######## +micro-src := $(wildcard micro/*.d) + .PHONY: micro-build micro-build: $(patsubst micro/%.d,$O/bin/%,$(wildcard micro/*.d)) @@ -51,11 +44,27 @@ micro-build: $(patsubst micro/%.d,$O/bin/%,$(wildcard micro/*.d)) $O/bin/%: $O/micro/%.o $(P_DC) $(DC) $(LDFLAGS) -of$@ $^ +.PHONY: micro-time +micro-time: $O/time/stats.csv + .PHONY: micro-stats micro-stats: $(patsubst micro/%.d,$O/stats/%.eps,$(wildcard micro/*.d)) -# special command line arguments 'split' micro benchmark -$O/micro/split.c.csv $O/micro/split.a.csv: override args := micro/bible.txt +# special command line arguments for 'shootout_binarytrees' micro benchmark +$O/time/shootout_binarytrees.t.csv $O/time/shootout_binarytrees.s.csv \ + $O/stats/shootout_binarytrees.c.csv \ + $O/stats/shootout_binarytrees.a.csv: \ + override args := 16 + +# special command line arguments for 'split' micro benchmark +$O/time/split.t.csv $O/time/split.s.csv \ + $O/stats/split.c.csv $O/stats/split.a.csv: \ + override args := micro/bible.txt + +# special command line arguments for 'voronoi' micro benchmark +$O/time/voronoi.t.csv $O/time/voronoi.s.csv \ + $O/stats/voronoi.c.csv $O/voronoi/split.a.csv: \ + override args := -n 30000 # dil @@ -84,6 +93,27 @@ $O/bin/dil-nop: $O/bin/dil $O/%.o: %.d $(P_DC) $(DC) -c $(DFLAGS) -of$@ $^ +I := 10 +.PRECIOUS: $O/time/%.t.csv +ifeq ($F,1) +.PHONY: $(patsubst micro/%.d,$O/bin/%,$(wildcard micro/*.d)) +endif +$O/time/%.t.csv: $O/bin/% + $P echo -n ' RUN $* $(args) > $@ ($I)' + $P echo -n > $@ + $P for i in `seq $I`; do \ + echo -n " $$i"; \ + time -f%e -a -o $@ ./$< $(args); \ + done; echo + +.PRECIOUS: $O/time/stats.csv +$O/time/stats.csv: $(patsubst micro/%.d,$O/time/%.t.csv,$(micro-src)) + $P echo -n > $@ + $P for t in $^; do \ + (echo -n `basename $$t`,; ./stats.py < $$t) >> $@; \ + echo " STATS `tail -n1 $@` >> $@"; \ + done + .PRECIOUS: $O/stats/%.c.csv $O/stats/%.a.csv $O/stats/%.c.csv $O/stats/%.a.csv: $O/bin/% $(P_RUN) D_GC_STATS=1 ./$< $(args) diff --git a/stats.py b/stats.py new file mode 100755 index 0000000..fc08dd3 --- /dev/null +++ b/stats.py @@ -0,0 +1,12 @@ +#!/usr/bin/env python + +import sys +import numpy.numarray.mlab as m + +vals = [] +for l in sys.stdin: + l = l.strip() + if l: + vals.append(float(l)) +print '%s,%s,%s,%s' % (min(vals), m.mean(vals), max(vals), m.std(vals)) + -- 2.43.0