-
Notifications
You must be signed in to change notification settings - Fork 5
/
Copy pathbenchmark.bash
executable file
·125 lines (115 loc) · 3.71 KB
/
benchmark.bash
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
#!/usr/bin/env bash
set -e
BUILD_DIR=./build
REPORT_DIR=./reports
STEP_IMPLEMENTATIONS_LIST=./src/step_implementations.txt
THREADS=4
TEST_ITERATIONS=1
if [ $# -ge 0 -a "$1" == '--debug' ]; then
# Debug benchmark size
BENCHMARK_SIZE=1000
MAX_ITERATIONS=10
MAX_SECONDS=60
else
# Original benchmark size
BENCHMARK_SIZE=6000
MAX_ITERATIONS=100
MAX_SECONDS=900
fi
function echo_red {
echo -e "\e[31m$@\e[0m"
}
function echo_header {
echo -e "\e[1m$@\e[0m"
}
function clean {
if [ -d "$BUILD_DIR" ]; then
echo "removing $BUILD_DIR"
rm --recursive "$BUILD_DIR"
fi
}
function check_dependencies {
local all_ok=1
local executables='python3 g++ clang++ make cmake cargo rustc'
for dep in $executables; do
local where=$(type -p $dep)
if [ -z $where ]; then
echo_red "$dep not found"
all_ok=0
else
echo "$dep is '$($where --version | head -1)' at $where"
fi
done
if [ "$all_ok" != "1" ]; then
echo_red "some dependencies are missing"
return 1
fi
}
echo_header "checking dependencies"
check_dependencies
echo
step_implementations=()
while read -r step; do
step_implementations+=("$step")
done < $STEP_IMPLEMENTATIONS_LIST
mkdir --verbose --parents ${REPORT_DIR}/{single-thread,multi-thread}/{gcc,clang,rustc}
for threads in 1 $THREADS; do
if [ $threads -eq 1 ]; then
mode=single-thread
cpu_list=0
else
mode=multi-thread
cpu_list=$(seq -s, 0 $(($threads - 1)))
fi
echo_header "$mode, gcc and rustc"
clean
export CXX=$(type -p g++)
export {OMP,RAYON}_NUM_THREADS=$threads
echo "cpu list '$cpu_list', CXX '$CXX', omp threads '$OMP_NUM_THREADS', rayon threads '$RAYON_NUM_THREADS'"
echo "building in debug mode"
if [ $threads -eq 1 ]; then
./build.py --debug --no-multi-thread --build_dir $BUILD_DIR
else
./build.py --debug --build_dir $BUILD_DIR
fi
echo "testing"
./test.py --iterations $TEST_ITERATIONS --build_dir $BUILD_DIR --threads $threads
clean
echo "building"
if [ $threads -eq 1 ]; then
./build.py --no-multi-thread --build_dir $BUILD_DIR
else
./build.py --build_dir $BUILD_DIR
fi
echo "benchmarking"
for step in ${step_implementations[*]}; do
echo "$step c++ gcc"
perf stat --field-separator=, taskset --cpu-list $cpu_list $BUILD_DIR/bin/${step}_cpp benchmark $BENCHMARK_SIZE $MAX_ITERATIONS $MAX_SECONDS &> ${REPORT_DIR}/$mode/gcc/${step}.txt
echo "$step rustc"
perf stat --field-separator=, taskset --cpu-list $cpu_list $BUILD_DIR/bin/${step}_rust benchmark $BENCHMARK_SIZE $MAX_ITERATIONS $MAX_SECONDS &> ${REPORT_DIR}/$mode/rustc/${step}.txt
done
echo_header "$mode, clang"
clean
echo "building in debug mode"
export CXX=$(type -p clang++)
echo "cpu list '$cpu_list', CXX '$CXX', omp threads '$OMP_NUM_THREADS', rayon threads '$RAYON_NUM_THREADS'"
if [ $threads -eq 1 ]; then
./build.py --debug --no-multi-thread --build_dir $BUILD_DIR
else
./build.py --debug --build_dir $BUILD_DIR
fi
echo "testing"
./test.py --no-rust --iterations $TEST_ITERATIONS --build_dir $BUILD_DIR --threads $threads
clean
echo "building"
if [ $threads -eq 1 ]; then
./build.py --no-multi-thread --build_dir $BUILD_DIR
else
./build.py --build_dir $BUILD_DIR
fi
echo "benchmarking"
for step in ${step_implementations[*]}; do
echo "$step c++ clang"
perf stat --field-separator=, taskset --cpu-list $cpu_list $BUILD_DIR/bin/${step}_cpp benchmark $BENCHMARK_SIZE $MAX_ITERATIONS $MAX_SECONDS &> ${REPORT_DIR}/$mode/clang/${step}.txt
done
done