From 93df330a6ba0754d5c21e3beef7aea27ffbcc616 Mon Sep 17 00:00:00 2001 From: Wouter Deconinck Date: Wed, 14 Aug 2024 15:16:52 -0500 Subject: [PATCH] fix: updated tracking algorithms for Acts up to 35.2.0 --- JugTrack/JugTrack/DD4hepBField.h | 4 ++ JugTrack/src/components/CKFTracking.cpp | 70 ++++++++++++++++++- .../src/components/TrackerSourceLinker.cpp | 1 - 3 files changed, 72 insertions(+), 3 deletions(-) diff --git a/JugTrack/JugTrack/DD4hepBField.h b/JugTrack/JugTrack/DD4hepBField.h index fd629277..99ec3922 100644 --- a/JugTrack/JugTrack/DD4hepBField.h +++ b/JugTrack/JugTrack/DD4hepBField.h @@ -42,7 +42,11 @@ namespace Jug::BField { Acts::MagneticFieldProvider::Cache makeCache(const Acts::MagneticFieldContext& mctx) const override { +#if Acts_VERSION_MAJOR >= 32 + return Acts::MagneticFieldProvider::Cache(std::in_place_type, mctx); +#else return Acts::MagneticFieldProvider::Cache::make(mctx); +#endif } /** construct constant magnetic field from field vector. diff --git a/JugTrack/src/components/CKFTracking.cpp b/JugTrack/src/components/CKFTracking.cpp index 1bd02d2c..bba17a90 100644 --- a/JugTrack/src/components/CKFTracking.cpp +++ b/JugTrack/src/components/CKFTracking.cpp @@ -15,19 +15,35 @@ #include "DDRec/SurfaceManager.h" #include "DDRec/Surface.h" +#if Acts_VERSION_MAJOR < 36 +#include +#endif +#if Acts_VERSION_MAJOR >= 32 +#include "Acts/EventData/ProxyAccessor.hpp" +#endif #include "Acts/Geometry/TrackingGeometry.hpp" #include "Acts/Plugins/DD4hep/DD4hepDetectorElement.hpp" #include "Acts/Surfaces/PerigeeSurface.hpp" -#include "Acts/TrackFinding/SourceLinkAccessorConcept.hpp" #include "Acts/TrackFitting/GainMatrixSmoother.hpp" #include "Acts/TrackFitting/GainMatrixUpdater.hpp" #include "Acts/Propagator/EigenStepper.hpp" +#if Acts_VERSION_MAJOR >= 34 +#include "Acts/Propagator/AbortList.hpp" +#include "Acts/Propagator/EigenStepper.hpp" +#include "Acts/Propagator/MaterialInteractor.hpp" #include "Acts/Propagator/Navigator.hpp" +#endif #include "Acts/Propagator/Propagator.hpp" +#if Acts_VERSION_MAJOR >= 34 +#include "Acts/Propagator/StandardAborters.hpp" +#endif #include "Acts/Definitions/Common.hpp" #include "Acts/Utilities/Helpers.hpp" #include "Acts/Utilities/Logger.hpp" +#if Acts_VERSION_MAJOR >= 34 +#include "Acts/Utilities/TrackHelpers.hpp" +#endif #include "Acts/Definitions/Units.hpp" #include @@ -139,7 +155,9 @@ namespace Jug::Reco { ActsExamples::PassThroughCalibrator pcalibrator; ActsExamples::MeasurementCalibratorAdapter calibrator(pcalibrator, *measurements); Acts::GainMatrixUpdater kfUpdater; +#if Acts_VERSION_MAJOR < 34 Acts::GainMatrixSmoother kfSmoother; +#endif Acts::MeasurementSelector measSel{m_sourcelinkSelectorCfg}; Acts::CombinatorialKalmanFilterExtensions @@ -150,9 +168,11 @@ namespace Jug::Reco { extensions.updater.connect< &Acts::GainMatrixUpdater::operator()>( &kfUpdater); +#if Acts_VERSION_MAJOR < 34 extensions.smoother.connect< &Acts::GainMatrixSmoother::operator()>( &kfSmoother); +#endif extensions.measurementSelector .connect<&Acts::MeasurementSelector::select>( &measSel); @@ -164,9 +184,27 @@ namespace Jug::Reco { slAccessorDelegate.connect<&ActsExamples::IndexSourceLinkAccessor::range>(&slAccessor); // Set the CombinatorialKalmanFilter options +#if Acts_VERSION_MAJOR < 34 CKFTracking::TrackFinderOptions options( m_geoctx, m_fieldctx, m_calibctx, slAccessorDelegate, extensions, pOptions, &(*pSurface)); +#else + CKFTracking::TrackFinderOptions options( + m_geoctx, m_fieldctx, m_calibctx, slAccessorDelegate, + extensions, pOptions); +#endif + +#if Acts_VERSION_MAJOR >= 34 + Acts::Propagator, Acts::Navigator> extrapolator( + Acts::EigenStepper<>(m_BField), + Acts::Navigator({m_actsGeoSvc->trackingGeometry()}, + logger().cloneWithSuffix("Navigator")), + logger().cloneWithSuffix("Propagator")); + + Acts::PropagatorOptions, + Acts::AbortList> + extrapolationOptions(m_geoctx, m_fieldctx); +#endif // Create track container auto trackContainer = std::make_shared(); @@ -175,7 +213,11 @@ namespace Jug::Reco { // Add seed number column tracks.addColumn("seed"); +#if Acts_VERSION_MAJOR >= 32 + Acts::ProxyAccessor seedNumber("seed"); +#else Acts::TrackAccessor seedNumber("seed"); +#endif // Loop over seeds for (std::size_t iseed = 0; iseed < init_trk_params->size(); ++iseed) { @@ -190,6 +232,27 @@ namespace Jug::Reco { // Set seed number for all found tracks auto& tracksForSeed = result.value(); for (auto& track : tracksForSeed) { + +#if Acts_VERSION_MAJOR >=34 + auto smoothingResult = Acts::smoothTrack(m_geoctx, track, logger()); + if (!smoothingResult.ok()) { + ACTS_ERROR("Smoothing for seed " + << iseed << " and track " << track.index() + << " failed with error " << smoothingResult.error()); + continue; + } + + auto extrapolationResult = Acts::extrapolateTrackToReferenceSurface( + track, *pSurface, extrapolator, extrapolationOptions, + Acts::TrackExtrapolationStrategy::firstOrLast, logger()); + if (!extrapolationResult.ok()) { + ACTS_ERROR("Extrapolation for seed " + << iseed << " and track " << track.index() + << " failed with error " << extrapolationResult.error()); + continue; + } +#endif + seedNumber(track) = iseed; } } @@ -210,8 +273,11 @@ namespace Jug::Reco { ); // Seed number column accessor +#if Acts_VERSION_MAJOR >= 32 + const Acts::ConstProxyAccessor constSeedNumber("seed"); +#else const Acts::ConstTrackAccessor constSeedNumber("seed"); - +#endif // Prepare the output data with MultiTrajectory, per seed ActsExamples::Trajectories::IndexedParameters parameters; diff --git a/JugTrack/src/components/TrackerSourceLinker.cpp b/JugTrack/src/components/TrackerSourceLinker.cpp index 8981f6f0..22ada49c 100644 --- a/JugTrack/src/components/TrackerSourceLinker.cpp +++ b/JugTrack/src/components/TrackerSourceLinker.cpp @@ -26,7 +26,6 @@ #include "Acts/Geometry/TrackingGeometry.hpp" #include "Acts/Plugins/DD4hep/DD4hepDetectorElement.hpp" #include "Acts/Surfaces/Surface.hpp" -#include #include "ActsExamples/EventData/Index.hpp" #include "ActsExamples/EventData/IndexSourceLink.hpp"