From 08dcab617ebe556512ec929f9dacc88fa89d709f Mon Sep 17 00:00:00 2001 From: Mathis Logemann Date: Thu, 27 Jan 2022 18:31:33 +0100 Subject: [PATCH] [CMake] add benchmark run script --- benchmark/CMakeLists.txt | 7 +++++ benchmark/run_benchmarks | 65 ++++++++++++++++++++++++++++++++++++++++ 2 files changed, 72 insertions(+) create mode 100644 benchmark/run_benchmarks diff --git a/benchmark/CMakeLists.txt b/benchmark/CMakeLists.txt index 60c4ff85f..87809b55e 100644 --- a/benchmark/CMakeLists.txt +++ b/benchmark/CMakeLists.txt @@ -36,9 +36,16 @@ function(mapnik_create_benchmark) LIBRARY_OUTPUT_DIRECTORY "${MAPNIK_OUTPUT_DIR}" RUNTIME_OUTPUT_DIRECTORY "${MAPNIK_OUTPUT_DIR}" ARCHIVE_OUTPUT_DIRECTORY "${MAPNIK_OUTPUT_DIR}/lib" + OUTPUT_NAME "${BENCHNAME}" ) endfunction() foreach(benchmark ${BENCHMARK_SRCS}) mapnik_create_benchmark(${benchmark}) endforeach() + +file(COPY data DESTINATION "${MAPNIK_OUTPUT_DIR}/benchmark") +file(COPY run_benchmarks + DESTINATION "${MAPNIK_OUTPUT_DIR}" + FILE_PERMISSIONS OWNER_READ OWNER_EXECUTE OWNER_WRITE GROUP_WRITE GROUP_READ GROUP_EXECUTE WORLD_READ +) diff --git a/benchmark/run_benchmarks b/benchmark/run_benchmarks new file mode 100644 index 000000000..4476f3a9d --- /dev/null +++ b/benchmark/run_benchmarks @@ -0,0 +1,65 @@ +#!/bin/bash + +BASE=. +function run { + local runner="$BASE/$1 --log=none" + local threads="$2" + local iters="$3" + shift 3 + $runner --threads 0 --iterations $iters "$@" + if test $threads -gt 0; then + $runner --threads $threads --iterations $((iters/threads)) "$@" + fi +} +run test_getline 30 10000000 +#run test_array_allocation 20 100000 +#run test_png_encoding1 10 1000 +#run test_png_encoding2 10 50 +#run test_to_string1 10 100000 +#run test_to_string2 10 100000 +#run test_polygon_clipping 10 1000 +#run test_polygon_clipping_rendering 10 100 +run test_proj_transform1 10 100 +run test_expression_parse 10 10000 +run test_face_ptr_creation 10 1000 +run test_font_registration 10 100 +run test_offset_converter 10 1000 +#run normalize_angle 0 1000000 --min-duration=0.2 + +# commented since this is really slow on travis +: ' +$BASE/test_rendering \ + --name "text rendering" \ + --map benchmark/data/roads.xml \ + --extent 1477001.12245,6890242.37746,1480004.49012,6892244.62256 \ + --width 600 \ + --height 600 \ + --iterations 20 \ + --threads 10 +' + +$BASE/test_rendering \ + --name "gdal tiff rendering" \ + --map benchmark/data/gdal-wgs.xml \ + --extent -180.0,-120.0,180.0,120.0 \ + --width 600 \ + --height 600 \ + --iterations 20 \ + --threads 10 + +$BASE/test_rendering \ + --name "raster tiff rendering" \ + --map benchmark/data/raster-wgs.xml \ + --extent -180.0,-120.0,180.0,120.0 \ + --width 600 \ + --height 600 \ + --iterations 20 \ + --threads 10 + +$BASE/test_quad_tree \ + --iterations 10000 \ + --threads 1 + +$BASE/test_quad_tree \ + --iterations 1000 \ + --threads 10