Skip to content

Commit feeed75

Browse files
Add simple benchmarks for osrm-* tools (#6925)
1 parent c7ee1a5 commit feeed75

File tree

1 file changed

+17
-4
lines changed

1 file changed

+17
-4
lines changed

scripts/ci/run_benchmarks.sh

Lines changed: 17 additions & 4 deletions
Original file line numberDiff line numberDiff line change
@@ -1,6 +1,18 @@
11
#!/bin/bash
22
set -eou pipefail
33

4+
function measure_peak_ram_and_time {
5+
COMMAND=$1
6+
OUTPUT_FILE=$2
7+
8+
OUTPUT=$(/usr/bin/time -f "%e %M" $COMMAND 2>&1 | tail -n 1)
9+
10+
TIME=$(echo $OUTPUT | awk '{print $1}')
11+
PEAK_RAM_KB=$(echo $OUTPUT | awk '{print $2}')
12+
PEAK_RAM_MB=$(echo "scale=2; $PEAK_RAM_KB / 1024" | bc)
13+
echo "Time: ${TIME}s Peak RAM: ${PEAK_RAM_MB}MB" > $OUTPUT_FILE
14+
}
15+
416
function run_benchmarks_for_folder {
517
echo "Running benchmarks for $1"
618

@@ -23,10 +35,11 @@ function run_benchmarks_for_folder {
2335
BINARIES_FOLDER="$FOLDER/build"
2436

2537
cp ~/data.osm.pbf $FOLDER
26-
$BINARIES_FOLDER/osrm-extract -p $FOLDER/profiles/car.lua $FOLDER/data.osm.pbf
27-
$BINARIES_FOLDER/osrm-partition $FOLDER/data.osrm
28-
$BINARIES_FOLDER/osrm-customize $FOLDER/data.osrm
29-
$BINARIES_FOLDER/osrm-contract $FOLDER/data.osrm
38+
39+
measure_peak_ram_and_time "$BINARIES_FOLDER/osrm-extract -p $FOLDER/profiles/car.lua $FOLDER/data.osm.pbf" "$RESULTS_FOLDER/osrm_extract.bench"
40+
measure_peak_ram_and_time "$BINARIES_FOLDER/osrm-partition $FOLDER/data.osrm" "$RESULTS_FOLDER/osrm_partition.bench"
41+
measure_peak_ram_and_time "$BINARIES_FOLDER/osrm-customize $FOLDER/data.osrm" "$RESULTS_FOLDER/osrm_customize.bench"
42+
measure_peak_ram_and_time "$BINARIES_FOLDER/osrm-contract $FOLDER/data.osrm" "$RESULTS_FOLDER/osrm_contract.bench"
3043

3144
if [ -f "$FOLDER/scripts/ci/locustfile.py" ]; then
3245
for ALGORITHM in mld ch; do

0 commit comments

Comments
 (0)