24 profiling_map_[
"setup"] = 0.;
25 profiling_map_[
"hits"] = 0.;
26 profiling_map_[
"seeds"] = 0.;
27 profiling_map_[
"ckf_setup"] = 0.;
28 profiling_map_[
"ckf_run"] = 0.;
29 profiling_map_[
"result_loop"] = 0.;
37 Acts::Vector3 b_field(0., 0., bfield_ * Acts::UnitConstants::T);
40 const auto const_b_field = std::make_shared<Acts::ConstantBField>(b_field);
48 surf_rotation_ = Acts::RotationMatrix3::Zero();
50 surf_rotation_(1, 0) = 1;
52 surf_rotation_(2, 1) = 1;
54 surf_rotation_(0, 2) = 1;
56 Acts::Vector3 target_pos(0., 0., 0.);
57 Acts::Translation3 target_translation(target_pos);
58 Acts::Transform3 target_transform(target_translation * surf_rotation_);
62 Acts::Surface::makeShared<Acts::PlaneSurface>(target_transform);
65 bool debug_transform =
false;
66 auto transform_pos = [
this, debug_transform](
const Acts::Vector3& pos_) {
67 Acts::Vector3 rot_pos;
70 rot_pos(2) = pos_(0) + DIPOLE_OFFSET;
73 rot_pos(0) += this->map_offset_[0];
74 rot_pos(1) += this->map_offset_[1];
75 rot_pos(2) += this->map_offset_[2];
80 if (debug_transform) {
81 std::cout <<
"PF::DEFAULT3 TRANSFORM" << std::endl;
82 std::cout <<
"PF::Check:: transforming Pos" << std::endl;
83 std::cout << pos_ << std::endl;
84 std::cout <<
"TO" << std::endl;
85 std::cout << rot_pos << std::endl;
91 Acts::RotationMatrix3 rotation = Acts::RotationMatrix3::Identity();
94 auto transform_b_field = [rotation, scale, debug_transform](
95 const Acts::Vector3& field,
96 const Acts::Vector3& ) {
98 Acts::Vector3 rot_field;
99 rot_field(0) = field(2);
100 rot_field(1) = field(0);
101 rot_field(2) = field(1);
104 rot_field = scale * rot_field;
107 rot_field = rotation * rot_field;
110 if (debug_transform) {
111 std::cout <<
"PF::DEFAULT3 TRANSFORM" << std::endl;
112 std::cout <<
"PF::Check:: transforming" << std::endl;
113 std::cout << field << std::endl;
114 std::cout <<
"TO" << std::endl;
115 std::cout << rot_field << std::endl;
122 const auto map = std::make_shared<InterpolatedMagneticField3>(
123 loadDefaultBField(field_map_,
126 transform_pos, transform_b_field));
128 auto acts_logging_level = Acts::Logging::FATAL;
129 if (debug_acts_) acts_logging_level = Acts::Logging::VERBOSE;
132 const auto stepper = Acts::EigenStepper<>{map};
133 const auto const_stepper = Acts::EigenStepper<>{const_b_field};
134 const auto multi_stepper = Acts::MultiEigenStepperLoop{map};
137 Acts::Navigator::Config nav_cfg{geometry().getTG()};
138 nav_cfg.resolveMaterial =
true;
139 nav_cfg.resolvePassive =
true;
140 nav_cfg.resolveSensitive =
true;
141 const Acts::Navigator navigator(nav_cfg);
143 propagator_ = std::make_unique<CkfPropagator>(
145 Acts::getDefaultLogger(
"CKF_PROP", acts_logging_level));
148 ckf_ = std::make_unique<std::decay_t<
decltype(*ckf_)>>(
149 *propagator_, Acts::getDefaultLogger(
"CKF", acts_logging_level));
150 trk_extrap_ = std::make_shared<std::decay_t<
decltype(*trk_extrap_)>>(
151 *propagator_, geometryContext(), magneticFieldContext());
154 Acts::ConstantBField zero_b_field(Acts::Vector3(0., 0., 0.));
155 const auto zero_b_stepper = Acts::EigenStepper<>{
156 std::make_shared<Acts::ConstantBField>(zero_b_field)};
158 std::make_unique<CkfPropagator>(zero_b_stepper, navigator);
159 ckf_zero_b_ = std::make_unique<std::decay_t<
decltype(*ckf_zero_b_)>>(
161 Acts::getDefaultLogger(
"CKF_ZERO_B", acts_logging_level));
163 std::make_shared<std::decay_t<
decltype(*trk_extrap_zero_b_)>>(
164 *propagator_zero_b_, geometryContext(), magneticFieldContext());
167 propagator_const_b_ =
168 std::make_unique<CkfPropagator>(const_stepper, navigator);
169 ckf_const_b_ = std::make_unique<std::decay_t<
decltype(*ckf_const_b_)>>(
170 *propagator_const_b_,
171 Acts::getDefaultLogger(
"CKF_CONST_B", acts_logging_level));
172 trk_extrap_const_b_ =
173 std::make_shared<std::decay_t<
decltype(*trk_extrap_const_b_)>>(
174 *propagator_const_b_, geometryContext(), magneticFieldContext());
184 std::vector<ldmx::Track> tracks;
186 auto start = std::chrono::high_resolution_clock::now();
190 ACTS_LOCAL_LOGGER(Acts::getDefaultLogger(
"LDMX Tracking Geometry Maker",
191 Acts::Logging::DEBUG));
194 Acts::PropagatorOptions<Acts::StepperPlainOptions,
195 Acts::NavigatorPlainOptions, ActionList, AbortList>
196 propagator_options(geometryContext(), magneticFieldContext());
198 propagator_options.pathLimit = std::numeric_limits<double>::max();
200 propagator_options.loopProtection =
false;
205 propagator_options.actionList.get<Acts::MaterialInteractor>();
206 m_interactor.multipleScattering =
true;
207 m_interactor.energyLoss =
true;
208 m_interactor.recordInteractions =
false;
212 propagator_options.actionList.get<Acts::detail::SteppingLogger>();
213 s_logger.sterile =
true;
215 propagator_options.stepping.maxStepSize =
216 propagator_step_size_ * Acts::UnitConstants::mm;
217 propagator_options.maxSteps = propagator_max_steps_;
227 auto setup = std::chrono::high_resolution_clock::now();
228 profiling_map_[
"setup"] +=
229 std::chrono::duration<double, std::milli>(setup - start).count();
231 const std::vector<ldmx::Measurement> measurements =
236 std::shared_ptr<tracking::sim::TruthMatchingTool> truth_matching_tool =
238 std::map<int, ldmx::SimParticle> particle_map;
240 if (event.
exists(sim_particles_coll_name_, sim_particles_event_passname_)) {
241 ldmx_log(debug) <<
"Setting up track truth matching tool";
243 sim_particles_coll_name_, sim_particles_event_passname_);
244 truth_matching_tool = std::make_shared<tracking::sim::TruthMatchingTool>(
245 particle_map, measurements);
250 const auto geo_id_sl_map = makeGeoIdSourceLinkMap(tg, measurements);
252 auto hits = std::chrono::high_resolution_clock::now();
253 profiling_map_[
"hits"] +=
254 std::chrono::duration<double, std::milli>(hits - setup).count();
259 const std::vector<ldmx::Track> seed_tracks =
260 event.getCollection<
ldmx::Track>(seed_coll_name_, input_pass_name_);
262 ldmx_log(info) <<
"Number of " << seed_coll_name_
263 <<
" seed tracks = " << seed_tracks.size();
265 if (seed_tracks.empty()) {
266 std::vector<ldmx::Track> empty;
267 ldmx_log(warn) <<
"No seed tracks, returning...";
268 event.add(out_trk_collection_, empty);
273 std::vector<Acts::BoundTrackParameters> start_parameters;
275 ldmx_log(debug) <<
"Transform the seed track to bound parameters";
276 int seed_track_index{0};
277 for (
auto& seed : seed_tracks) {
281 Acts::Vector3 perigee_acts = tracking::sim::utils::ldmx2Acts(Acts::Vector3(
282 seed.getPerigeeX(), seed.getPerigeeY(), seed.getPerigeeZ()));
283 std::shared_ptr<Acts::PerigeeSurface> perigee_surface =
284 Acts::Surface::makeShared<Acts::PerigeeSurface>(perigee_acts);
286 Acts::BoundVector param_vec;
287 param_vec << seed.getD0(), seed.getZ0(), seed.getPhi(), seed.getTheta(),
288 seed.getQoP(), seed.getT();
290 Acts::BoundSquareMatrix cov_mat =
291 tracking::sim::utils::unpackCov(seed.getPerigeeCov());
293 ldmx_log(debug) <<
" For seed index_ = " << seed_track_index
294 <<
": Perigee X / Y / Z = " << seed.getPerigeeX() <<
" / "
295 << seed.getPerigeeY() <<
" / " << seed.getPerigeeZ()
296 <<
", D0 = " << param_vec[0] <<
", Z0 = " << param_vec[1]
297 <<
", Phi = " << param_vec[2]
298 <<
", Theta = " << param_vec[3]
299 <<
", QoP = " << param_vec[4]
300 <<
", Time = " << param_vec[5];
302 ldmx_log(debug) <<
" Cov matrix diagonal (" << cov_mat(0, 0) <<
", "
303 << cov_mat(1, 1) <<
", " << cov_mat(2, 2) <<
")";
306 auto part_hypo{Acts::SinglyChargedParticleHypothesis::electron()};
307 start_parameters.push_back(Acts::BoundTrackParameters(
308 perigee_surface, param_vec, cov_mat, part_hypo));
316 auto seeds = std::chrono::high_resolution_clock::now();
317 profiling_map_[
"seeds"] +=
318 std::chrono::duration<double, std::milli>(seeds - hits).count();
320 Acts::GainMatrixUpdater kf_updater;
325 Acts::MeasurementSelector::Config measurement_selector_cfg = {
327 {Acts::GeometryIdentifier(), {{}, {outlier_pval_}, {1u}}},
330 Acts::MeasurementSelector meas_sel{measurement_selector_cfg};
334 Acts::CombinatorialKalmanFilterExtensions<TrackContainer> ckf_extensions;
336 if (use1_dmeasurements_) {
337 ckf_extensions.calibrator
339 Acts::VectorMultiTrajectory>>(&calibrator);
341 ckf_extensions.calibrator
343 Acts::VectorMultiTrajectory>>(&calibrator);
346 ckf_extensions.updater.connect<
347 &Acts::GainMatrixUpdater::operator()<Acts::VectorMultiTrajectory>>(
350 ckf_extensions.measurementSelector
351 .connect<&Acts::MeasurementSelector::select<Acts::VectorMultiTrajectory>>(
354 ldmx_log(debug) <<
"SourceLinkAccessor...";
357 struct SourceLinkAccIt {
358 using BaseIt =
decltype(geo_id_sl_map.begin());
361#pragma GCC diagnostic push
362#pragma GCC diagnostic ignored "-Wunused-local-typedefs"
364 using difference_type =
typename BaseIt::difference_type;
365 using iterator_category =
typename BaseIt::iterator_category;
367 using value_type = Acts::SourceLink;
368 using pointer =
typename BaseIt::pointer;
369 using reference = value_type&;
370#pragma GCC diagnostic pop
372 SourceLinkAccIt& operator++() {
376 bool operator==(
const SourceLinkAccIt& other)
const {
377 return it_ == other.it_;
379 bool operator!=(
const SourceLinkAccIt& other)
const {
380 return !(*
this == other);
385 value_type operator*()
const {
return value_type{it_->second}; }
388 auto source_link_accessor = [&](
const Acts::Surface& surface)
389 -> std::pair<SourceLinkAccIt, SourceLinkAccIt> {
390 auto [begin, end] = geo_id_sl_map.equal_range(surface.geometryId());
391 return {SourceLinkAccIt{begin}, SourceLinkAccIt{end}};
394 Acts::SourceLinkAccessorDelegate<SourceLinkAccIt>
395 source_link_accessor_delegate;
396 source_link_accessor_delegate
397 .connect<&
decltype(source_link_accessor)::operator(),
398 decltype(source_link_accessor)>(&source_link_accessor);
400 ldmx_log(debug) <<
"Setting up surfaces...";
402 std::shared_ptr<const Acts::PerigeeSurface> origin_surface =
403 Acts::Surface::makeShared<Acts::PerigeeSurface>(
404 Acts::Vector3(0., 0., 0.));
406 ldmx_log(debug) <<
"About to run CKF...";
409 auto ckf_setup = std::chrono::high_resolution_clock::now();
410 profiling_map_[
"ckf_setup"] +=
411 std::chrono::duration<double, std::milli>(ckf_setup - seeds).count();
413 Acts::VectorTrackContainer vtc;
414 Acts::VectorMultiTrajectory mtj;
415 Acts::TrackContainer tc{vtc, mtj};
419 ldmx_log(debug) <<
"Loop on the track candidates";
420 for (
size_t track_id = 0u; track_id < start_parameters.size(); ++track_id) {
421 ldmx_log(debug) <<
"---------------------------";
422 ldmx_log(debug) <<
"Candidate Track ID = " << track_id;
424 const Acts::CombinatorialKalmanFilterOptions<SourceLinkAccIt,
426 ckf_options(TrackingGeometryUser::geometryContext(),
427 TrackingGeometryUser::magneticFieldContext(),
428 TrackingGeometryUser::calibrationContext(),
429 source_link_accessor_delegate, ckf_extensions,
430 propagator_options,
true ,
433 ldmx_log(debug) <<
" Checking options: multiple scattering = "
434 << ckf_options.multipleScattering
435 <<
" energy loss = " << ckf_options.energyLoss;
439 ckf_->findTracks(start_parameters.at(track_id), ckf_options, tc);
441 auto start_params = start_parameters.at(track_id).parameters().transpose();
445 if (!tagger_tracking_) {
447 n_fieldmap_ckf_failed_recoil_++;
449 <<
" Field-map CKF failed, trying zero-B CKF fallback";
450 results = ckf_zero_b_->findTracks(start_parameters.at(track_id),
453 n_zerob_ckf_recovered_recoil_++;
454 ldmx_log(debug) <<
" Yay! Zero-B CKF succeeded as fallback!";
456 ldmx_log(debug) <<
" Zero-B CKF also failed!";
460 n_fieldmap_ckf_failed_tagger_++;
462 <<
" Field-map CKF failed, trying const-B (1.5T) CKF fallback";
463 results = ckf_const_b_->findTracks(start_parameters.at(track_id),
466 n_constb_ckf_recovered_tagger_++;
467 ldmx_log(debug) <<
" Yay! Const-B CKF succeeded as fallback!";
469 ldmx_log(debug) <<
" Const-B CKF also failed!";
475 <<
" Checking CKF success for track candidate with params: "
476 <<
" D0 = " << start_params[0] <<
" Z0 = " << start_params[1]
477 <<
", Phi = " << start_params[2] <<
" Theta = " << start_params[3]
478 <<
", QoP = " << start_params[4] <<
" Time = " << start_params[5];
479 if (not results.ok()) {
480 ldmx_log(debug) <<
" CKF failed!";
483 ldmx_log(debug) <<
" CKF succeded!";
486 auto& tracks_from_seed = results.value();
487 if (tracks_from_seed.size() != 1) {
488 ldmx_log(info) <<
" tracksFromSeed.size = " << tracks_from_seed.size();
491 for (
auto& track : tracks_from_seed) {
493 Acts::smoothTrack(geometryContext(), track);
498 auto opt_target = trk_extrap_->extrapolate(track, target_surface_);
501 if (tagger_tracking_) {
502 n_fieldmap_target_extrap_failed_tagger_++;
503 ldmx_log(debug) <<
" Field-map target extrapolation failed, "
504 "trying const-B (1.5T) fallback";
505 opt_target = trk_extrap_const_b_->extrapolate(track, target_surface_);
507 n_constb_target_extrap_recovered_tagger_++;
509 ldmx_log(debug) <<
" Both field-map and Const-B target "
510 "extrapolation failed!";
512 n_fieldmap_target_extrap_failed_recoil_++;
513 ldmx_log(debug) <<
" Field-map target extrapolation failed, "
514 "trying zero-B fallback";
515 opt_target = trk_extrap_zero_b_->extrapolate(track, target_surface_);
517 n_zerob_target_extrap_recovered_recoil_++;
520 <<
" Both field-map and Zero-B target extrapolation failed!";
525 ldmx_log(debug) <<
" Could not extrapolate to target! nhits = "
526 << track.nMeasurements() <<
" Printing track states:";
527 for (
const auto ts : track.trackStatesReversed()) {
528 if (ts.hasSmoothed())
529 ldmx_log(debug) <<
" Parameters: " << ts.smoothed().transpose();
531 ldmx_log(debug) <<
" Track state not smoothed!";
533 ldmx_log(debug) <<
" ...skipping this track candidate...";
537 ldmx_log(debug) <<
" Successfully obtained TrackState at target";
540 auto ts_at_target = tracking::sim::utils::makeTrackState(
541 geometryContext(), *opt_target, ldmx::AtTarget);
542 trk.addTrackState(ts_at_target);
544 ldmx_log(debug) <<
" Position at target (LDMX): ("
545 << ts_at_target.pos_[0] <<
", " << ts_at_target.pos_[1]
546 <<
", " << ts_at_target.pos_[2] <<
") mm"
547 <<
" Momentum: (" << ts_at_target.mom_[0] <<
", "
548 << ts_at_target.mom_[1] <<
", " << ts_at_target.mom_[2]
552 track.setReferenceSurface(target_surface_);
553 track.parameters() = opt_target->parameters();
556 trk.setPerigeeParameters(tracking::sim::utils::convertActsToLdmxPars(
557 opt_target->parameters()));
558 if (opt_target->covariance()) {
559 std::vector<double> cov_vec;
560 tracking::sim::utils::flatCov(*(opt_target->covariance()), cov_vec);
561 trk.setPerigeeCov(cov_vec);
564 Acts::Vector3 target_loc_ldmx = tracking::sim::utils::acts2Ldmx(
565 target_surface_->transform(geometryContext()).translation());
566 trk.setPerigeeLocation(target_loc_ldmx[0], target_loc_ldmx[1],
569 trk.setChi2(track.chi2());
570 trk.setNhits(track.nMeasurements());
571 trk.setNdf(track.nMeasurements() - 5);
572 trk.setNsharedHits(track.nSharedHits());
573 trk.setCharge(opt_target->parameters()[Acts::eBoundQOverP] > 0 ? 1 : -1);
576 if ((trk.getNhits() <= min_hits_) ||
577 (std::abs(1. / trk.getQoP()) <= 0.05)) {
579 <<
" > Track candidate did NOT meet the requirements: Nhits = "
580 << trk.getNhits() <<
" and p = " << std::abs(1. / trk.getQoP())
586 ldmx_log(debug) <<
" Add measurements to the final track from "
587 << track.nTrackStates() <<
" TrackStates with "
588 << track.nMeasurements() <<
" measurements";
590 int trk_state_index{0};
591 for (
const auto ts : track.trackStatesReversed()) {
593 ldmx_log(debug) <<
" Checking Track State index_ = "
594 << trk_state_index <<
" at location "
595 << ts.referenceSurface()
596 .transform(geometryContext())
600 if (ts.hasSmoothed()) {
601 ldmx_log(debug) <<
" Smoothed track parameters: "
602 << ts.smoothed().transpose();
608 auto type_flags = ts.typeFlags();
610 if (type_flags.test(Acts::TrackStateFlag::MeasurementFlag) &&
611 ts.hasUncalibratedSourceLink()) {
613 ts.getUncalibratedSourceLink()
614 .template get<acts_examples::IndexSourceLink>();
617 ldmx_log(debug) <<
" Adding measurement to ldmx::track with "
618 "source link index_ = "
620 ldmx_log(trace) <<
" Measurement:\n" << ldmx_meas;
621 trk.addMeasurementIndex(sl.
index());
624 if (ts.hasSmoothed()) {
625 const auto& meas_surface = ts.referenceSurface();
626 const auto& smoothed_params = ts.smoothed();
631 float p_inv = smoothed_params[Acts::eBoundQOverP];
632 float p = 1.0f / std::abs(p_inv);
633 float theta = smoothed_params[Acts::eBoundTheta];
634 float phi = smoothed_params[Acts::eBoundPhi];
636 Acts::Vector3 global_momentum(p * std::sin(theta) * std::cos(phi),
637 p * std::sin(theta) * std::sin(phi),
638 p * std::cos(theta));
641 auto local_frame_transform =
642 meas_surface.transform(geometryContext());
643 Acts::Vector3 local_momentum =
644 local_frame_transform.rotation().transpose() * global_momentum;
647 float phi_u = (local_momentum.z() != 0)
648 ? local_momentum.x() / local_momentum.z()
650 float phi_v = (local_momentum.z() != 0)
651 ? local_momentum.y() / local_momentum.z()
658 const float sensor_thickness = 0.320f;
659 float tan_angle_sq = phi_u * phi_u + phi_v * phi_v;
660 float cos_angle = 1.0f / std::sqrt(1.0f + tan_angle_sq);
661 float path_length = sensor_thickness / cos_angle;
663 ldmx_log(debug) <<
" Local angles: phi_u = " << phi_u
664 <<
", phi_v = " << phi_v
665 <<
"; Path length = " << path_length <<
" mm";
668 float edep = ldmx_meas.
getEdep();
669 float dedx = edep / path_length;
670 trk.addDedxMeasurement(dedx);
672 ldmx_log(debug) <<
" Edep = " << edep
673 <<
" MeV, dE/dx = " << dedx <<
" MeV/mm";
676 ldmx_log(debug) <<
" This TrackState is not a measurement";
681 ldmx_log(debug) <<
" Starting extrapolations";
684 const double ecal_scoring_plane = 240.5;
685 Acts::Vector3 pos(ecal_scoring_plane, 0., 0.);
686 Acts::Translation3 surf_translation(pos);
687 Acts::Transform3 surf_transform(surf_translation * surf_rotation_);
688 const std::shared_ptr<Acts::PlaneSurface> ecal_surface =
689 Acts::Surface::makeShared<Acts::PlaneSurface>(surf_transform);
692 const std::shared_ptr<Acts::Surface> beam_origin_surface =
693 tracking::sim::utils::unboundSurface(-700);
695 if (tagger_tracking_) {
696 ldmx_log(debug) <<
" Beam Origin Extrapolation";
697 auto opt_beam_origin =
698 trk_extrap_->extrapolate(track, beam_origin_surface);
699 if (opt_beam_origin) {
700 trk.addTrackState(tracking::sim::utils::makeTrackState(
701 geometryContext(), *opt_beam_origin, ldmx::AtBeamOrigin));
703 <<
" Successfully obtained TrackState at beam origin";
708 if (!tagger_tracking_) {
709 ldmx_log(debug) <<
" Ecal Extrapolation";
710 auto opt_ecal = trk_extrap_->extrapolate(track, ecal_surface);
713 n_fieldmap_ecal_extrap_failed_recoil_++;
714 ldmx_log(debug) <<
" Field-map ECAL extrapolation failed, trying "
716 opt_ecal = trk_extrap_zero_b_->extrapolate(track, ecal_surface);
718 n_zerob_ecal_extrap_recovered_recoil_++;
721 <<
" Both field-map and Zero-B ECAL extrapolation failed!";
725 auto ts_at_ecal = tracking::sim::utils::makeTrackState(
726 geometryContext(), *opt_ecal, ldmx::AtECAL);
727 trk.addTrackState(ts_at_ecal);
728 ldmx_log(debug) <<
" Successfully obtained TrackState at ECAL";
729 ldmx_log(debug) <<
" Position at ECAL (LDMX): ("
730 << ts_at_ecal.pos_[0] <<
", " << ts_at_ecal.pos_[1]
731 <<
", " << ts_at_ecal.pos_[2] <<
") mm";
736 if (truth_matching_tool) {
737 auto truth_info = truth_matching_tool->truthMatch(trk);
738 trk.setTrackID(truth_info.track_id_);
739 trk.setPdgID(truth_info.pdg_id_);
740 trk.setTruthProb(truth_info.truth_prob_);
745 <<
" > Adding the track candidate to the track collection";
746 tracks.push_back(trk);
751 ldmx_log(info) <<
"Number of CKF tracks " << tracks.size();
753 auto ckf_run = std::chrono::high_resolution_clock::now();
754 profiling_map_[
"ckf_run"] +=
755 std::chrono::duration<double, std::milli>(ckf_run - ckf_setup).count();
758 auto shared_hits = computeSharedHits(
759 tracks, measurements, tg, tracking::sim::utils::sourceLinkHash,
760 tracking::sim::utils::sourceLinkEquality);
761 for (std::size_t i_track = 0; i_track < shared_hits.size(); ++i_track) {
762 tracks[i_track].setNsharedHits(shared_hits[i_track].size());
763 for (
auto idx : shared_hits[i_track]) {
764 tracks[i_track].addSharedIndex(idx);
768 auto result_loop = std::chrono::high_resolution_clock::now();
769 profiling_map_[
"result_loop"] +=
770 std::chrono::duration<double, std::milli>(result_loop - ckf_run).count();
773 event.add(out_trk_collection_, tracks);
775 auto end = std::chrono::high_resolution_clock::now();
778 auto diff = end - start;
779 processing_time_ += std::chrono::duration<double, std::milli>(diff).count();