-
Notifications
You must be signed in to change notification settings - Fork 52
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
Add CPU and CUDA benchmark for toy detector propagation
- Loading branch information
1 parent
8740109
commit 129f147
Showing
10 changed files
with
611 additions
and
1 deletion.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# TRACCC library, part of the ACTS project (R&D line) | ||
# | ||
# (c) 2024 CERN for the benefit of the ACTS project | ||
# | ||
# Mozilla Public License Version 2.0 | ||
|
||
# Project include(s). | ||
include( traccc-compiler-options-cpp ) | ||
|
||
# Set up a common library, shared by all of the tests. | ||
add_library( traccc_benchmarks_common STATIC | ||
"common/benchmarks/toy_detector_benchmark.hpp" ) | ||
target_include_directories( traccc_benchmarks_common | ||
PUBLIC ${CMAKE_CURRENT_SOURCE_DIR}/common ) | ||
target_link_libraries( traccc_benchmarks_common | ||
PUBLIC benchmark::benchmark benchmark::benchmark_main | ||
traccc::core traccc::io traccc::simulation detray::core detray::utils | ||
vecmem::core Boost::filesystem) | ||
|
||
add_subdirectory(cpu) | ||
if( TRACCC_BUILD_CUDA ) | ||
add_subdirectory(cuda) | ||
endif() |
180 changes: 180 additions & 0 deletions
180
benchmarks/common/benchmarks/toy_detector_benchmark.hpp
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,180 @@ | ||
/** TRACCC library, part of the ACTS project (R&D line) | ||
* | ||
* (c) 2024 CERN for the benefit of the ACTS project | ||
* | ||
* Mozilla Public License Version 2.0 | ||
*/ | ||
|
||
// Traccc include(s). | ||
#include "traccc/definitions/common.hpp" | ||
#include "traccc/finding/finding_algorithm.hpp" | ||
#include "traccc/fitting/fitting_algorithm.hpp" | ||
#include "traccc/io/utils.hpp" | ||
#include "traccc/seeding/seeding_algorithm.hpp" | ||
#include "traccc/seeding/track_params_estimation.hpp" | ||
#include "traccc/simulation/measurement_smearer.hpp" | ||
#include "traccc/simulation/simulator.hpp" | ||
#include "traccc/simulation/smearing_writer.hpp" | ||
|
||
// Detray include(s). | ||
#include "detray/core/detector.hpp" | ||
#include "detray/definitions/units.hpp" | ||
#include "detray/detectors/bfield.hpp" | ||
#include "detray/detectors/build_toy_detector.hpp" | ||
#include "detray/geometry/mask.hpp" | ||
#include "detray/geometry/shapes/rectangle2D.hpp" | ||
#include "detray/io/frontend/detector_reader.hpp" | ||
#include "detray/io/frontend/detector_writer.hpp" | ||
#include "detray/navigation/detail/ray.hpp" | ||
#include "detray/navigation/navigator.hpp" | ||
#include "detray/propagator/propagator.hpp" | ||
#include "detray/propagator/rk_stepper.hpp" | ||
#include "detray/simulation/event_generator/track_generators.hpp" | ||
|
||
// VecMem include(s). | ||
#include <vecmem/memory/host_memory_resource.hpp> | ||
|
||
// Boost include(s). | ||
#include <boost/filesystem.hpp> | ||
|
||
// Google Benchmark include(s). | ||
#include <benchmark/benchmark.h> | ||
|
||
namespace {} // namespace | ||
|
||
class ToyDetectorBenchmark : public benchmark::Fixture { | ||
public: | ||
static const int n_events = 100u; | ||
static const int n_tracks = 5000u; | ||
|
||
std::vector<traccc::spacepoint_collection_types::host> spacepoints; | ||
std::vector<traccc::measurement_collection_types::host> measurements; | ||
|
||
// Configs | ||
traccc::seedfinder_config seeding_cfg; | ||
traccc::seedfilter_config filter_cfg; | ||
traccc::spacepoint_grid_config grid_cfg{seeding_cfg}; | ||
traccc::finding_config<float> finding_cfg; | ||
traccc::fitting_config fitting_cfg; | ||
|
||
static constexpr std::array<float, 2> phi_range{ | ||
-traccc::constant<float>::pi, traccc::constant<float>::pi}; | ||
static constexpr std::array<float, 2> theta_range{ | ||
0.f, traccc::constant<float>::pi}; | ||
static constexpr std::array<float, 2> mom_range{ | ||
10.f * traccc::unit<float>::GeV, 100.f * traccc::unit<float>::GeV}; | ||
|
||
static inline const std::string sim_dir = "toy_detector_benchmark/"; | ||
|
||
// Detector type | ||
using detector_type = detray::detector<detray::toy_metadata>; | ||
|
||
// B field value and its type | ||
// @TODO: Set B field as argument | ||
using b_field_t = covfie::field<detray::bfield::const_bknd_t>; | ||
|
||
static constexpr traccc::vector3 B{0, 0, | ||
2 * detray::unit<traccc::scalar>::T}; | ||
|
||
ToyDetectorBenchmark() { | ||
|
||
// VecMem memory resource(s) | ||
vecmem::host_memory_resource host_mr; | ||
|
||
// Use deterministic random number generator for testing | ||
using uniform_gen_t = detray::detail::random_numbers< | ||
traccc::scalar, std::uniform_real_distribution<traccc::scalar>>; | ||
|
||
// Build the detector | ||
auto [det, name_map] = | ||
detray::build_toy_detector(host_mr, get_toy_config()); | ||
|
||
// B field | ||
auto field = detray::bfield::create_const_field(B); | ||
|
||
// Origin of particles | ||
using generator_type = | ||
detray::random_track_generator<traccc::free_track_parameters, | ||
uniform_gen_t>; | ||
generator_type::configuration gen_cfg{}; | ||
gen_cfg.n_tracks(n_tracks); | ||
gen_cfg.phi_range(phi_range); | ||
gen_cfg.theta_range(theta_range); | ||
gen_cfg.mom_range(mom_range); | ||
generator_type generator(gen_cfg); | ||
|
||
// Smearing value for measurements | ||
traccc::measurement_smearer<traccc::default_algebra> meas_smearer( | ||
50 * detray::unit<traccc::scalar>::um, | ||
50 * detray::unit<traccc::scalar>::um); | ||
|
||
// Type declarations | ||
using writer_type = traccc::smearing_writer< | ||
traccc::measurement_smearer<traccc::default_algebra>>; | ||
|
||
// Writer config | ||
typename writer_type::config smearer_writer_cfg{meas_smearer}; | ||
|
||
// Run simulator | ||
const std::string full_path = traccc::io::data_directory() + sim_dir; | ||
|
||
boost::filesystem::create_directories(full_path); | ||
|
||
auto sim = traccc::simulator<detector_type, b_field_t, generator_type, | ||
writer_type>( | ||
n_events, det, field, std::move(generator), | ||
std::move(smearer_writer_cfg), full_path); | ||
|
||
sim.run(); | ||
|
||
// Write detector file | ||
auto writer_cfg = detray::io::detector_writer_config{} | ||
.format(detray::io::format::json) | ||
.replace_files(true) | ||
.write_grids(true) | ||
.write_material(true) | ||
.path(sim_dir); | ||
detray::io::write_detector(det, name_map, writer_cfg); | ||
} | ||
|
||
detray::toy_det_config get_toy_config() const { | ||
|
||
// Create the toy geometry | ||
detray::toy_det_config toy_cfg{}; | ||
toy_cfg.n_brl_layers(4u).n_edc_layers(7u).do_check(false); | ||
|
||
// @TODO: Increase the material budget again | ||
toy_cfg.module_mat_thickness(0.11f * detray::unit<traccc::scalar>::mm); | ||
|
||
return toy_cfg; | ||
} | ||
|
||
void SetUp(::benchmark::State& /*state*/) { | ||
|
||
// VecMem memory resource(s) | ||
vecmem::host_memory_resource host_mr; | ||
|
||
// Build the detector | ||
auto [det, name_map] = | ||
detray::build_toy_detector(host_mr, get_toy_config()); | ||
|
||
// Read geometry | ||
traccc::geometry surface_transforms = | ||
traccc::io::alt_read_geometry(det); | ||
|
||
// Read events | ||
for (std::size_t i_evt = 0; i_evt < n_events; i_evt++) { | ||
|
||
// Read the hits from the relevant event file | ||
traccc::io::spacepoint_reader_output readOut(&host_mr); | ||
traccc::io::read_spacepoints(readOut, i_evt, sim_dir, | ||
surface_transforms); | ||
spacepoints.push_back(readOut.spacepoints); | ||
|
||
// Read measurements | ||
traccc::io::measurement_reader_output meas_read_out(&host_mr); | ||
traccc::io::read_measurements(meas_read_out, i_evt, sim_dir); | ||
measurements.push_back(meas_read_out.measurements); | ||
} | ||
} | ||
}; |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,23 @@ | ||
# TRACCC library, part of the ACTS project (R&D line) | ||
# | ||
# (c) 2024 CERN for the benefit of the ACTS project | ||
# | ||
# Mozilla Public License Version 2.0 | ||
|
||
# Look for openMP, which is used for the CPU benchmark | ||
find_package(OpenMP) | ||
|
||
# Build the benchmark executable. | ||
traccc_add_executable(benchmark_cpu | ||
"toy_detector_cpu.cpp" | ||
LINK_LIBRARIES benchmark::benchmark benchmark::benchmark_main | ||
traccc::core traccc_benchmarks_common | ||
detray::core detray::utils vecmem::core) | ||
|
||
# Optimize the cpu benchmark (e.g. auto-vectorization) | ||
target_compile_options(traccc_benchmark_cpu PRIVATE | ||
"-march=native" "-ftree-vectorize") | ||
|
||
if(OpenMP_CXX_FOUND) | ||
target_link_libraries(traccc_benchmark_cpu PRIVATE OpenMP::OpenMP_CXX) | ||
endif() |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,97 @@ | ||
/** TRACCC library, part of the ACTS project (R&D line) | ||
* | ||
* (c) 2024 CERN for the benefit of the ACTS project | ||
* | ||
* Mozilla Public License Version 2.0 | ||
*/ | ||
|
||
// Traccc algorithm include(s). | ||
#include "traccc/finding/finding_algorithm.hpp" | ||
#include "traccc/fitting/fitting_algorithm.hpp" | ||
#include "traccc/seeding/seeding_algorithm.hpp" | ||
#include "traccc/seeding/track_params_estimation.hpp" | ||
|
||
// Traccc IO include(s). | ||
#include "traccc/io/event_map2.hpp" | ||
#include "traccc/io/read_geometry.hpp" | ||
#include "traccc/io/read_measurements.hpp" | ||
#include "traccc/io/read_spacepoints.hpp" | ||
|
||
// Local include(s). | ||
#include "benchmarks/toy_detector_benchmark.hpp" | ||
|
||
// Detray include(s). | ||
#include "detray/core/detector.hpp" | ||
#include "detray/detectors/bfield.hpp" | ||
#include "detray/io/frontend/detector_reader.hpp" | ||
#include "detray/navigation/navigator.hpp" | ||
#include "detray/propagator/propagator.hpp" | ||
#include "detray/propagator/rk_stepper.hpp" | ||
|
||
// VecMem include(s). | ||
#include <vecmem/memory/host_memory_resource.hpp> | ||
|
||
// Google benchmark include(s). | ||
#include <benchmark/benchmark.h> | ||
|
||
BENCHMARK_F(ToyDetectorBenchmark, CPU)(benchmark::State& state) { | ||
|
||
// Type declarations | ||
using rk_stepper_type = | ||
detray::rk_stepper<b_field_t::view_t, | ||
typename detector_type::algebra_type, | ||
detray::constrained_step<>>; | ||
using host_detector_type = detray::detector<detray::default_metadata>; | ||
using host_navigator_type = detray::navigator<const host_detector_type>; | ||
using host_fitter_type = | ||
traccc::kalman_fitter<rk_stepper_type, host_navigator_type>; | ||
|
||
// VecMem memory resource(s) | ||
vecmem::host_memory_resource host_mr; | ||
|
||
// Read back detector file | ||
const std::string path = sim_dir; | ||
detray::io::detector_reader_config reader_cfg{}; | ||
reader_cfg.add_file(path + "toy_detector_geometry.json") | ||
.add_file(path + "toy_detector_homogeneous_material.json") | ||
.add_file(path + "toy_detector_surface_grids.json"); | ||
|
||
auto [det, names] = | ||
detray::io::read_detector<host_detector_type>(host_mr, reader_cfg); | ||
|
||
// B field | ||
auto field = detray::bfield::create_const_field(B); | ||
|
||
// Algorithms | ||
traccc::seeding_algorithm sa(seeding_cfg, grid_cfg, filter_cfg, host_mr); | ||
traccc::track_params_estimation tp(host_mr); | ||
traccc::finding_algorithm<rk_stepper_type, host_navigator_type> | ||
host_finding(finding_cfg); | ||
traccc::fitting_algorithm<host_fitter_type> host_fitting(fitting_cfg); | ||
|
||
for (auto _ : state) { | ||
|
||
// Iterate over events | ||
#pragma omp parallel for | ||
for (int i_evt = 0; i_evt < n_events; i_evt++) { | ||
|
||
auto& spacepoints_per_event = spacepoints[i_evt]; | ||
auto& measurements_per_event = measurements[i_evt]; | ||
|
||
// Seeding | ||
auto seeds = sa(spacepoints_per_event); | ||
|
||
// Track param estimation | ||
auto params = tp(spacepoints_per_event, seeds, B); | ||
|
||
// Track finding with CKF | ||
auto track_candidates = | ||
host_finding(det, field, measurements_per_event, params); | ||
|
||
// Track fitting with KF | ||
auto track_states = host_fitting(det, field, track_candidates); | ||
} | ||
} | ||
} | ||
|
||
BENCHMARK_MAIN(); |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,12 @@ | ||
# TRACCC library, part of the ACTS project (R&D line) | ||
# | ||
# (c) 2024 CERN for the benefit of the ACTS project | ||
# | ||
# Mozilla Public License Version 2.0 | ||
|
||
traccc_add_executable( benchmark_cuda | ||
"toy_detector_cuda.cpp" | ||
LINK_LIBRARIES benchmark::benchmark | ||
vecmem::core vecmem::cuda | ||
traccc::core traccc::device_common | ||
traccc::cuda traccc_benchmarks_common ) |
Oops, something went wrong.