|
ATLAS Offline Software
|
Go to the documentation of this file.
28 const std::string& na,
32 declareInterface<IMdtDriftCircleOnTrackCreator>(
this);
33 declareInterface<IRIO_OnTrackCreator>(
this);
51 using Property = ToolSettings::Property;
54 calibSettings.isActive(Property::TofCorrection));
56 calibSettings.isActive(Property::PropCorrection));
58 calibSettings.isActive(Property::TempCorrection));
60 calibSettings.isActive(Property::MagFieldCorrection));
62 calibSettings.isActive(Property::SlewCorrection));
64 calibSettings.isActive(Property::BackgroundCorrection));
75 return StatusCode::FAILURE;
77 if (msgLevel(MSG::INFO)) {
79 ss <<
"Constructed default MuonDriftCircleErrorStrategy:";
110 ss <<
"Using Data Loose error tuning";
112 ss <<
"Using Data Tight error tuning";
122 ATH_MSG_ERROR(
"Detected bad default configuration, using Cosmic TOF without "
123 <<
"time of flight corrections does not work");
124 return StatusCode::FAILURE;
130 return StatusCode::FAILURE;
134 ATH_MSG_ERROR(
"This tool is too complicated to rely on defaults. Potential configuration issue.");
135 return StatusCode::FAILURE;
137 return StatusCode::SUCCESS;
143 const double t0Shift,
146 const double tTrack)
const {
148 const EventContext& ctx{Gaudi::Hive::currentContext()};
155 calibInput.setClosestApproach(GP);
156 if (GD) calibInput.setTrackDirection((*GD).unit());
162 ATH_MSG_VERBOSE(
" running in ATLTIME mode, tof: " << calibInput.timeOfFlight());
167 calibInput.setTimeOfFlight(0);
168 ATH_MSG_VERBOSE(
"running in NO_CORRECTIONS mode, tof: " << calibInput.timeOfFlight());
175 ATH_MSG_VERBOSE(
" running in COSMICS_TRIGGERTIME mode, triggerOffset: "
176 << calibInput.triggerTime());
179 calibInput.setTimeOfFlight(
timeOfFlight(calibInput.closestApproach(),
beta, tTrack, t0Shift));
181 << calibInput.timeOfFlight() <<
" tTrack: " << tTrack
182 <<
" t0Shift: " << t0Shift
187 ATH_MSG_WARNING(
"No valid mode selected, cannot apply tof correction");
188 calibInput.setTimeOfFlight(0);
197 if (!posOnIdealWire) {
198 ATH_MSG_WARNING(__FILE__<<
":"<<__LINE__<<
" globalToLocal() failed for ideal surface");
201 posOnWire = std::move(*posOnIdealWire);
203 double positionAlongWire = posOnWire[
Trk::locZ];
218 std::unique_ptr<MdtDriftCircleOnTrack> rot{};
224 std::optional<Amg::Vector2D>
pos = surf.globalToLocal(GP, calibInput.trackDirection());
228 ATH_MSG_WARNING(
"Unexpected globalToLocal failure, cannot create MDT ROT ");
235 rot = std::make_unique<MdtDriftCircleOnTrack>(&mdtPrd,
236 std::move(calibOutput.
locPars),
237 std::move(calibOutput.
locErr),
240 calibInput.trackDirection(),
250 rot = std::make_unique<MdtDriftCircleOnTrack>(&mdtPrd,
251 std::move(calibOutput.
locPars),
252 std::move(calibOutput.
locErr),
260 rot = std::make_unique<MdtDriftCircleOnTrack>(&mdtPrd,
261 std::move(calibOutput.
locPars),
262 std::move(calibOutput.
locErr),
275 return rot.release();
302 ATH_MSG_VERBOSE(
"getLocalMeasurement "<<calibInput<<
" with m_doMdt=" <<
m_doMdt <<
" and " << myStrategy);
312 ATH_MSG_VERBOSE(
"getLocalMeasurement() - Calibrated output "<<calibOutput);
314 radius = calibOutput.driftRadius();
319 std::optional<Amg::Vector2D> myLocalPosition = surf.
globalToLocal(gpos, gdir);
320 if (myLocalPosition) {
323 ATH_MSG_WARNING(__FILE__<<
":"<<__LINE__<<
" ErrorAtPredictedPosition failed because local position "<<
324 "transformation didn't succeed. Using measured radius instead.");
346 sigmaR = calibOutput.driftRadiusUncert();
349 <<
" SigmaR = " << sigmaR);
350 double sigmaR2 = 0.0;
354 ATH_MSG_DEBUG(
"After scaling etc:\t Moore sigmaR2 = " << sigmaR2);
357 ATH_MSG_DEBUG(
"After scaling etc:\t Muon ErrorStrategy sigmaR2 = " << sigmaR2);
367 newLocalCov(0, 0) = sigmaR2;
379 const double tTrack)
const {
387 const EventContext& )
const {
390 <<
" Trk::PrepRawData not a MdtPrepData!! No rot created ");
422 ATH_MSG_WARNING(
"updateError: ErrorAtPredictedPosition is not yet supported!");
430 <<
" for radius=" <<
radius);
433 const EventContext& ctx{Gaudi::Hive::currentContext()};
437 if (sigmaR < 0.0001 || sigmaR * sigmaR < 0.0001) {
440 <<
" reso " << sigmaR <<
" sigma2 "
441 << sigmaR * sigmaR <<
" drift time " <<
t
449 double sigmaR2 = 0.0;
455 ATH_MSG_DEBUG(
"After scaling etc:\t Muon ErrorStrategy sigmaR2 = " << sigmaR2);
457 std::unique_ptr<MdtDriftCircleOnTrack> rot{DCT.
clone()};
459 rot->setErrorStrategy(myStrategy);
466 return rot.release();
472 const double tShift)
const {
479 return 0.23 *
std::exp(-std::abs(
r) / 6.06) + 0.0362;
507 return sigmaR2 + 0.005;
510 return 4 * sigmaR2 + 0.16;
513 return sigmaR2 + 0.005;
522 return 1.44 * sigmaR2 + 1.44;
526 return 1.44 * sigmaR2 + 0.16;
527 return 1.44 * sigmaR2 + 1.;
532 return 1.44 * sigmaR2 + 1.;
534 return 4 * sigmaR2 + 25;
537 return 1.44 * sigmaR2 + 1.;
543 return 4 * sigmaR2 + 49.;
546 return 4 * sigmaR2 + 4.;
553 return 2.25 * sigmaR2 + 0.09;
571 return 1.44 * sigmaR2 + fixedTerm;
590 return sigmaR2 + 0.005;
594 return 4 * sigmaR2 + 0.16;
597 return sigmaR2 + 0.005;
607 return 1.44 * sigmaR2 + 4;
610 return 1.44 * sigmaR2 + 0.04;
615 return 1.44 * sigmaR2 + 1.;
616 return 4 * sigmaR2 + 25;
620 return 1.44 * sigmaR2 + 0.25;
627 return 1.44 * sigmaR2 + 0.25;
630 return 1.44 * sigmaR2 + 0.04;
637 return 4 * sigmaR2 + 4.;
640 return 4 * sigmaR2 + 4.;
647 return 2.25 * sigmaR2 + 0.09;
666 return 1.44 * sigmaR2 + fixedTerm;
685 return sigmaR2 + 0.005;
688 return 4 * sigmaR2 + 0.16;
691 return sigmaR2 + 0.005;
700 return 1.44 * sigmaR2 + 0.04;
704 return 1.21 * sigmaR2 + 0.01;
706 return 1.21 * sigmaR2 + 0.01;
711 return 1.44 * sigmaR2 + 1.;
713 return 4 * sigmaR2 + 1.;
718 return 1.21 * sigmaR2 + 0.25;
725 return 1.21 * sigmaR2 + 0.25;
731 return 1.21 * sigmaR2 + 25.;
734 return 1.21 * sigmaR2 + 0.04;
740 return 4 * sigmaR2 + 4.;
743 return 4 * sigmaR2 + 4.;
750 return 2.25 * sigmaR2 + 0.09;
755 double fixedTerm = 0.01;
768 return 1.21 * sigmaR2 + fixedTerm;
797 return sigmaR2 + 0.005;
800 return 4 * sigmaR2 + 0.16;
803 return sigmaR2 + 0.005;
809 return 1.21 * sigmaR2;
816 return 2.25 * sigmaR2;
819 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