ATLAS Offline Software
Loading...
Searching...
No Matches
MuonR4::SpacePointCalibrator Class Reference

#include <SpacePointCalibrator.h>

Inheritance diagram for MuonR4::SpacePointCalibrator:
Collaboration diagram for MuonR4::SpacePointCalibrator:

Public Types

enum class  ProjectorType {
  e1DimNoTime = 0 , e1DimRotNoTime = 1 , e2DimNoTime = 2 , e1DimWithTime = 3 ,
  e1DimRotWithTime = 4 , e2DimWithTime = 5
}
 Enum encoding the possible projectors used in ATLAS. More...
using SourceLink_t
 Encode the source links supported by the Calibrator class as a variant of the measurement class type pointer used within Athena.

Public Member Functions

StatusCode initialize () override final
CalibSpacePointPtr calibrate (const EventContext &ctx, const SpacePoint *spacePoint, const Amg::Vector3D &seedPosInChamb, const Amg::Vector3D &seedDirInChamb, const double timeDelay) const override final
CalibSpacePointPtr calibrate (const EventContext &ctx, const CalibratedSpacePoint &spacePoint, const Amg::Vector3D &seedPosInChamb, const Amg::Vector3D &seedDirInChamb, const double timeDelay) const override final
CalibSpacePointVec calibrate (const EventContext &ctx, const std::vector< const SpacePoint * > &spacePoints, const Amg::Vector3D &seedPosInChamb, const Amg::Vector3D &seedDirInChamb, const double timeDelay) const override final
CalibSpacePointVec calibrate (const Acts::CalibrationContext &ctx, const Amg::Vector3D &seedPosInChamb, const Amg::Vector3D &seedDirInChamb, const double timeDelay, const CalibSpacePointVec &spacePoints) const override final
void updateSigns (const Amg::Vector3D &trackPos, const Amg::Vector3D &trackDir, CalibSpacePointVec &hitsToCalib) const override final
double driftVelocity (const Acts::CalibrationContext &ctx, const CalibratedSpacePoint &spacePoint) const override final
double driftAcceleration (const Acts::CalibrationContext &ctx, const CalibratedSpacePoint &spacePoint) const override final
void calibrateSourceLink (const Acts::GeometryContext &geoctx, const Acts::CalibrationContext &cctx, const Acts::SourceLink &link, ActsTrk::MutableTrackContainer::TrackStateProxy state) const override final
void stampSignsOnMeasurements (const xAOD::MuonSegment &segment) const override final
double driftRadius (const Acts::CalibrationContext &cctx, const CalibratedSpacePoint &spacePoint, const double timeDelay) const override final
double driftVelocity (const Acts::CalibrationContext &cctx, const CalibratedSpacePoint &spacePoint, const double timeDelay) const override final
double driftAcceleration (const Acts::CalibrationContext &cctx, const CalibratedSpacePoint &spacePoint, const double timeDelay) const override final
template<std::size_t Dim, Acts::TrackStateProxyConcept proxy_t, typename pos_t, typename cov_t>
void setState (const ProjectorType projector, const pos_t &locpos, const cov_t &cov, Acts::SourceLink link, proxy_t &trackState) const
 Copy the local position & covariance into the Acts track state proxy.

Static Public Member Functions

static SourceLinkType getType (const Acts::SourceLink &sl)
 Returns the enumeration corresponding to the object type cached within the Acts::SourceLink.
static SourceLink_t unpackBase (const Acts::SourceLink &sl)
 Unpack the SourceLink_t from the passed Acts source link.
template<Acts::PointerConcept Ptr_t>
static Acts::SourceLink pack (const Ptr_t &measurement)
 Pack the measurement type pointer to an Acts::SourceLink including the intermediate conversion into a SourceLink_t.

Private Member Functions

void calibrateCombinedPrd (const EventContext &ctx, const ActsTrk::GeometryContext &gctx, const xAOD::CombinedMuonStrip *combinedPrd, ActsTrk::MutableTrackContainer::TrackStateProxy state) const
 Calibrates the track states from a combined muon strip.
std::pair< double, double > calibrateMM (const EventContext &ctx, const ActsTrk::GeometryContext &gctx, const xAOD::MMCluster &cluster, const Amg::Vector3D &globalPos, const Amg::Vector3D &globalDir) const
 Calibrates the position and covariance of a MicroMegas (MM) cluster.
std::pair< double, double > calibratesTGC (const EventContext &ctx, const ActsTrk::GeometryContext &gctx, const xAOD::sTgcStripCluster &cluster, std::optional< double > posAlongTheStrip, const Amg::Vector3D &globalPos, const Amg::Vector3D &globalDir) const
 Calibrates the position and covariance of an sTGC (small-strip Thin Gap Chamber) cluster.

Private Attributes

ActsTrk::GeoContextReadKey_t m_geoCtxKey {this, "AlignmentKey", "ActsAlignment", "cond handle key"}
 access to the ACTS geometry context
ServiceHandle< Muon::IMuonIdHelperSvcm_idHelperSvc {this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"}
ToolHandle< IMdtCalibrationToolm_mdtCalibrationTool {this, "MdtCalibrationTool", ""}
ToolHandle< Muon::INSWCalibToolm_nswCalibTool {this, "NSWCalibTool", ""}
ToolHandle< Muon::IMMClusterBuilderToolm_clusterBuilderToolMM {this, "MMClusterBuilder", ""}
const MuonGMR4::MuonDetectorManagerm_detMgr {nullptr}
Gaudi::Property< double > m_muonPropSpeed {this, "PropagationSpeed", 1./ Gaudi::Units::c_light }
 Assumed propagation velocity of the muon through the detector.
Gaudi::Property< double > m_rpcSignalVelocity
 How fast does an electron signal travel along an rpc strip.
Gaudi::Property< double > m_rpcTimeResolution
Gaudi::Property< bool > m_useRpcTime {this, "useRpcTime", false}
 Load the Rpc time on the track states for the track fit.
Gaudi::Property< bool > m_useTgcTime
 Load the Tgc bunch crossing ID on the track states.
Gaudi::Property< bool > m_usesTgcTime
Gaudi::Property< bool > m_MdtSignFromSegment

Static Private Attributes

static constexpr std::array< Acts::BoundSubspaceIndices, 6 > s_boundSpaceIndices
 Array to map the Projector types to the bound index configurations used by the ATLAS detector measurements.

Detailed Description

Definition at line 30 of file SpacePointCalibrator.h.

Member Typedef Documentation

◆ SourceLink_t

Initial value:
std::variant<std::monostate,
This class is the pure abstract base class for all fittable tracking measurements.
UncalibratedMeasurement_v1 UncalibratedMeasurement
Define the version of the uncalibrated measurement class.

Encode the source links supported by the Calibrator class as a variant of the measurement class type pointer used within Athena.

The std::monostate is used to encode nullptrs or not yet supported types

Definition at line 55 of file MeasurementCalibratorBase.h.

Member Enumeration Documentation

◆ ProjectorType

Enum encoding the possible projectors used in ATLAS.

Their integer representations correspond to the element index in the s_boundSpaceIndices member

Enumerator
e1DimNoTime 
e1DimRotNoTime 

Project out solely the locX (Applies to Itk strips, Rpc, Tgc, sTgc, Mm).

e2DimNoTime 

Project out solely the locY - Complementary projector if the strip plane is rotated (Applies to Itk endcap strips, Rpc, Tgc, sTgc).

e1DimWithTime 

Project out the two spatial coordinates - (Applies to ITk pixel, BI-Rpc, sTgc pad).

e1DimRotWithTime 

Project out the locX & time coordinate - (Applies to Rpc, Tgc, Mm, sTgc).

e2DimWithTime 

Project out the locY & time coordinate - (Applies to Rpc, Tgc, sTgc).

Definition at line 43 of file MeasurementCalibratorBase.h.

43 {
44 e1DimNoTime = 0,
45 e1DimRotNoTime = 1,
47 e2DimNoTime = 2,
48 e1DimWithTime = 3,
49 e1DimRotWithTime = 4,
50 e2DimWithTime = 5,
51 };

Member Function Documentation

◆ calibrate() [1/4]

CalibSpacePointVec MuonR4::SpacePointCalibrator::calibrate ( const Acts::CalibrationContext & ctx,
const Amg::Vector3D & seedPosInChamb,
const Amg::Vector3D & seedDirInChamb,
const double timeDelay,
const CalibSpacePointVec & spacePoints ) const
finaloverride

Definition at line 80 of file SpacePointCalibrator.cxx.

84 {
85 CalibSpacePointVec newCalib{};
86 const EventContext* ctx = cctx.get<const EventContext*>();
87 newCalib.reserve(spacePoints.size());
88 for (const CalibSpacePointPtr& sp : spacePoints){
89 newCalib.emplace_back(calibrate(*ctx, *sp, segPos, segDir, timeDelay));
90 }
91 return newCalib;
92 }
static Double_t sp
CalibSpacePointPtr calibrate(const EventContext &ctx, const SpacePoint *spacePoint, const Amg::Vector3D &seedPosInChamb, const Amg::Vector3D &seedDirInChamb, const double timeDelay) const override final
ISpacePointCalibrator::CalibSpacePointVec CalibSpacePointVec
ISpacePointCalibrator::CalibSpacePointPtr CalibSpacePointPtr

◆ calibrate() [2/4]

CalibSpacePointPtr MuonR4::SpacePointCalibrator::calibrate ( const EventContext & ctx,
const CalibratedSpacePoint & spacePoint,
const Amg::Vector3D & seedPosInChamb,
const Amg::Vector3D & seedDirInChamb,
const double timeDelay ) const
finaloverride

Definition at line 61 of file SpacePointCalibrator.cxx.

65 {
66 CalibSpacePointPtr calibSP{};
67 if (spacePoint.type() != xAOD::UncalibMeasType::Other){
68 calibSP = calibrate(ctx, spacePoint.spacePoint(), segPos, segDir, timeDelay);
69 } else {
70 calibSP = std::make_unique<CalibratedSpacePoint>(spacePoint);
71 }
72 if (spacePoint.fitState() == State::Outlier) {
73 calibSP->setFitState(State::Outlier);
74 } else if (spacePoint.fitState() == State::Duplicate) {
75 calibSP->setFitState(State::Duplicate);
76 }
77 return calibSP;
78 }

◆ calibrate() [3/4]

CalibSpacePointPtr MuonR4::SpacePointCalibrator::calibrate ( const EventContext & ctx,
const SpacePoint * spacePoint,
const Amg::Vector3D & seedPosInChamb,
const Amg::Vector3D & seedDirInChamb,
const double timeDelay ) const
finaloverride

In valid drift radius has been created

Set time measurement used by the fast fitter, corrected by the tube T0 and a fast estimate of the time of flight

Set time measurement used by the fast fitter, corrected by the tube T0 and a fast estimate of the time of flight

Transform the space point into the local frame to calculate the propagation time towards the readout

Average the time

Add the difference to the covariance though

Update the covariance of the strip measurements along the strip

Definition at line 94 of file SpacePointCalibrator.cxx.

98 {
99 const ActsTrk::GeometryContext* gctx{nullptr};
100 if (!SG::get(gctx, m_geoCtxKey, ctx).isSuccess()) {
101 return CalibSpacePointPtr{};
102 }
103 const Amg::Vector3D& spPos{spacePoint->localPosition()};
104 const Amg::Transform3D& locToGlob{spacePoint->msSector()->localToGlobalTransform(*gctx)};
105 const Amg::Vector3D& chDir{spacePoint->sensorDirection()};
106
107 // Adjust the space point position according to the external seed. But only if the space point
108 // is a 1D strip
109 Amg::Vector3D calibSpPos = spacePoint->dimension() == 2 ? spPos
110 : spPos + Amg::intersect<3>(posInChamb, dirInChamb, spPos, chDir).value_or(0) * chDir;
111
112 SpacePoint::Cov_t cov = spacePoint->covariance();
113 CalibSpacePointPtr calibSP{};
114 ATH_MSG_VERBOSE("Calibrate "<<(*spacePoint) <<" -> updated pos "<<Amg::toString(calibSpPos));
115 switch (spacePoint->type()) {
116 using enum xAOD::UncalibMeasType;
117 case MdtDriftCircleType: {
118 const Amg::Vector3D locClosestApproach = posInChamb
119 + Amg::intersect<3>(spPos, chDir,
120 posInChamb, dirInChamb).value_or(0) * dirInChamb;
121
122 Amg::Vector3D closestApproach{locToGlob* locClosestApproach};
123 const double timeOfArrival = closestApproach.mag() * c_inv + ActsTrk::timeToAthena(timeDelay);
124
125 if (ATH_LIKELY(spacePoint->dimension() == 1)) {
126 auto* dc = static_cast<const xAOD::MdtDriftCircle*>(spacePoint->primaryMeasurement());
127 MdtCalibInput calibInput{*dc, *gctx};
128 calibInput.setTrackDirection(locToGlob.linear() * dirInChamb,
129 Acts::abs(dirInChamb.phi() - 90._degree) > 1.e-7 );
130 calibInput.setTimeOfFlight(timeOfArrival);
131 calibInput.setClosestApproach(std::move(closestApproach));
132 ATH_MSG_VERBOSE("Parse hit calibration "<<m_idHelperSvc->toString(dc->identify())<<", "<<calibInput);
133 MdtCalibOutput calibOutput = m_mdtCalibrationTool->calibrate(ctx, calibInput);
134 ATH_MSG_VERBOSE("Returned calibration object "<<calibOutput);
135 State fitState{State::Valid};
137 if (calibOutput.status() != Muon::MdtDriftCircleStatus::MdtStatusDriftTime) {
138 ATH_MSG_DEBUG("Failed to create a valid hit from "<<m_idHelperSvc->toString(dc->identify())
139 <<std::endl<<calibInput<<std::endl<<calibOutput);
140 fitState = State::FailedCalib;
141 cov[Acts::toUnderlying(AxisDefs::etaCov)] = dc->readoutElement()->innerTubeRadius();
142 } else {
143 cov[Acts::toUnderlying(AxisDefs::etaCov)] = Acts::square(calibOutput.driftRadiusUncert());
144 }
145 calibSP = std::make_unique<CalibratedSpacePoint>(spacePoint, std::move(calibSpPos), fitState);
146 calibSP->setCovariance(cov);
147 calibSP->setDriftRadius(calibOutput.driftRadius());
149 double fastToF {(locToGlob * calibSP->localPosition()).norm() * c_inv};
150 calibSP->setTimeMeasurement(ActsTrk::timeToActs(dc->tdc() * IMdtCalibrationTool::tdcBinSize -
151 calibOutput.tubeT0() - fastToF - calibOutput.signalPropagationTime()));
152 ATH_MSG_VERBOSE("Mdt time Meas: " << ActsTrk::timeToAthena(calibSP->time())
153 << ", ToF / fastToF: " << fastToF << " / " << closestApproach.mag() * c_inv
154 << ", tubeT0: " << calibOutput.tubeT0() << ", Signal Prop Time: " << calibOutput.signalPropagationTime());
155 } else {
156 auto* dc = static_cast<const xAOD::MdtTwinDriftCircle*>(spacePoint->primaryMeasurement());
157 MdtCalibInput calibInput{*dc, *gctx};
158 calibInput.setClosestApproach(closestApproach);
159 calibInput.setTimeOfFlight(timeOfArrival);
160
161 MdtCalibInput twinInput{dc->twinIdentify(), dc->twinAdc(), dc->twinTdc(), dc->readoutElement(), *gctx};
162 twinInput.setClosestApproach(closestApproach);
163 twinInput.setTimeOfFlight(timeOfArrival);
164
165 MdtCalibTwinOutput calibOutput = m_mdtCalibrationTool->calibrateTwinTubes(ctx,
166 std::move(calibInput),
167 std::move(twinInput));
168
169 State fitState{State::Valid};
170 if (calibOutput.primaryStatus() != Muon::MdtDriftCircleStatus::MdtStatusDriftTime) {
171 ATH_MSG_DEBUG("Failed to create a valid hit from "<<m_idHelperSvc->toString(dc->identify())
172 <<std::endl<<calibOutput);
173 cov[Acts::toUnderlying(AxisDefs::etaCov)] = Acts::square(dc->readoutElement()->innerTubeRadius());
174 cov[Acts::toUnderlying(AxisDefs::phiCov)] = Acts::square(0.5* dc->readoutElement()->activeTubeLength(dc->measurementHash()));
175 fitState = State::FailedCalib;
176 } else {
177 cov[Acts::toUnderlying(AxisDefs::etaCov)] = Acts::square(calibOutput.uncertPrimaryR());
178 cov[Acts::toUnderlying(AxisDefs::phiCov)] = Acts::square(calibOutput.sigmaZ());
179 }
180 calibSP = std::make_unique<CalibratedSpacePoint>(spacePoint, std::move(calibSpPos), fitState);
181 calibSP->setCovariance(cov);
182 calibSP->setDriftRadius(calibOutput.primaryDriftR());
184 double fastToF {(locToGlob * calibSP->localPosition()).norm() * c_inv};
185 double tubeT0 {m_mdtCalibrationTool->getCalibConstants(ctx, dc->identify())->tubeCalib->getCalib(dc->identify())->t0};
186 // Remember to add the signal propagation time!!
187 calibSP->setTimeMeasurement(ActsTrk::timeToActs(calibOutput.primaryTdc() * IMdtCalibrationTool::tdcBinSize - tubeT0 - fastToF));
188 }
189 break;
190 }
191 case RpcStripType: {
192 auto* strip = static_cast<const xAOD::RpcMeasurement*>(spacePoint->primaryMeasurement());
193
195 const Amg::Transform3D toGasGap{strip->readoutElement()->globalToLocalTransform(*gctx, strip->layerHash()) * locToGlob};
196 const Amg::Vector3D lPos = toGasGap * calibSpPos;
198 calibSP = std::make_unique<CalibratedSpacePoint>(spacePoint, std::move(calibSpPos));
199
200 // @TODO the constants could be converted to what is needed here (units, inverse) at initialization/construction time
201 // in particular 1/m_rpcSignalVelocity
202 cov[Acts::toUnderlying(AxisDefs::timeCov)] = Acts::square(ActsTrk::timeToActs(m_rpcTimeResolution.value()));
203
204 const double time1 = strip->time()
205 - strip->readoutElement()->distanceToEdge(strip->layerHash(), lPos,
206 EdgeSide::readOut) /m_rpcSignalVelocity;
207
208 if (spacePoint->dimension() == 2) {
209 auto* strip2 = static_cast<const xAOD::RpcMeasurement*>(spacePoint->secondaryMeasurement());
210
211 const double time2 = strip2->time() -
212 strip2->readoutElement()->distanceToEdge(strip2->layerHash(),lPos, EdgeSide::readOut)/m_rpcSignalVelocity;
214 calibSP->setTimeMeasurement(ActsTrk::timeToActs(0.5*(time1 + time2)));
216 cov[Acts::toUnderlying(AxisDefs::timeCov)] += Acts::square(ActsTrk::timeToActs(0.5*(time1 - time2)));
217 } else {
218 calibSP->setTimeMeasurement(ActsTrk::timeToActs(time1));
219 }
220 calibSP->setCovariance(cov);
221 ATH_MSG_VERBOSE("Create rpc space point "<<m_idHelperSvc->toString(strip->identify())<<", dimension "<<spacePoint->dimension()
222 << ", at "<<Amg::toString(calibSP->localPosition())<<", uncalib time: "
223 <<strip->time()<<", calib time: "<<ActsTrk::timeToAthena(calibSP->time())<<" cov " <<calibSP->covariance()
224 <<", time Uncert: "<<ActsTrk::timeToAthena(std::sqrt(calibSP->covariance()[Acts::toUnderlying(AxisDefs::timeCov)])));
225 break;
226 }
227 case TgcStripType: {
228 calibSP = std::make_unique<CalibratedSpacePoint>(spacePoint, std::move(calibSpPos));
230 if (spacePoint->primaryMeasurement()->measuresPhi()) {
231 const auto* strip = static_cast<const xAOD::TgcStrip*>(spacePoint->primaryMeasurement());
232 const Amg::Transform3D toGasGap{strip->readoutElement()->globalToLocalTransform(*gctx, strip->layerHash()) * locToGlob};
233 const Amg::Vector3D lPos = toGasGap * calibSP->localPosition();
234 const auto& sensorPlane = strip->readoutElement()->sensorLayout(strip->layerHash());
235 const auto& radialDesign = strip->readoutElement()->stripLayout(strip->layerHash());
236 cov[Acts::toUnderlying(AxisDefs::phiCov)] = Acts::square(
237 radialDesign.stripPitch(strip->channelNumber(), sensorPlane->to2D(lPos,true))) / 12.;
238 }
239 calibSP->setCovariance(cov);
240 break;
241 }
242 case MMClusterType: {
243 const xAOD::MMCluster* cluster = static_cast<const xAOD::MMCluster*>(spacePoint->primaryMeasurement());
244 Amg::Vector3D globalPos{locToGlob * posInChamb};
245 Amg::Vector3D globalDir{locToGlob.linear() * dirInChamb};
246
247 std::pair<double, double> calibPosCov {calibrateMM(ctx, *gctx, *cluster, globalPos, globalDir)};
248
249 ATH_MSG_DEBUG("Calibrated pos and cov" << calibPosCov.first << " " << calibPosCov.second);
250 cov[Acts::toUnderlying(AxisDefs::etaCov)] = calibPosCov.second;
251 Amg::Transform3D toChamberTrans{ locToGlob.inverse() * cluster->readoutElement()->localToGlobalTransform(*gctx, cluster->layerHash())};
252
253 // since we want to take the second coordiante from the external estimate we need to transform the sp posiiton to the layer frame, replace the precission coordinate and transform back
254 Amg::Vector3D calibSpPosInLayer = toChamberTrans.inverse() * calibSpPos;
255 ATH_MSG_DEBUG("in layer before calibration" << Amg::toString(calibSpPosInLayer));
256 calibSpPosInLayer.x() = calibPosCov.first;
257 ATH_MSG_DEBUG("in layer after calibration" << Amg::toString(calibSpPosInLayer));
258 calibSpPos = toChamberTrans * calibSpPosInLayer;
259
260 calibSP = std::make_unique<CalibratedSpacePoint>(spacePoint, std::move(calibSpPos));
261 calibSP->setCovariance(cov);
262 ATH_MSG_DEBUG("calibrated MM cluster "<<m_idHelperSvc->toString(cluster->identify()) << " loc x old " << cluster->localPosition<1>()[0] << " new loc x " << calibSP->localPosition()[1] << "cov " << calibSP->covariance());
263
264 break;
265 }
266 case sTgcStripType: {
267 const auto* cluster = static_cast<const xAOD::sTgcMeasurement*>(spacePoint->primaryMeasurement());
268
269 // We do not apply any correction for pads or wire only space points
270 if (cluster->channelType() != sTgcIdHelper::sTgcChannelTypes::Strip) {
271 ATH_MSG_DEBUG("Calibrating an sTGC Pad or wire " << m_idHelperSvc->toString(cluster->identify()));
272 calibSP = std::make_unique<CalibratedSpacePoint>(spacePoint, std::move(calibSpPos));
273 calibSP->setCovariance(cov);
274 break;
275 }
276
277 std::optional<double> posAlongTheStrip{std::nullopt};
278
279 // check if the space point is a strip/wire combination and take the position along the strip from the wire measurement
280 if(spacePoint->secondaryMeasurement()) {
281 const auto* secMeas = static_cast<const xAOD::sTgcMeasurement*>(spacePoint->secondaryMeasurement());
282 ATH_MSG_VERBOSE("Using secondary measurement "<< m_idHelperSvc->toString(secMeas->identify())<<" for sTGC strip cluster " << m_idHelperSvc->toString(cluster->identify()));
283 // Extract scalar value - use 2D for pads (2 dimensions), 1D for wires (1 dimension)
284 if (secMeas->numDimensions() == 2) {
285 posAlongTheStrip = static_cast<double>(secMeas->localPosition<2>()[0]);
286 } else {
287 posAlongTheStrip = static_cast<double>(secMeas->localPosition<1>()[0]);
288 }
289 } else {
290 ATH_MSG_VERBOSE("No secondary measurement for sTGC strip cluster " << m_idHelperSvc->toString(cluster->identify()));
291 }
292
293 Amg::Vector3D globalPos{locToGlob * posInChamb};
294 Amg::Vector3D globalDir{locToGlob.linear() * dirInChamb};
295
296 const auto* stripClus = static_cast<const xAOD::sTgcStripCluster*>(cluster);
297 const auto [calibPos, calibCov] = calibratesTGC(ctx, *gctx, *stripClus, posAlongTheStrip, globalPos, globalDir);
298
299 ATH_MSG_DEBUG("Calibrated pos and cov" << calibPos << " " << calibCov);
300 cov[Acts::toUnderlying(AxisDefs::etaCov)] = calibCov;
301 Amg::Transform3D toChamberTrans{ locToGlob.inverse() * cluster->readoutElement()->localToGlobalTransform(*gctx, cluster->layerHash())};
302
303 // since we want to take the second coordiante from the external estimate we need to transform the sp posiiton to the layer frame, replace the precission coordinate and transform back
304 Amg::Vector3D calibSpPosInLayer = toChamberTrans.inverse() * calibSpPos;
305 ATH_MSG_DEBUG("in layer before calibration" << Amg::toString(calibSpPosInLayer));
306 calibSpPosInLayer.x() = calibPos;
307 ATH_MSG_DEBUG("in layer after calibration" << Amg::toString(calibSpPosInLayer));
308 calibSpPos = toChamberTrans * calibSpPosInLayer;
309
310 calibSP = std::make_unique<CalibratedSpacePoint>(spacePoint, std::move(calibSpPos));
311 calibSP->setCovariance(cov);
312 ATH_MSG_DEBUG("calibrated sTGC cluster "<<m_idHelperSvc->toString(cluster->identify()) << " loc x old " << cluster->localPosition<1>()[0] << " new loc x " << calibSP->localPosition()[1] << "cov " << calibSP->covariance());
313 break;
314 }
315
316 default:
317 ATH_MSG_WARNING("Do not know how to calibrate "<<m_idHelperSvc->toString(spacePoint->identify()));
318 }
319 return calibSP;
320 }
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
#define ATH_LIKELY(x)
static constexpr double tdcBinSize
Conversion to go from tdc counts -> drift Time.
void setClosestApproach(const Amg::Vector3D &approach)
Sets the closest approach.
void setTimeOfFlight(const double toF)
Sets the time of flight (Usually globPos.mag() * inverseSpeed of light).
void setTrackDirection(const Amg::Vector3D &trackDir, bool hasPhi)
Sets the direction of the externally determined track.
double driftRadiusUncert() const
Returns the uncertainty on the drift radius.
double driftRadius() const
Returns the drift radius of the calibrated object.
MdtDriftCircleStatus status() const
Status of the calibration.
double signalPropagationTime() const
Returns the signal propagation time.
double tubeT0() const
Returns the point in time where the muon typically enters the chamber.
MdtDriftCircleStatus primaryStatus() const
double primaryDriftR() const
double uncertPrimaryR() const
const Amg::Transform3D & localToGlobalTransform(const ActsTrk::GeometryContext &ctx) const
Returns the transformation from the local coordinate system of the readout element into the global AT...
std::pair< double, double > calibratesTGC(const EventContext &ctx, const ActsTrk::GeometryContext &gctx, const xAOD::sTgcStripCluster &cluster, std::optional< double > posAlongTheStrip, const Amg::Vector3D &globalPos, const Amg::Vector3D &globalDir) const
Calibrates the position and covariance of an sTGC (small-strip Thin Gap Chamber) cluster.
ToolHandle< IMdtCalibrationTool > m_mdtCalibrationTool
Gaudi::Property< double > m_rpcSignalVelocity
How fast does an electron signal travel along an rpc strip.
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc
ActsTrk::GeoContextReadKey_t m_geoCtxKey
access to the ACTS geometry context
Gaudi::Property< double > m_rpcTimeResolution
std::pair< double, double > calibrateMM(const EventContext &ctx, const ActsTrk::GeometryContext &gctx, const xAOD::MMCluster &cluster, const Amg::Vector3D &globalPos, const Amg::Vector3D &globalDir) const
Calibrates the position and covariance of a MicroMegas (MM) cluster.
std::array< double, 3 > Cov_t
Abrivation of the covariance type.
const MuonGMR4::MmReadoutElement * readoutElement() const override final
Retrieve the associated MmReadoutElement.
IdentifierHash layerHash() const override final
Returns the hash of the associated layer (Needed for surface retrieval).
const Identifier & identify() const
Returns the Athena identifier of the measurement.
float time() const
Returns the time.
ConstVectorMap< N > localPosition() const
Returns the local position of the measurement.
constexpr double timeToAthena(T actsT)
Converts a time unit from Acts to Athena units.
constexpr auto timeToActs(T athenaT)
Converts a time unit from Athena to Acts units.
std::optional< double > intersect(const AmgVector(N)&posA, const AmgVector(N)&dirA, const AmgVector(N)&posB, const AmgVector(N)&dirB)
Calculates the point B' along the line B that's closest to a second line A.
std::string toString(const Translation3D &translation, int precision=4)
GeoPrimitvesToStringConverter.
Eigen::Affine3d Transform3D
Eigen::Matrix< double, 3, 1 > Vector3D
CalibratedSpacePoint::State State
const T * get(const ReadCondHandleKey< T > &key, const EventContext &ctx)
Convenience function to retrieve an object given a ReadCondHandleKey.
MdtDriftCircle_v1 MdtDriftCircle
MdtTwinDriftCircle_v1 MdtTwinDriftCircle
TgcStrip_v1 TgcStrip
Definition TgcStripFwd.h:9
sTgcStripCluster_v1 sTgcStripCluster
UncalibMeasType
Define the type of the uncalibrated measurement.
RpcMeasurement_v1 RpcMeasurement
MMCluster_v1 MMCluster
sTgcMeasurement_v1 sTgcMeasurement

◆ calibrate() [4/4]

CalibSpacePointVec MuonR4::SpacePointCalibrator::calibrate ( const EventContext & ctx,
const std::vector< const SpacePoint * > & spacePoints,
const Amg::Vector3D & seedPosInChamb,
const Amg::Vector3D & seedDirInChamb,
const double timeDelay ) const
finaloverride

Definition at line 322 of file SpacePointCalibrator.cxx.

326 {
327 CalibSpacePointVec calibSpacePoints{};
328 calibSpacePoints.reserve(spacePoints.size());
329 for(const SpacePoint* spacePoint : spacePoints) {
330 CalibSpacePointPtr hit = calibrate(ctx, spacePoint, posInChamb, dirInChamb, timeDelay);
331 if (hit) {
332 calibSpacePoints.push_back(std::move(hit));
333 }
334 }
335 return calibSpacePoints;
336 }

◆ calibrateCombinedPrd()

void MuonR4::SpacePointCalibrator::calibrateCombinedPrd ( const EventContext & ctx,
const ActsTrk::GeometryContext & gctx,
const xAOD::CombinedMuonStrip * combinedPrd,
ActsTrk::MutableTrackContainer::TrackStateProxy state ) const
private

Calibrates the track states from a combined muon strip.

It's a pseudo measurement composed out of two 1D strip measurements residing in the same gas gap (Relevant for Rpc/Tgc/sTgc)

Parameters
ctxThe event context providing the necessary conditions and event-specific information.
gctxPointer to the ActsTrk::GeometryContext, used for geometry-related transformations.
combinedPrdPointer to the measurement carrying the actual prds which are to be combined on the track state
stateThe proxy to the actual track state to fill

Construct bound track parameters to fetch the global track position

Definition at line 402 of file SpacePointCalibrator.cxx.

405 {
406 const auto sl = ActsTrk::detail::xAODUncalibMeasCalibrator::pack(combinedPrd);
407
408 Amg::Vector2D cmbPos = xAOD::toEigen(combinedPrd->localPosition<2>());
409 AmgSymMatrix(2) cmbCov = xAOD::toEigen(combinedPrd->localCovariance<2>());
410 if (combinedPrd->type() == xAOD::UncalibMeasType::RpcStripType) {
411 if (m_useRpcTime) {
412 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<" Implement me");
413 }
414 setState<2>(ProjectorType::e2DimNoTime, cmbPos, cmbCov, sl, state);
415
416 } else if (combinedPrd->type() == xAOD::UncalibMeasType::TgcStripType) {
417 if (m_useTgcTime) {
418 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<" Implement me");
419 }
420
421 setState<2>(ProjectorType::e2DimNoTime, cmbPos, cmbCov, sl, state);
422
423 } else if(combinedPrd->type() == xAOD::UncalibMeasType::sTgcStripType) {
424 if (m_usesTgcTime) {
425 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<" Implement me");
426 }
427 // combined sTGC Space points can be strip/wire, strip/pad or pad/wire combinations.
428 const auto* primMeas = static_cast<const xAOD::sTgcMeasurement*>(combinedPrd->primaryStrip());
429
430 if(primMeas->channelType() == sTgcIdHelper::sTgcChannelTypes::Strip) {
431 const auto* primStripMeas = static_cast<const xAOD::sTgcStripCluster*>(primMeas);
433 const Acts::BoundTrackParameters trackPars{state.referenceSurface().getSharedPtr(),
434 state.parameters(), state.covariance(),
435 Acts::ParticleHypothesis::muon()};
436 std::pair<double, double> calibPosCov{calibratesTGC(ctx, gctx, *primStripMeas, cmbPos[1] ,
437 trackPars.position(gctx.context()),
438 trackPars.direction())};
439 cmbPos[0] = calibPosCov.first;
440 cmbCov(0,0) = calibPosCov.second;
441 }
442 setState<2>(ProjectorType::e2DimNoTime, cmbPos, cmbCov, sl, state);
443
444 } else {
445 THROW_EXCEPTION("Undefined uncalibrated measurement "
446 <<m_idHelperSvc->toString(combinedPrd->identify()));
447 }
448 }
#define AmgSymMatrix(dim)
if(pathvar)
Acts::GeometryContext context() const
static Acts::SourceLink pack(const Ptr_t &measurement)
Pack the measurement type pointer to an Acts::SourceLink including the intermediate conversion into a...
@ e2DimNoTime
Project out solely the locY - Complementary projector if the strip plane is rotated (Applies to Itk e...
void setState(const ProjectorType projector, const pos_t &locpos, const cov_t &cov, Acts::SourceLink link, proxy_t &trackState) const
Copy the local position & covariance into the Acts track state proxy.
Gaudi::Property< bool > m_useRpcTime
Load the Rpc time on the track states for the track fit.
Gaudi::Property< bool > m_useTgcTime
Load the Tgc bunch crossing ID on the track states.
Gaudi::Property< bool > m_usesTgcTime
const xAOD::MuonMeasurement * primaryStrip() const
Returns the primary associated measurement.
virtual xAOD::UncalibMeasType type() const override final
Returns the type of the measurement type as a simple enumeration.
Eigen::Matrix< double, 2, 1 > Vector2D
#define THROW_EXCEPTION(MESSAGE)
Definition throwExcept.h:10

◆ calibrateMM()

std::pair< double, double > MuonR4::SpacePointCalibrator::calibrateMM ( const EventContext & ctx,
const ActsTrk::GeometryContext & gctx,
const xAOD::MMCluster & cluster,
const Amg::Vector3D & globalPos,
const Amg::Vector3D & globalDir ) const
private

Calibrates the position and covariance of a MicroMegas (MM) cluster.

Parameters
ctxThe event context providing the necessary conditions and event-specific information.
gctxPointer to the ActsTrk::GeometryContext, used for geometry-related transformations.
clusterPointer to the xAOD::MMCluster representing the MicroMegas cluster to be calibrated.
globalPosThe global position from an external measurement.
globalDirThe global position from an external measurement.
calibLocPosThe calibrated local position of the cluster (output parameter).
calibLocCovThe calibrated local covariance of the cluster (output parameter).

Definition at line 357 of file SpacePointCalibrator.cxx.

361 {
362 std::vector<NSWCalib::CalibratedStrip> calibClus;
363 StatusCode sc = m_nswCalibTool->calibrateClus(ctx, gctx, cluster, globalPos, calibClus);
364 if(sc.isFailure()) {
365 ATH_MSG_WARNING("Failed to calibrate MM cluster "<<m_idHelperSvc->toString(cluster.identify()));
366 return std::make_pair(0., 0.);
367 }
368
369 Amg::Vector2D locPos{cluster.localPosition<1>()[0] * Amg::Vector2D::UnitX()};
371
372 Amg::MatrixX calibCov{};
373 calibCov.resize(1,1);
374 calibCov(0,0) = cluster.localCovariance<1>()(0, 0);
375 ATH_MSG_DEBUG("old loc pos " << locPos[0] << " old cov" << calibCov(0,0) );
376
377 Muon::IMMClusterBuilderTool::RIO_Author rotAuthor = m_clusterBuilderToolMM->getCalibratedClusterPosition(ctx, calibClus, locDir ,locPos, calibCov);
378 if(rotAuthor == Muon::IMMClusterBuilderTool::RIO_Author::unKnownAuthor){
379 THROW_EXCEPTION("Failed to calibrate MM cluster "<<m_idHelperSvc->toString(cluster.identify()));
380 }
381 ATH_MSG_DEBUG("new loc pos " << locPos[0] << " new cov" << calibCov(0,0) );
382 return std::make_pair(locPos[0], calibCov(0,0));
383 }
static Double_t sc
Amg::Transform3D globalToLocalTransform(const ActsTrk::GeometryContext &ctx) const
Returns the transformation from the global ATLAS coordinate system into the local coordinate system o...
ToolHandle< Muon::IMMClusterBuilderTool > m_clusterBuilderToolMM
ToolHandle< Muon::INSWCalibTool > m_nswCalibTool
MMClusterOnTrack::Author RIO_Author
Refinement of the cluster position after the cluster calibration loop is ran with a complete external...
ConstMatrixMap< N > localCovariance() const
Returns the local covariance of the measurement.
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic > MatrixX
Dynamic Matrix - dynamic allocation.
::StatusCode StatusCode
StatusCode definition for legacy code.
Amg::Vector3D toLocal(const Amg::Transform3D &toLocalTrans, const Amg::Vector3D &dir)
Rotates a direction vector into a local frame: x-axis : Parallell to the radial direction of the dete...

◆ calibrateSourceLink()

void MuonR4::SpacePointCalibrator::calibrateSourceLink ( const Acts::GeometryContext & geoctx,
const Acts::CalibrationContext & cctx,
const Acts::SourceLink & link,
ActsTrk::MutableTrackContainer::TrackStateProxy state ) const
finaloverride

Construct bound track parameters to fetch the global track position

Only the combined muonstrip has zero dimensions

Vast majority of the measurements are ordinary drift tubes

Invalid drift radius has been created

Twin tube case

Legacy BM / BO chambers

BI clusters

Definition at line 449 of file SpacePointCalibrator.cxx.

452 {
453
455 const Acts::BoundTrackParameters trackPars{trackState.referenceSurface().getSharedPtr(),
456 trackState.parameters(), trackState.covariance(),
457 Acts::ParticleHypothesis::muon()};
458
459
460 const auto* muonMeas = ActsTrk::detail::xAODUncalibMeasCalibrator::unpack(link);
461 const ActsTrk::GeometryContext* gctx = geoctx.get<const ActsTrk::GeometryContext*>();
462 const EventContext* ctx = cctx.get<const EventContext*>();
463 ATH_MSG_VERBOSE("Calibrate measurement "<<m_idHelperSvc->toString(xAOD::identify(muonMeas))
464 <<" @ surface "<<trackState.referenceSurface().geometryId());
466 if (muonMeas->numDimensions() == 0u) {
467 calibrateCombinedPrd(*ctx, *gctx, static_cast<const xAOD::CombinedMuonStrip*>(muonMeas),
468 trackState);
469 return;
470
471 }
472 const Amg::Vector3D trackPos{trackPars.position(geoctx)};
473 const Amg::Vector3D trackDir{trackPars.direction()};
474
475 switch (muonMeas->type()){
476 using enum xAOD::UncalibMeasType;
477 case MdtDriftCircleType: {
478 const auto* dc = static_cast<const xAOD::MdtDriftCircle*>(muonMeas);
479 MdtCalibInput calibInput{*dc, *gctx};
480 calibInput.setClosestApproach(trackPos);
481 //calibInput.setTimeOfFlight(trackPars.parameters()[Acts::eBoundTime]);
482 calibInput.setTrackDirection(trackDir, true);
483 const double driftSign = m_MdtSignFromSegment ?
484 static_cast<double>(dec_trackSign(*dc)) :
485 Acts::copySign(1.,trackPars.parameters()[Acts::eBoundLoc0]);
486
488 if (ATH_LIKELY(muonMeas->numDimensions() == 1)) {
489 MdtCalibOutput calibOutput = m_mdtCalibrationTool->calibrate(*ctx, calibInput);
490 ATH_MSG_VERBOSE("Returned calibration object "<<calibOutput);
491 AmgVector(1) pos{AmgVector(1)::Zero()};
492 AmgSymMatrix(1) cov{AmgSymMatrix(1)::Identity()};
494 if (calibOutput.status() != Muon::MdtDriftCircleStatus::MdtStatusDriftTime) {
495 ATH_MSG_DEBUG("Failed to create a valid hit from "<<m_idHelperSvc->toString(dc->identify())
496 <<std::endl<<calibInput<<std::endl<<calibOutput);
497 cov(Acts::eBoundLoc0,Acts::eBoundLoc0) = std::pow(dc->readoutElement()->innerTubeRadius(), 2);
498 } else {
499 pos[Acts::eBoundLoc0] = driftSign*calibOutput.driftRadius();
500 cov(Acts::eBoundLoc0, Acts::eBoundLoc0) = std::pow(calibOutput.driftRadiusUncert(), 2);
501 }
502 setState<1>(ProjectorType::e1DimNoTime, pos, cov, link, trackState);
503 }
505 else {
506 const auto* twinDC = static_cast<const xAOD::MdtTwinDriftCircle*>(muonMeas);
507 MdtCalibInput twinInput{twinDC->twinIdentify(), twinDC->twinAdc(), twinDC->twinTdc(), twinDC->readoutElement(), *gctx};
508 twinInput.setClosestApproach(trackPos);
509 twinInput.setTimeOfFlight(trackPars.parameters()[Acts::eBoundTime]);
510
511 MdtCalibTwinOutput calibOutput = m_mdtCalibrationTool->calibrateTwinTubes(*ctx,
512 std::move(calibInput),
513 std::move(twinInput));
514 Amg::Vector2D locPos{Amg::Vector2D::Zero()};
515 AmgSymMatrix(2) locCov{AmgSymMatrix(2)::Identity()};
516 if (calibOutput.primaryStatus() != Muon::MdtDriftCircleStatus::MdtStatusDriftTime) {
517 ATH_MSG_DEBUG("Failed to create a valid hit from "<<m_idHelperSvc->toString(dc->identify())
518 <<std::endl<<calibOutput);
519 locCov(Acts::eBoundLoc0, Acts::eBoundLoc0) = std::pow(dc->readoutElement()->innerTubeRadius(), 2);
520 locCov(Acts::eBoundLoc1, Acts::eBoundLoc1) = std::pow(0.5* dc->readoutElement()->activeTubeLength(dc->measurementHash()), 2);
521 } else {
522 locCov(Acts::eBoundLoc0, Acts::eBoundLoc0) = std::pow(calibOutput.uncertPrimaryR(), 2);
523 locCov(Acts::eBoundLoc1, Acts::eBoundLoc1) = std::pow(calibOutput.sigmaZ(), 2);
524 locPos[Acts::eBoundLoc0] = driftSign*calibOutput.primaryDriftR();
525 locPos[Acts::eBoundLoc1] = calibOutput.locZ();
526 }
527 setState<2>(ProjectorType::e2DimNoTime, locPos, locCov, link, trackState);
528 }
529 break;
530 } case RpcStripType: {
531 const auto* rpcClust = static_cast<const xAOD::RpcMeasurement*>(muonMeas);
533 if (ATH_LIKELY(rpcClust->numDimensions() == 1)) {
534
535 if (!m_useRpcTime) {
536 const auto proj = rpcClust->measuresPhi() ? ProjectorType::e1DimRotNoTime
538 setState<1>(proj, rpcClust->localPosition<1>(),
539 rpcClust->localCovariance<1>(), link, trackState);
540 } else {
541 AmgVector(2) measPars{AmgVector(2)::Zero()};
542 AmgSymMatrix(2) measCov{AmgSymMatrix(2)::Identity()};
543 measPars[0] = rpcClust->localPosition<1>()[0];
544 measCov(0,0) = rpcClust->localCovariance<1>()(0, 0);
545 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<"Please fix me using the ActsInterops package");
546 measCov(1,1) = std::pow(m_rpcTimeResolution, 2);
547 const auto proj = rpcClust->measuresPhi() ? ProjectorType::e1DimRotWithTime
549 setState<2>(proj, measPars, measCov, link, trackState);
550 }
551 }
553 else {
554 if (!m_useRpcTime) {
556 rpcClust->localPosition<2>(),
557 rpcClust->localCovariance<2>(), link, trackState);
558 } else {
559 AmgVector(3) measPars{AmgVector(3)::Zero()};
560 AmgSymMatrix(3) measCov{AmgSymMatrix(3)::Identity()};
561 measPars.block<2,1>(0,0) = xAOD::toEigen(rpcClust->localPosition<2>());
562 measCov.block<2,2>(0,0) = xAOD::toEigen(rpcClust->localCovariance<2>());
563 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<"Please fix me using the ActsInterops package");
564 measCov(2,2) = std::pow(m_rpcTimeResolution, 2);
565 setState<3>(ProjectorType::e2DimWithTime, measPars, measCov, link, trackState);
566 }
567 }
568 break;
569 } case TgcStripType: {
570 const auto* tgcClust = static_cast<const xAOD::TgcStrip*>(muonMeas);
571 if (!m_useTgcTime) {
572 if (!tgcClust->measuresPhi()) {
574 tgcClust->localPosition<1>(),
575 tgcClust->localCovariance<1>(),
576 link, trackState);
577
578 } else {
579 const auto [pos, cov] = xAOD::positionAndCovariance(tgcClust);
580 setState<2>(ProjectorType::e1DimRotNoTime, pos, cov, link, trackState);
581
582 }
583 } else {
584 ATH_MSG_WARNING("Tgc time calibration to be implemented...");
585 }
586 break;
587 }
588 case MMClusterType: {
589 const auto* mmClust = static_cast<const xAOD::MMCluster*>(muonMeas);
590 std::pair<double, double> calibPosCov{calibrateMM(*ctx,* gctx, *mmClust, trackPos, trackDir)};
591 AmgVector(1) pos{AmgVector(1)(calibPosCov.first)};
592 AmgSymMatrix(1) cov{AmgSymMatrix(1)(calibPosCov.second)};
593
594 setState<1>(ProjectorType::e1DimNoTime, pos, cov, link, trackState);
595 break;
596 } case sTgcStripType: {
597 const auto* stgcClust = static_cast<const xAOD::sTgcMeasurement*>(muonMeas);
598
599 if(stgcClust->channelType() == sTgcIdHelper::sTgcChannelTypes::Wire) {
601 muonMeas->localPosition<1>(),
602 muonMeas->localCovariance<1>(), link, trackState);
603 } else if (stgcClust->channelType() == sTgcIdHelper::sTgcChannelTypes::Pad) {
605 stgcClust->localPosition<2>(),
606 stgcClust->localCovariance<2>(), link, trackState);
607 } else { // strips
608 const auto stgCluster = static_cast<const xAOD::sTgcStripCluster*>(muonMeas);
609 std::pair<double, double> calibPosCov{calibratesTGC(*ctx, *gctx, *stgCluster, std::nullopt, trackPos, trackDir)};
610 if(!m_usesTgcTime) {
611 AmgVector(1) pos{calibPosCov.first};
612 AmgSymMatrix(1) cov{calibPosCov.second};
613 setState<1>(ProjectorType::e1DimNoTime, pos, cov, link, trackState);
614 } else {
615 ATH_MSG_WARNING("sTGC time calibration to be implemented...");
616 AmgVector(2) pos{AmgVector(2)::Zero()};
617 AmgSymMatrix(2) cov{AmgSymMatrix(2)::Zero()};
618 pos[0] = calibPosCov.first;
619 pos[1] = stgCluster->time();
620 cov(0,0) = calibPosCov.second;
621 ATH_MSG_WARNING(__FILE__<<":"<<__LINE__<<"Please fix me using the ActsInterops package");
622 cov(1,1) = std::pow(25 /*ns*/, 2);
623
624 setState<2>(ProjectorType::e1DimWithTime, pos, cov, link, trackState);
625 }
626 }
627 break;
628 } case Other: {
629 ActsTrk::detail::xAODUncalibMeasCalibrator auxCalibrator{};
630 auxCalibrator.calibrate(geoctx, cctx, link, trackState);
631 break;
632 } default: {
633 THROW_EXCEPTION("The parsed measurement is not a muon measurement. Please check.");
634 }
635 }
636 }
#define AmgVector(rows)
@ e2DimWithTime
Project out the locY & time coordinate - (Applies to Rpc, Tgc, sTgc).
@ e1DimWithTime
Project out the two spatial coordinates - (Applies to ITk pixel, BI-Rpc, sTgc pad).
@ e1DimRotNoTime
Project out solely the locX (Applies to Itk strips, Rpc, Tgc, sTgc, Mm).
@ e1DimRotWithTime
Project out the locX & time coordinate - (Applies to Rpc, Tgc, Mm, sTgc).
void calibrate(const Acts::GeometryContext &gctx, const Acts::CalibrationContext &cctx, const Acts::SourceLink &sl, const MutableTrackStateBackend::TrackStateProxy trackState) const
: Interface method for the Acts fitter to calibrate the trajectory track states from the source link ...
static const xAOD::UncalibratedMeasurement * unpack(const Acts::SourceLink &sl)
Helper method to unpack an Acts source link to an uncalibrated measurement.
void calibrateCombinedPrd(const EventContext &ctx, const ActsTrk::GeometryContext &gctx, const xAOD::CombinedMuonStrip *combinedPrd, ActsTrk::MutableTrackContainer::TrackStateProxy state) const
Calibrates the track states from a combined muon strip.
Gaudi::Property< bool > m_MdtSignFromSegment
void Zero(TH1D *hin)
Definition generate.cxx:32
const Identifier & identify(const UncalibratedMeasurement *meas)
Returns the associated identifier from the muon measurement.
std::pair< Amg::Vector2D, AmgSymMatrix(2)> positionAndCovariance(const MuonMeasurement *oneDimMeas)
Returns the 1D position of the uncalibrated measurement expressed in the coordinate system of the mea...
CombinedMuonStrip_v1 CombinedMuonStrip

◆ calibratesTGC()

std::pair< double, double > MuonR4::SpacePointCalibrator::calibratesTGC ( const EventContext & ctx,
const ActsTrk::GeometryContext & gctx,
const xAOD::sTgcStripCluster & cluster,
std::optional< double > posAlongTheStrip,
const Amg::Vector3D & globalPos,
const Amg::Vector3D & globalDir ) const
private

Calibrates the position and covariance of an sTGC (small-strip Thin Gap Chamber) cluster.

Parameters
ctxThe event context providing the necessary conditions for the calibration.
gctxPointer to the ActsTrk::GeometryContext, which provides geometry-related information.
clusterPointer to the sTGC strip cluster to be calibrated.
posAlongTheStripThe position along the strip obtained from the secondary measurement(wire), 0 if no wire measurement is present.
globalPosThe global position from an external measurement.
globalDirThe global direction from an external measurement.
[out]calibLocPosThe calibrated local position of the cluster (output parameter).
[out]calibLocCovThe calibrated local covariance of the cluster (output parameter).

Definition at line 385 of file SpacePointCalibrator.cxx.

390 {
391
392 // if the second coordiante was not provided by the wire, take it from the seed track position
393 if(!posAlongTheStrip) {
394 Amg::Vector3D extPosLocal = cluster.readoutElement()->globalToLocalTransform(gctx, cluster.layerHash()) * globalPos;
395 posAlongTheStrip = extPosLocal[1];
396 }
397
398 // For now just copying over the local position and covariance. Eventually this should apply corrections from B-Lines and as build geometry
399
400 return std::make_pair(cluster.localPosition<1>()[0], cluster.localCovariance<1>()(0,0));
401 }
IdentifierHash layerHash() const override final
Returns the hash of the associated gasGap layer.
const MuonGMR4::sTgcReadoutElement * readoutElement() const override final
Retrieve the associated sTgcReadoutElement.

◆ driftAcceleration() [1/2]

double MuonR4::SpacePointCalibrator::driftAcceleration ( const Acts::CalibrationContext & cctx,
const CalibratedSpacePoint & spacePoint,
const double timeDelay ) const
finaloverride

Definition at line 669 of file SpacePointCalibrator.cxx.

671 {
672 if(spacePoint.type() == xAOD::UncalibMeasType::MdtDriftCircleType) {
673 const MuonCalib::MdtFullCalibData* calibConsts =
674 m_mdtCalibrationTool->getCalibConstants(*cctx.get<const EventContext*>(), spacePoint.spacePoint()->identify());
675 return ActsTrk::accelerationToActs(calibConsts->rtRelation->rt()->driftAcceleration(ActsTrk::timeToAthena(spacePoint.time() - timeDelay)));
676 }
677 return 0.;
678 }
constexpr double accelerationToActs(const double athenaA)
Converts an acceleration from Athena to Acts units.

◆ driftAcceleration() [2/2]

double MuonR4::SpacePointCalibrator::driftAcceleration ( const Acts::CalibrationContext & ctx,
const CalibratedSpacePoint & spacePoint ) const
finaloverride

Definition at line 347 of file SpacePointCalibrator.cxx.

348 {
349 if(spacePoint.type() == xAOD::UncalibMeasType::MdtDriftCircleType) {
350 const MuonCalib::MdtFullCalibData* calibConsts = m_mdtCalibrationTool->getCalibConstants(*ctx.get<const EventContext*>(), spacePoint.spacePoint()->identify());
351 const std::optional<double> driftTime = calibConsts->rtRelation->tr()->driftTime(spacePoint.driftRadius());
352 return ActsTrk::accelerationToActs(calibConsts->rtRelation->rt()->driftAcceleration(driftTime.value_or(0.)));
353 }
354 return 0.;
355 }
@ driftTime
Definition HitInfo.h:43

◆ driftRadius()

double MuonR4::SpacePointCalibrator::driftRadius ( const Acts::CalibrationContext & cctx,
const CalibratedSpacePoint & spacePoint,
const double timeDelay ) const
finaloverride

Definition at line 648 of file SpacePointCalibrator.cxx.

650 {
651 if(spacePoint.type() == xAOD::UncalibMeasType::MdtDriftCircleType) {
652 const MuonCalib::MdtFullCalibData* calibConsts =
653 m_mdtCalibrationTool->getCalibConstants(*cctx.get<const EventContext*>(), spacePoint.spacePoint()->identify());
654 return calibConsts->rtRelation->rt()->radius(ActsTrk::timeToAthena(spacePoint.time() - timeDelay));
655 }
656 return 0.;
657 }

◆ driftVelocity() [1/2]

double MuonR4::SpacePointCalibrator::driftVelocity ( const Acts::CalibrationContext & cctx,
const CalibratedSpacePoint & spacePoint,
const double timeDelay ) const
finaloverride

Definition at line 659 of file SpacePointCalibrator.cxx.

661 {
662 if(spacePoint.type() == xAOD::UncalibMeasType::MdtDriftCircleType) {
663 const MuonCalib::MdtFullCalibData* calibConsts =
664 m_mdtCalibrationTool->getCalibConstants(*cctx.get<const EventContext*>(), spacePoint.spacePoint()->identify());
665 return ActsTrk::velocityToActs(calibConsts->rtRelation->rt()->driftVelocity(ActsTrk::timeToAthena(spacePoint.time() - timeDelay)));
666 }
667 return 0.;
668 }
constexpr double velocityToActs(const double athenaV)
Converts a velocity from Athena to Acts units.

◆ driftVelocity() [2/2]

double MuonR4::SpacePointCalibrator::driftVelocity ( const Acts::CalibrationContext & ctx,
const CalibratedSpacePoint & spacePoint ) const
finaloverride

Definition at line 337 of file SpacePointCalibrator.cxx.

338 {
339 if(spacePoint.type() == xAOD::UncalibMeasType::MdtDriftCircleType) {
340
341 const MuonCalib::MdtFullCalibData* calibConsts = m_mdtCalibrationTool->getCalibConstants(*ctx.get<const EventContext*>(), spacePoint.spacePoint()->identify());
342 const std::optional<double> driftTime = calibConsts->rtRelation->tr()->driftTime(spacePoint.driftRadius());
343 return ActsTrk::velocityToActs(calibConsts->rtRelation->rt()->driftVelocity(driftTime.value_or(0.)));
344 }
345 return 0.;
346 }

◆ getType()

SourceLinkType ActsTrk::detail::MeasurementCalibratorBase::getType ( const Acts::SourceLink & sl)
staticinherited

Returns the enumeration corresponding to the object type cached within the Acts::SourceLink.

The SourceLink must have been created by a MeasurementCalibrator to ensure that the underlying variant is cached. If the variant is a monostate, nTypes is returned

Parameters
slReference to the source link to unpack.

◆ initialize()

StatusCode MuonR4::SpacePointCalibrator::initialize ( )
finaloverride

Definition at line 43 of file SpacePointCalibrator.cxx.

43 {
44 ATH_CHECK(m_geoCtxKey.initialize());
45 ATH_CHECK(m_idHelperSvc.retrieve());
46 ATH_CHECK(m_mdtCalibrationTool.retrieve(EnableTool{m_idHelperSvc->hasMDT()}));
47 ATH_CHECK(m_nswCalibTool.retrieve(EnableTool{m_idHelperSvc->hasMM() || m_idHelperSvc->hasSTGC()}));
48 ATH_CHECK(detStore()->retrieve(m_detMgr));
49 return StatusCode::SUCCESS;
50 }
#define ATH_CHECK
Evaluate an expression and check for errors.
const MuonGMR4::MuonDetectorManager * m_detMgr

◆ pack()

template<Acts::PointerConcept Ptr_t>
Acts::SourceLink ActsTrk::detail::MeasurementCalibratorBase::pack ( const Ptr_t & measurement)
staticinherited

Pack the measurement type pointer to an Acts::SourceLink including the intermediate conversion into a SourceLink_t.

Nullptrs are converted to a std::monostate.

Parameters
measurementPointer to the measurement to transform into a SourceLInk

◆ setState()

template<std::size_t Dim, Acts::TrackStateProxyConcept proxy_t, typename pos_t, typename cov_t>
void ActsTrk::detail::MeasurementCalibratorBase::setState ( const ProjectorType projector,
const pos_t & locpos,
const cov_t & cov,
Acts::SourceLink link,
proxy_t & trackState ) const
inherited

Copy the local position & covariance into the Acts track state proxy.

Template Parameters
DimDimension of the measurement
trajectory_tData type of the track state proxy backend
pos_tData type of the [Dim x 1] position vector
cov_tData type of the [Dim x Dim] covariance matrix
Parameters
projectorProjector configuration of the measurement
locposCalibrated local postion
covCalibrated local covariance
linkSource link to associate with the state
trackStateRefrence to the track state proxy to write.

◆ stampSignsOnMeasurements()

void MuonR4::SpacePointCalibrator::stampSignsOnMeasurements ( const xAOD::MuonSegment & segment) const
finaloverride

Definition at line 637 of file SpacePointCalibrator.cxx.

637 {
638 const auto [segPos, segLine] = makeLine(localSegmentPars(segment));
639 const Segment* detSeg = MuonR4::detailedSegment(segment);
640 for (const auto& meas : detSeg->measurements()) {
642 dec_trackSign(*meas->spacePoint()->primaryMeasurement()) =
643 SeedingAux::strawSign(segPos, segLine, *meas);
644 }
645 }
646 }
Parameters localSegmentPars(const xAOD::MuonSegment &seg)
Returns the localSegPars decoration from a xAODMuon::Segment.
std::pair< Amg::Vector3D, Amg::Vector3D > makeLine(const Parameters &pars)
Returns the parsed parameters into an Eigen line parametrization.
const Segment * detailedSegment(const xAOD::MuonSegment &seg)
Helper function to navigate from the xAOD::MuonSegment to the MuonR4::Segment.

◆ unpackBase()

SourceLink_t ActsTrk::detail::MeasurementCalibratorBase::unpackBase ( const Acts::SourceLink & sl)
staticinherited

Unpack the SourceLink_t from the passed Acts source link.

Parameters
slReference to the source link to unpack.

◆ updateSigns()

void MuonR4::SpacePointCalibrator::updateSigns ( const Amg::Vector3D & trackPos,
const Amg::Vector3D & trackDir,
CalibSpacePointVec & hitsToCalib ) const
finaloverride

Definition at line 52 of file SpacePointCalibrator.cxx.

54 {
55 std::vector<int> signs = SeedingAux::strawSigns(trackPos, trackDir,
56 hitsToCalib);
57 for (const auto [spIdx, sp]: Acts::enumerate(hitsToCalib)) {
58 sp->setDriftRadius(sp->driftRadius() * signs[spIdx]);
59 }
60 }

Member Data Documentation

◆ m_clusterBuilderToolMM

ToolHandle<Muon::IMMClusterBuilderTool> MuonR4::SpacePointCalibrator::m_clusterBuilderToolMM {this, "MMClusterBuilder", ""}
private

Definition at line 144 of file SpacePointCalibrator.h.

144{this, "MMClusterBuilder", ""};

◆ m_detMgr

const MuonGMR4::MuonDetectorManager* MuonR4::SpacePointCalibrator::m_detMgr {nullptr}
private

Definition at line 146 of file SpacePointCalibrator.h.

146{nullptr};

◆ m_geoCtxKey

ActsTrk::GeoContextReadKey_t MuonR4::SpacePointCalibrator::m_geoCtxKey {this, "AlignmentKey", "ActsAlignment", "cond handle key"}
private

access to the ACTS geometry context

Definition at line 136 of file SpacePointCalibrator.h.

136{this, "AlignmentKey", "ActsAlignment", "cond handle key"};

◆ m_idHelperSvc

ServiceHandle<Muon::IMuonIdHelperSvc> MuonR4::SpacePointCalibrator::m_idHelperSvc {this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"}
private

Definition at line 138 of file SpacePointCalibrator.h.

138{this, "MuonIdHelperSvc", "Muon::MuonIdHelperSvc/MuonIdHelperSvc"};

◆ m_mdtCalibrationTool

ToolHandle<IMdtCalibrationTool> MuonR4::SpacePointCalibrator::m_mdtCalibrationTool {this, "MdtCalibrationTool", ""}
private

Definition at line 140 of file SpacePointCalibrator.h.

140{this, "MdtCalibrationTool", ""};

◆ m_MdtSignFromSegment

Gaudi::Property<bool> MuonR4::SpacePointCalibrator::m_MdtSignFromSegment
private
Initial value:
{this, "useSegmentSigns", true,
"Mdt drift signs are copied from the segment line instead from the track state"}

Definition at line 167 of file SpacePointCalibrator.h.

167 {this, "useSegmentSigns", true,
168 "Mdt drift signs are copied from the segment line instead from the track state"};

◆ m_muonPropSpeed

Gaudi::Property<double> MuonR4::SpacePointCalibrator::m_muonPropSpeed {this, "PropagationSpeed", 1./ Gaudi::Units::c_light }
private

Assumed propagation velocity of the muon through the detector.

Needs to be replaced by the proper time estimate once the calibrator is exposed to the Acts propagator

Definition at line 151 of file SpacePointCalibrator.h.

151{this, "PropagationSpeed", 1./ Gaudi::Units::c_light };

◆ m_nswCalibTool

ToolHandle<Muon::INSWCalibTool> MuonR4::SpacePointCalibrator::m_nswCalibTool {this, "NSWCalibTool", ""}
private

Definition at line 142 of file SpacePointCalibrator.h.

142{this, "NSWCalibTool", ""};

◆ m_rpcSignalVelocity

Gaudi::Property<double> MuonR4::SpacePointCalibrator::m_rpcSignalVelocity
private
Initial value:
{this, "rpcSignalVelocity", 0.5 * Gaudi::Units::c_light,
"Propagation speed of the signal inside the rpc strip"}

How fast does an electron signal travel along an rpc strip.

Definition at line 154 of file SpacePointCalibrator.h.

154 {this, "rpcSignalVelocity", 0.5 * Gaudi::Units::c_light,
155 "Propagation speed of the signal inside the rpc strip"};

◆ m_rpcTimeResolution

Gaudi::Property<double> MuonR4::SpacePointCalibrator::m_rpcTimeResolution
private
Initial value:
{this, "rpcTimeResolution", 0.6 * Gaudi::Units::nanosecond,
"Estimated time resolution of the strip readout"}

Definition at line 157 of file SpacePointCalibrator.h.

157 {this, "rpcTimeResolution", 0.6 * Gaudi::Units::nanosecond,
158 "Estimated time resolution of the strip readout"};

◆ m_useRpcTime

Gaudi::Property<bool> MuonR4::SpacePointCalibrator::m_useRpcTime {this, "useRpcTime", false}
private

Load the Rpc time on the track states for the track fit.

Definition at line 161 of file SpacePointCalibrator.h.

161{this, "useRpcTime", false};

◆ m_usesTgcTime

Gaudi::Property<bool> MuonR4::SpacePointCalibrator::m_usesTgcTime
private
Initial value:
{this, "usesTgcTime", false,
"Load the sTgc time on the track states for the fit"}

Definition at line 165 of file SpacePointCalibrator.h.

165 {this, "usesTgcTime", false,
166 "Load the sTgc time on the track states for the fit"};

◆ m_useTgcTime

Gaudi::Property<bool> MuonR4::SpacePointCalibrator::m_useTgcTime
private
Initial value:
{this, "useTgcTime", false,
"Load the Tgc BC-ID on the track states for the fit"}

Load the Tgc bunch crossing ID on the track states.

Definition at line 163 of file SpacePointCalibrator.h.

163 {this, "useTgcTime", false,
164 "Load the Tgc BC-ID on the track states for the fit"};

◆ s_boundSpaceIndices

std::array<Acts::BoundSubspaceIndices, 6> ActsTrk::detail::MeasurementCalibratorBase::s_boundSpaceIndices
staticconstexprprivateinherited
Initial value:
{
Acts::BoundSubspaceIndices{Acts::eBoundLoc0},
Acts::BoundSubspaceIndices{Acts::eBoundLoc1},
Acts::BoundSubspaceIndices{Acts::eBoundLoc0, Acts::eBoundLoc1},
Acts::BoundSubspaceIndices{Acts::eBoundLoc0, Acts::eBoundTime},
Acts::BoundSubspaceIndices{Acts::eBoundLoc1, Acts::eBoundTime},
Acts::BoundSubspaceIndices{Acts::eBoundLoc0, Acts::eBoundLoc1, Acts::eBoundTime}
}

Array to map the Projector types to the bound index configurations used by the ATLAS detector measurements.

Definition at line 97 of file MeasurementCalibratorBase.h.

97 {
98 Acts::BoundSubspaceIndices{Acts::eBoundLoc0}, // One dimenion without time
99 Acts::BoundSubspaceIndices{Acts::eBoundLoc1}, // Complementary one dimension without time
100 Acts::BoundSubspaceIndices{Acts::eBoundLoc0, Acts::eBoundLoc1},
101 Acts::BoundSubspaceIndices{Acts::eBoundLoc0, Acts::eBoundTime}, // One dimension with time
102 Acts::BoundSubspaceIndices{Acts::eBoundLoc1, Acts::eBoundTime}, // Complementary one dimension with time
103 Acts::BoundSubspaceIndices{Acts::eBoundLoc0, Acts::eBoundLoc1, Acts::eBoundTime}
104 };

The documentation for this class was generated from the following files: