#include <DTLinearDriftFromDBAlgo.h>
Public Member Functions | |
bool | compute (const DTLayer *layer, const DTDigi &digi, LocalPoint &leftPoint, LocalPoint &rightPoint, LocalError &error) const override |
bool | compute (const DTLayer *layer, const DTRecHit1D &recHit1D, const float &angle, const GlobalPoint &globPos, DTRecHit1D &newHit1D) const override |
bool | compute (const DTLayer *layer, const DTRecHit1D &recHit1D, const float &angle, DTRecHit1D &newHit1D) const override |
DTLinearDriftFromDBAlgo (const edm::ParameterSet &config) | |
Constructor. More... | |
void | setES (const edm::EventSetup &setup) override |
Pass the Event Setup to the algo at each event. More... | |
~DTLinearDriftFromDBAlgo () override | |
Destructor. More... | |
Public Member Functions inherited from DTRecHitBaseAlgo | |
DTRecHitBaseAlgo (const edm::ParameterSet &config) | |
Constructor. More... | |
virtual edm::OwnVector< DTRecHit1DPair > | reconstruct (const DTLayer *layer, const DTLayerId &layerId, const DTDigiCollection::Range &digiRange) |
Build all hits in the range associated to the layerId, at the 1st step. More... | |
virtual | ~DTRecHitBaseAlgo () |
Destructor. More... | |
Private Member Functions | |
virtual bool | compute (const DTLayer *layer, const DTWireId &wireId, const float digiTime, const GlobalPoint &globPos, DTRecHit1D &newHit1D, int step) const |
virtual bool | compute (const DTLayer *layer, const DTWireId &wireId, const float digiTime, const GlobalPoint &globPos, LocalPoint &leftPoint, LocalPoint &rightPoint, LocalError &error, int step) const |
Private Attributes | |
const bool | debug |
const bool | doVdriftCorr |
const MagneticField * | field |
const float | maxTime |
const float | minTime |
const DTMtime * | mTimeMap |
int | nominalB |
const bool | stepTwoFromDigi |
const DTRecoConditions * | uncertMap |
bool | useUncertDB |
Additional Inherited Members | |
Protected Attributes inherited from DTRecHitBaseAlgo | |
std::unique_ptr< DTTTrigBaseSync > | theSync |
Concrete implementation of DTRecHitBaseAlgo. Compute drift distance using constant drift velocity read from database.
Definition at line 18 of file DTLinearDriftFromDBAlgo.h.
DTLinearDriftFromDBAlgo::DTLinearDriftFromDBAlgo | ( | const edm::ParameterSet & | config | ) |
|
override |
|
overridevirtual |
First step in computation of Left/Right hits from a Digi. The results are the local position (in DTLayer frame) of the Left and Right hit, and the error (which is common). Returns false on failure. The hit is assumed to be at the wire center.
Implements DTRecHitBaseAlgo.
Definition at line 72 of file DTLinearDriftFromDBAlgo.cc.
References relativeConstraints::error, phase1PixelTopology::layer, DTDigi::time(), and DTDigi::wire().
Referenced by compute().
|
overridevirtual |
Third (and final) step in hits position computation. Also the hit position along the wire is available and can be used to correct the drift time for particle TOF and propagation of signal along the wire. NOTE: Only position and error of the new hit are modified
Implements DTRecHitBaseAlgo.
Definition at line 109 of file DTLinearDriftFromDBAlgo.cc.
References compute(), DTRecHit1D::digiTime(), phase1PixelTopology::layer, and DTRecHit1D::wireId().
|
overridevirtual |
Second step in hit position computation. It is the same as first step since the angular information is not used NOTE: Only position and error of the new hit are modified
Implements DTRecHitBaseAlgo.
Definition at line 88 of file DTLinearDriftFromDBAlgo.cc.
References compute(), DTRecHit1D::digiTime(), phase1PixelTopology::layer, DTRecHit1D::localPosition(), DTRecHit1D::localPositionError(), DTRecHit1D::setPositionAndError(), stepTwoFromDigi, DTWireId::wire(), and DTRecHit1D::wireId().
|
privatevirtual |
Definition at line 200 of file DTLinearDriftFromDBAlgo.cc.
References compute(), relativeConstraints::error, Exception, phase1PixelTopology::layer, DTEnums::Left, DTRecHit1D::localPosition(), DTRecHit1D::lrSide(), DTEnums::Right, DTRecHit1D::setPositionAndError(), PV3DBase< T, PVType, FrameType >::x(), PV3DBase< T, PVType, FrameType >::y(), and PV3DBase< T, PVType, FrameType >::z().
|
privatevirtual |
cf. http://arxiv.org/PS_cache/arxiv/pdf/0911/0911.4895v2.pdf
Definition at line 118 of file DTLinearDriftFromDBAlgo.cc.
References funct::abs(), writedatasetfile::args, DTVelocityUnits::cm_per_ns, gather_cfg::cout, debug, doVdriftCorr, shallow::drift(), relativeConstraints::error, DTRecoConditions::get(), DTMtime::get(), DTLinearDriftAlgo_cfi::hitResolution, phase1PixelTopology::layer, maxTime, mTimeMap, nominalB, DTChamberId::station(), DTSuperLayerId::superLayer(), DTLayerId::superlayerId(), DTRecHitBaseAlgo::theSync, uncertMap, useUncertDB, DTChamberId::wheel(), DTWireId::wire(), PV3DBase< T, PVType, FrameType >::x(), PV3DBase< T, PVType, FrameType >::y(), and PV3DBase< T, PVType, FrameType >::z().
|
overridevirtual |
Pass the Event Setup to the algo at each event.
Implements DTRecHitBaseAlgo.
Definition at line 42 of file DTLinearDriftFromDBAlgo.cc.
References gather_cfg::cout, debug, field, get, volumeBasedMagneticField_160812_cfi::magfield, mTimeMap, nominalB, MagneticField::nominalValue(), singleTopDQM_cfi::setup, DTRecHitBaseAlgo::theSync, uncertMap, useUncertDB, DTRecoConditions::version(), and DTMtime::version().
|
private |
Definition at line 107 of file DTLinearDriftFromDBAlgo.h.
Referenced by compute(), runTauIdMVA.TauIDEmbedder::loadMVA_WPs_run2_2017(), runTauIdMVA.TauIDEmbedder::runTauID(), and setES().
|
private |
Definition at line 96 of file DTLinearDriftFromDBAlgo.h.
Referenced by compute().
|
private |
Definition at line 83 of file DTLinearDriftFromDBAlgo.h.
Referenced by setES().
|
private |
Definition at line 93 of file DTLinearDriftFromDBAlgo.h.
Referenced by compute().
|
private |
Definition at line 90 of file DTLinearDriftFromDBAlgo.h.
|
private |
Definition at line 80 of file DTLinearDriftFromDBAlgo.h.
|
private |
Definition at line 84 of file DTLinearDriftFromDBAlgo.h.
|
private |
Definition at line 100 of file DTLinearDriftFromDBAlgo.h.
Referenced by compute().
|
private |
Definition at line 87 of file DTLinearDriftFromDBAlgo.h.
|
private |
Definition at line 104 of file DTLinearDriftFromDBAlgo.h.