Loading [MathJax]/extensions/tex2jax.js
 |
ATLAS Offline Software
|
Go to the documentation of this file.
27 const std::string& na,
31 declareInterface<IMdtDriftCircleOnTrackCreator>(
this);
32 declareInterface<IRIO_OnTrackCreator>(
this);
50 using Property = ToolSettings::Property;
53 calibSettings.isActive(Property::TofCorrection));
55 calibSettings.isActive(Property::PropCorrection));
57 calibSettings.isActive(Property::TempCorrection));
59 calibSettings.isActive(Property::MagFieldCorrection));
61 calibSettings.isActive(Property::SlewCorrection));
63 calibSettings.isActive(Property::BackgroundCorrection));
74 return StatusCode::FAILURE;
76 if (msgLevel(MSG::INFO)) {
78 ss <<
"Constructed default MuonDriftCircleErrorStrategy:";
109 ss <<
"Using Data Loose error tuning";
111 ss <<
"Using Data Tight error tuning";
121 ATH_MSG_ERROR(
"Detected bad default configuration, using Cosmic TOF without "
122 <<
"time of flight corrections does not work");
123 return StatusCode::FAILURE;
129 return StatusCode::FAILURE;
133 ATH_MSG_ERROR(
"This tool is too complicated to rely on defaults. Potential configuration issue.");
134 return StatusCode::FAILURE;
136 return StatusCode::SUCCESS;
142 const double t0Shift,
145 const double tTrack)
const {
147 const EventContext& ctx{Gaudi::Hive::currentContext()};
154 calibInput.setClosestApproach(GP);
155 if (GD) calibInput.setTrackDirection((*GD).unit(),
true);
161 ATH_MSG_VERBOSE(
" running in ATLTIME mode, tof: " << calibInput.timeOfFlight());
166 calibInput.setTimeOfFlight(0);
167 ATH_MSG_VERBOSE(
"running in NO_CORRECTIONS mode, tof: " << calibInput.timeOfFlight());
174 ATH_MSG_VERBOSE(
" running in COSMICS_TRIGGERTIME mode, triggerOffset: "
175 << calibInput.triggerTime());
178 calibInput.setTimeOfFlight(
timeOfFlight(calibInput.closestApproach(),
beta, tTrack, t0Shift));
180 << calibInput.timeOfFlight() <<
" tTrack: " << tTrack
181 <<
" t0Shift: " << t0Shift
186 ATH_MSG_WARNING(
"No valid mode selected, cannot apply tof correction");
187 calibInput.setTimeOfFlight(0);
196 if (!posOnIdealWire) {
197 ATH_MSG_WARNING(__FILE__<<
":"<<__LINE__<<
" globalToLocal() failed for ideal surface");
200 posOnWire = std::move(*posOnIdealWire);
202 double positionAlongWire = posOnWire[
Trk::locZ];
217 std::unique_ptr<MdtDriftCircleOnTrack> rot{};
223 std::optional<Amg::Vector2D>
pos = surf.globalToLocal(GP, calibInput.trackDirection());
227 ATH_MSG_WARNING(
"Unexpected globalToLocal failure, cannot create MDT ROT ");
234 rot = std::make_unique<MdtDriftCircleOnTrack>(&mdtPrd,
235 std::move(calibOutput.
locPars),
236 std::move(calibOutput.
locErr),
239 calibInput.trackDirection(),
249 rot = std::make_unique<MdtDriftCircleOnTrack>(&mdtPrd,
250 std::move(calibOutput.
locPars),
251 std::move(calibOutput.
locErr),
259 rot = std::make_unique<MdtDriftCircleOnTrack>(&mdtPrd,
260 std::move(calibOutput.
locPars),
261 std::move(calibOutput.
locErr),
274 return rot.release();
301 ATH_MSG_VERBOSE(
"getLocalMeasurement "<<calibInput<<
" with m_doMdt=" <<
m_doMdt <<
" and " << myStrategy);
311 ATH_MSG_VERBOSE(
"getLocalMeasurement() - Calibrated output "<<calibOutput);
313 radius = calibOutput.driftRadius();
318 std::optional<Amg::Vector2D> myLocalPosition = surf.
globalToLocal(gpos, gdir);
319 if (myLocalPosition) {
322 ATH_MSG_WARNING(__FILE__<<
":"<<__LINE__<<
" ErrorAtPredictedPosition failed because local position "<<
323 "transformation didn't succeed. Using measured radius instead.");
345 sigmaR = calibOutput.driftRadiusUncert();
348 <<
" SigmaR = " << sigmaR);
349 double sigmaR2 = 0.0;
353 ATH_MSG_DEBUG(
"After scaling etc:\t Moore sigmaR2 = " << sigmaR2);
356 ATH_MSG_DEBUG(
"After scaling etc:\t Muon ErrorStrategy sigmaR2 = " << sigmaR2);
366 newLocalCov(0, 0) = sigmaR2;
378 const double tTrack)
const {
386 const EventContext& )
const {
389 <<
" Trk::PrepRawData not a MdtPrepData!! No rot created ");
421 ATH_MSG_WARNING(
"updateError: ErrorAtPredictedPosition is not yet supported!");
429 <<
" for radius=" <<
radius);
432 const EventContext& ctx{Gaudi::Hive::currentContext()};
436 if (sigmaR < 0.0001 || sigmaR * sigmaR < 0.0001) {
439 <<
" reso " << sigmaR <<
" sigma2 "
440 << sigmaR * sigmaR <<
" drift time " <<
t
448 double sigmaR2 = 0.0;
454 ATH_MSG_DEBUG(
"After scaling etc:\t Muon ErrorStrategy sigmaR2 = " << sigmaR2);
456 std::unique_ptr<MdtDriftCircleOnTrack> rot{DCT.
clone()};
458 rot->setErrorStrategy(myStrategy);
465 return rot.release();
471 const double tShift)
const {
478 return 0.23 *
std::exp(-std::abs(
r) / 6.06) + 0.0362;
506 return sigmaR2 + 0.005;
509 return 4 * sigmaR2 + 0.16;
512 return sigmaR2 + 0.005;
521 return 1.44 * sigmaR2 + 1.44;
525 return 1.44 * sigmaR2 + 0.16;
526 return 1.44 * sigmaR2 + 1.;
531 return 1.44 * sigmaR2 + 1.;
533 return 4 * sigmaR2 + 25;
536 return 1.44 * sigmaR2 + 1.;
542 return 4 * sigmaR2 + 49.;
545 return 4 * sigmaR2 + 4.;
552 return 2.25 * sigmaR2 + 0.09;
570 return 1.44 * sigmaR2 + fixedTerm;
589 return sigmaR2 + 0.005;
593 return 4 * sigmaR2 + 0.16;
596 return sigmaR2 + 0.005;
606 return 1.44 * sigmaR2 + 4;
609 return 1.44 * sigmaR2 + 0.04;
614 return 1.44 * sigmaR2 + 1.;
615 return 4 * sigmaR2 + 25;
619 return 1.44 * sigmaR2 + 0.25;
626 return 1.44 * sigmaR2 + 0.25;
629 return 1.44 * sigmaR2 + 0.04;
636 return 4 * sigmaR2 + 4.;
639 return 4 * sigmaR2 + 4.;
646 return 2.25 * sigmaR2 + 0.09;
665 return 1.44 * sigmaR2 + fixedTerm;
684 return sigmaR2 + 0.005;
687 return 4 * sigmaR2 + 0.16;
690 return sigmaR2 + 0.005;
699 return 1.44 * sigmaR2 + 0.04;
703 return 1.21 * sigmaR2 + 0.01;
705 return 1.21 * sigmaR2 + 0.01;
710 return 1.44 * sigmaR2 + 1.;
712 return 4 * sigmaR2 + 1.;
717 return 1.21 * sigmaR2 + 0.25;
724 return 1.21 * sigmaR2 + 0.25;
730 return 1.21 * sigmaR2 + 25.;
733 return 1.21 * sigmaR2 + 0.04;
739 return 4 * sigmaR2 + 4.;
742 return 4 * sigmaR2 + 4.;
749 return 2.25 * sigmaR2 + 0.09;
754 double fixedTerm = 0.01;
767 return 1.21 * sigmaR2 + fixedTerm;
796 return sigmaR2 + 0.005;
799 return 4 * sigmaR2 + 0.16;
802 return sigmaR2 + 0.005;
808 return 1.21 * sigmaR2;
815 return 2.25 * sigmaR2;
818 return 1.21 * sigmaR2;
double mooreErrorStrategyTight(const MuonDriftCircleErrorStrategy &myStrategy, double sigmaR, const Identifier &id) const
static double parametrisedSigma(double r)
double mooreErrorStrategy(const MuonDriftCircleErrorStrategy &myStrategy, double sigmaR, const Identifier &id) const
Trk::LocalParameters locPars
Gaudi::Property< bool > m_errorAtPredictedPosition
Add a term to the error to account for very poorly aligned stations.
@ COSMICS_TRIGGERTIME
case for normal cosmic data with rpc trigger or simulation including TOF.
Eigen::Matrix< double, Eigen::Dynamic, Eigen::Dynamic > MatrixX
Dynamic Matrix - dynamic allocation.
void setCalibWindow(unsigned long)
Only the first nCalibWindowBits bits will be stored!
Gaudi::Property< bool > m_stationError
Add a special error to account for the T0 refit.
DriftCircleStatus
Enumerates the 'status' of the wire on which the tracks passed (based on the TRT_Side enum,...
double innerTubeRadius() const
Returns the inner tube radius excluding the aluminium walls.
Eigen::Matrix< double, 2, 1 > Vector2D
const Amg::MatrixX & localCovariance() const
return const ref to the error matrix
Gaudi::Property< bool > m_doMdt
Process MDT ROTs.
Gaudi::Property< double > m_globalToLocalTolerance
virtual bool type(PrepRawDataType type) const =0
Interface method checking the type.
@ ATLTIME
normal time of flight corrections assuming IP + light speed to be used for simulated data and collisi...
virtual const MuonGM::MdtReadoutElement * detectorElement() const override final
Returns the detector element, assoicated with the PRD of this class.
#define ATH_MSG_VERBOSE(x)
@ NO_CORRECTIONS
special case for cosmics taken with scintilator trigger which is read out so the offset with respect ...
double muonErrorStrategy(const MuonDriftCircleErrorStrategy &myStrategy, double sigmaR, const Identifier &id) const
MdtDriftCircleOnTrackCreator(const std::string &, const std::string &, const IInterface *)
NRpcCablingAlg reads raw condition data and writes derived condition data to the condition store.
virtual void updateSign(MdtDriftCircleOnTrack &rot, const Trk::DriftCircleSide si) const override final
Update of the sign of the drift radius.
Support class for PropertyMgr.
MdtDriftCircleOnTrack * MdtRotPtr
@ PropCorrection
Propagation correction was applied in calibration.
@ TempCorrection
Temperature correction was applied in calibration.
double driftTime() const
Returns the value of the drift time used to obtain the drift radius.
ToolHandle< IMdtCalibrationTool > m_mdtCalibrationTool
std::pair< double, ParamDefs > DefinedParameter
@ T0Refit
A special error was applied to account for the T0 refit (user defined via jobProperties)
@ UNDECIDED
sign of drift radius has not been determined
virtual bool globalToLocal(const Amg::Vector3D &glob, const Amg::Vector3D &mom, Amg::Vector2D &loc) const override final
Specified for StraightLineSurface: GlobalToLocal method without dynamic memory allocation This method...
MuonDriftCircleErrorStrategy m_errorStrategy
< Error strategy for created ROTs
@ SlewCorrection
Slewing correction was applied in calibration.
@ FixedError
A fixed error is given to this hit (user defined via jobProperties)
virtual StatusCode initialize() override final
Gaudi::Property< bool > m_looseErrors
@ TofCorrection
Time of flight correction was applied in calibration.
::StatusCode StatusCode
StatusCode definition for legacy code.
Gaudi::Property< bool > m_t0Refit
Use error strategy for segments by default.
double mooreErrorStrategyLoose(const MuonDriftCircleErrorStrategy &myStrategy, double sigmaR, const Identifier &id) const
Gaudi::Property< bool > m_doIndividualChamberReweights
toggle between MC and data alignment errors (to be removed in rel.
static constexpr double s_inverseSpeedOfLight
@ BackgroundCorrection
Background correction was applied in calibration.
virtual MdtDriftCircleOnTrack * clone() const override final
Pseudo-constructor, needed to avoid excessive RTTI.
@ NODRIFTTIME
drift time was not used - drift radius is 0.
double driftRadius() const
Returns the value of the drift radius.
@ Segment
Treating a segment or a track.
Trk::DriftCircleStatus m_status
information on the status of the Mdt measurement - see Trk::DriftCircleStatus for definitions
double mooreErrorStrategyMC(const MuonDriftCircleErrorStrategy &myStrategy, double sigmaR, const Identifier &id) const
@ ErrorAtPredictedPosition
@ MagFieldCorrection
Magnetic field correction was applied in calibration
const Amg::MatrixX & localCovariance() const
Interface method to get the localError.
@ DECIDED
sign of drift radius has been determined
Identifier identify() const
return the identifier
@ StationError
A term is added to account for misaligned.
Gaudi::Property< bool > m_doSegments
Deweight individual chambers.
double error(const Amg::MatrixX &mat, int index)
return diagonal error of the matrix caller should ensure the matrix is symmetric and the index is in ...
const Amg::Vector2D & localPosition() const
return the local position reference
Gaudi::Property< bool > m_useErrorParametrisation
Use the predicted track position to correct the Error.
This class represents the corrected MDT measurements, where the corrections include the effects of wi...
virtual void setLocalParameters(const Trk::LocalParameters &locPos)
Sets the local parameters.
CalibrationOutput getLocalMeasurement(const EventContext &ctx, const MdtPrepData &DC, const MdtCalibInput &calibInput, const MuonDriftCircleErrorStrategy &strategy) const
preform the mdt calibration
Class to represent measurements from the Monitored Drift Tubes.
Eigen::Matrix< double, 3, 1 > Vector3D
void setParameter(CreationParameter, bool value)
void setStrategy(Strategy)
Select the strategy to be used - only one can be set at a time.
const LocalParameters & localParameters() const
Interface method to get the LocalParameters.
double timeOfFlight(const Amg::Vector3D &pos, const double beta, const double tTrack, const double tShift) const
DriftCircleSide
Enumerates the 'side' of the wire on which the tracks passed (i.e.
@ ParameterisedErrors
Use parameterised errors.
Gaudi::Property< bool > m_isMC
toggle whether the time of flight is included in the t0 shifts
Amg::MatrixX m_localCovariance
Gaudi::Property< bool > m_wasConfigured
Gaudi::Property< bool > m_createTubeHits
Scale ROTs depending on local alignment (i.e.
virtual bool globalToLocal(const Amg::Vector3D &glob, const Amg::Vector3D &mom, Amg::Vector2D &loc) const =0
Specified by each surface type: GlobalToLocal method without dynamic memory allocation - boolean chec...
double getTriggerTime() const
currently returns 0.
Gaudi::Property< bool > m_applyToF
toggle between loose errors (initial before alignment) and tight after alignment
#define ATH_MSG_WARNING(x)
Identifier identify() const
return the identifier -extends MeasurementBase
virtual Trk::RIO_OnTrack * correct(const Trk::PrepRawData &prd, const Trk::TrackParameters &tp, const EventContext &) const override
Base class method for correct.
Gaudi::Property< int > m_timeCorrectionType
StIndex
enum to classify the different station layers in the muon spectrometer
@ LEFT
the drift radius is negative (see Trk::AtaStraightLine)
virtual MdtRotPtr createRIO_OnTrack(const MdtPrepData &prd, const Amg::Vector3D &globalPos, const Amg::Vector3D *gdir=nullptr, const double t0Shift=0., const MuonDriftCircleErrorStrategy *strategy=nullptr, const double beta=1, const double tTrack=1) const override final
Calibrate a MdtPrepData object.
Gaudi::Property< bool > m_scaleMdtCov
Fixed error (not tube radius)
MdtDriftCircleOnTrackCreator::CalibrationOutput CalibrationOutput
struct to hold output of calibration
bool creationParameter(CreationParameter) const
virtual MdtRotPtr updateError(const MdtDriftCircleOnTrack &DCT, const Trk::TrackParameters *pars=nullptr, const MuonDriftCircleErrorStrategy *strategy=nullptr) const override
Update error of a ROT without changing the drift radius.
Gaudi::Property< bool > m_doFixedError
Use parameterised errors.
Gaudi::Property< std::string > m_defaultStrategy
if set to true, the ROT creator create 'tube' hits with a local position of 0 and an error of tube ra...
Strategy strategy() const
ServiceHandle< Muon::IMuonIdHelperSvc > m_idHelperSvc