ATLAS Offline Software
Loading...
Searching...
No Matches
StripCalibratorToolImpl.icc
Go to the documentation of this file.
1/*
2 Copyright (C) 2002-2026 CERN for the benefit of the ATLAS collaboration
3
4*/
5
6#ifndef STRIPCALIBRATORTOOLIMPL_ICC
7#define STRIPCALIBRATORTOOLIMPL_ICC
8
9#include "InDetReadoutGeometry/SiDetectorElement.h"
10#include "SCT_ReadoutGeometry/StripStereoAnnulusDesign.h"
11#include <stdexcept>
12
13namespace ActsTrk::detail{
14
15 template <typename traj_t>
16 StripCalibratorToolImpl<traj_t>::StripCalibratorToolImpl(const std::string& type,
17 const std::string& name,
18 const IInterface* parent)
19 : base_class(type, name, parent)
20 {}
21
22 template <typename traj_t>
23 StatusCode StripCalibratorToolImpl<traj_t>::initialize()
24 {
25 ATH_MSG_DEBUG("Initializing " << AthAlgTool::name() << " ...");
26
27 ATH_MSG_DEBUG(AthAlgTool::name() << " successfully initialized");
28
29 ATH_MSG_INFO( m_correctCovariance );
30 ATH_MSG_INFO( m_postCalibration );
31 ATH_MSG_INFO( m_errorStrategy );
32
33 return StatusCode::SUCCESS;
34
35 }
36
37 template <typename traj_t>
38 const InDetDD::SiDetectorElement& StripCalibrator<traj_t>::getDetectorElement(const Acts::Surface &surface) const
39 {
40 const ActsDetectorElement* detElem = dynamic_cast<const ActsDetectorElement*>(surface.surfacePlacement());
41 const InDetDD::SiDetectorElement *siDetElement = detElem ? dynamic_cast<const InDetDD::SiDetectorElement *>(detElem->upstreamDetectorElement()) : nullptr;
42 if (!siDetElement) {
43 ATH_MSG_ERROR("Surface without associated SI detector element");
44 throw std::runtime_error("SiDetectorElement is NULL");
45 }
46 return *siDetElement;
47 }
48
49 template <typename traj_t>
50 std::optional<float> StripCalibrator<traj_t>::getCorrectedError(const xAOD::StripCluster& cluster) const
51 {
52 std::optional<float> errX {std::nullopt};
53 if (not m_options.m_correctCovariance) {
54 return errX;
55 }
56
57 Cov cov = cluster.template localCovariance<1>();
58 int nrows = cluster.channelsInPhi();
59
60 if (m_options.m_errorStrategy == 0 ) {
61
62 errX = std::sqrt(cov(0,0));
63
64 } else if (m_options.m_errorStrategy == 1 ) {
65
66 errX = std::sqrt(cov(0,0)) / nrows;
67
68 }
69
70
71 return errX;
72 }
73
74 template <typename traj_t>
75 std::pair<typename StripCalibrator<traj_t>::Pos,
76 typename StripCalibrator<traj_t>::Cov>
77 StripCalibrator<traj_t>::calibrate(
78 const Acts::GeometryContext& gctx,
79 const Acts::CalibrationContext& cctx,
80 const xAOD::StripCluster& cluster,
81 const StripCalibrator<traj_t>::TrackStateProxy& /*state*/) const
82 {
83 // const InDetDD::SiDetectorElement &detElement = getDetectorElement(state.referenceSurface());
84 return calibrate(gctx, cctx, cluster);
85 }
86
87 template <typename traj_t>
88 std::pair<typename StripCalibrator<traj_t>::Pos,
89 typename StripCalibrator<traj_t>::Cov>
90 StripCalibrator<traj_t>::calibrate(
91 const Acts::GeometryContext& gctx,
92 const Acts::CalibrationContext& cctx,
93 [[maybe_unused]] const Acts::Surface& surface,
94 const xAOD::StripCluster& cluster,
95 const Acts::BoundTrackParameters& /*bound_parameters*/) const
96 {
97 // const InDetDD::SiDetectorElement &detElement = getDetectorElement(surface);
98 return calibrate(gctx, cctx, cluster);
99 }
100
101 template <typename traj_t>
102 std::pair<typename StripCalibrator<traj_t>::Pos,
103 typename StripCalibrator<traj_t>::Cov>
104 StripCalibrator<traj_t>::calibrate(
105 const Acts::GeometryContext& /*gctx*/,
106 const Acts::CalibrationContext& /*cctx*/,
107 const xAOD::StripCluster& cluster) const
108 {
109 Pos pos = cluster.template localPosition<1>();
110 Cov cov = cluster.template localCovariance<1>();
111
112 auto errX = getCorrectedError(cluster);
113 if (errX.has_value()) {
114 double newErr = *errX;
115 cov(0, 0) = newErr * newErr;
116 }
117
118 return std::make_pair(pos, cov);
119 }
120
121 template <typename traj_t>
122 void StripCalibrator<traj_t>::connectOnTrackCalibrator(typename StripCalibrator<traj_t>::BASE::OnTrackCalibrator& stripCalibrator) const
123 {
124 using CalibFuncPtr_t =
125 std::pair<typename StripCalibrator<traj_t>::Pos, typename StripCalibrator<traj_t>::Cov>
126 (StripCalibrator<traj_t>:: *)(const Acts::GeometryContext&,
127 const Acts::CalibrationContext&,
128 const xAOD::StripCluster&,
129 const StripCalibrator<traj_t>::TrackStateProxy&) const;
130
131 stripCalibrator. template connect<static_cast<CalibFuncPtr_t>(&StripCalibrator<traj_t>::calibrate)>(this);
132 }
133
134 template <typename traj_t>
135 void StripCalibrator<traj_t>::connectCalibrator(StripOnBoundStateCalibratorBase::Calibrator& stripCalibrator) const
136 {
137 using CalibFuncPtr_t =
138 std::pair<typename StripCalibrator<traj_t>::Pos,
139 typename StripCalibrator<traj_t>::Cov>
140 (StripCalibrator<traj_t>:: *)(const Acts::GeometryContext&,
141 const Acts::CalibrationContext&,
142 const Acts::Surface &,
143 const xAOD::StripCluster&,
144 const Acts::BoundTrackParameters&) const;
145
146 stripCalibrator.template connect<static_cast<CalibFuncPtr_t>(&StripCalibrator<traj_t>::calibrate)>(this);
147 }
148
149 template <typename traj_t>
150 bool StripCalibratorToolImpl<traj_t>::calibrateAfterMeasurementSelection() const
151 { return m_postCalibration.value(); }
152
153} // namespace ActsTrk::detail
154
155#endif