CMS 3D CMS Logo

DTLinearDriftAlgo.cc
Go to the documentation of this file.
1 /*
2  * See header file for a description of this class.
3  *
4  * \author G. Cerminara - INFN Torino
5  */
6 
14 
15 using namespace std;
16 using namespace edm;
17 
19  DTRecHitBaseAlgo(config),
20  // Get the Drift Velocity from parameter set.
21  vDrift(config.getParameter<double>("driftVelocity")), // FIXME: Default was 0.00543 cm/ns
22  hitResolution(config.getParameter<double>("hitResolution")), // FIXME: Default is
23  // vDriftMB1W1(config.getParameter<double>("driftVelocityMB1W1")), // FIXME: Default was 0.00543 cm/ns
24  minTime(config.getParameter<double>("minTime")), // FIXME: Default was -3 ns
25  maxTime(config.getParameter<double>("maxTime")), // FIXME: Default was 415 ns
26  // Set verbose output
27  debug(config.getUntrackedParameter<bool>("debug"))
28  {}
29 
30 
31 
33 
34 
35 
37  theSync->setES(setup);
38 }
39 
40 
41 
42 // First Step
44  const DTDigi& digi,
45  LocalPoint& leftPoint,
46  LocalPoint& rightPoint,
47  LocalError& error) const {
48  // Get the wireId
49  DTLayerId layerId = layer->id();
50  const DTWireId wireId(layerId, digi.wire());
51 
52  // Get Wire position
53  if(!layer->specificTopology().isWireValid(digi.wire())) return false;
54  LocalPoint locWirePos(layer->specificTopology().wirePosition(digi.wire()), 0, 0);
55  const GlobalPoint globWirePos = layer->toGlobal(locWirePos);
56 
57  return compute(layer, wireId, digi.time(), globWirePos, leftPoint, rightPoint, error, 1);
58 }
59 
60 
61 
62 // Second step: the same as 1st step
64  const DTRecHit1D& recHit1D,
65  const float& angle,
66  DTRecHit1D& newHit1D) const {
67  newHit1D.setPositionAndError(recHit1D.localPosition(), recHit1D.localPositionError());
68  return true;
69 }
70 
71 
72 
73 // Third step.
75  const DTRecHit1D& recHit1D,
76  const float& angle,
77  const GlobalPoint& globPos,
78  DTRecHit1D& newHit1D) const {
79  return compute(layer, recHit1D.wireId(), recHit1D.digiTime(), globPos, newHit1D, 3);
80 }
81 
82 
83 
84 // Do the actual work.
86  const DTWireId& wireId,
87  const float digiTime,
88  const GlobalPoint& globPos,
89  LocalPoint& leftPoint,
90  LocalPoint& rightPoint,
92  int step) const {
93  // Subtract the offset to the digi time accordingly to the DTTTrigBaseSync concrete instance
94  float driftTime = digiTime - theSync->offset(layer, wireId, globPos);
95 
96  // check for out-of-time
97  if (driftTime < minTime || driftTime > maxTime) {
98  if (debug) cout << "[DTLinearDriftAlgo]*** Drift time out of window for in-time hits "
99  << driftTime << endl;
100 
101  if(step == 1) { //FIXME: protection against failure at 2nd and 3rd steps, must be checked!!!
102  // Hits are interpreted as coming from out-of-time pile-up and recHit
103  // is ignored.
104  return false;
105  }
106  }
107 
108  // Small negative times interpreted as hits close to the wire.
109  if (driftTime<0.) driftTime=0;
110 
111  // Compute the drift distance
112  // SL 21-Dec-2006: Use specific Drift for MB1W1 (non fluxed chamber)
113  float vd=vDrift;
114  // if (wireId.wheel()==1 && wireId.station()==1) {
115  // vd=vDriftMB1W1;
116  // //cout << "Using Vd " << vd<< endl;
117  // }
118 
119  float drift = driftTime * vd;
120 
121  // Get Wire position
122  if(!layer->specificTopology().isWireValid(wireId.wire())) return false;
123  LocalPoint locWirePos(layer->specificTopology().wirePosition(wireId.wire()), 0, 0);
124  //Build the two possible points and the error on the position
125  leftPoint = LocalPoint(locWirePos.x()-drift,
126  locWirePos.y(),
127  locWirePos.z());
128  rightPoint = LocalPoint(locWirePos.x()+drift,
129  locWirePos.y(),
130  locWirePos.z());
131  error = LocalError(hitResolution*hitResolution,0.,0.);
132 
133 
134  if(debug) {
135  cout << "[DTLinearDriftAlgo] Compute drift distance, for digi at wire: " << wireId << endl
136  << " Step: " << step << endl
137  << " Digi time: " << digiTime << endl
138  << " Drift time: " << driftTime << endl
139  << " Drift distance: " << drift << endl
140  << " Hit Resolution: " << hitResolution << endl
141  << " Left point: " << leftPoint << endl
142  << " Right point: " << rightPoint << endl
143  << " Error: " << error << endl;
144  }
145 
146  return true;
147 
148 }
149 
150 
151 // Interface to the method which does the actual work suited for 2nd and 3rd steps
153  const DTWireId& wireId,
154  const float digiTime,
155  const GlobalPoint& globPos,
156  DTRecHit1D& newHit1D,
157  int step) const {
158  LocalPoint leftPoint;
159  LocalPoint rightPoint;
161 
162  if(compute(layer, wireId, digiTime, globPos, leftPoint, rightPoint, error, step)) {
163  // Set the position and the error of the rechit which is being updated
164  switch(newHit1D.lrSide()) {
165 
166  case DTEnums::Left:
167  {
168  // Keep the original y position of newHit1D: for step==3, it's the
169  // position along the wire. Needed for rotation alignment
170  LocalPoint leftPoint3D(leftPoint.x(), newHit1D.localPosition().y(), leftPoint.z());
171  newHit1D.setPositionAndError(leftPoint3D, error);
172  break;
173  }
174 
175  case DTEnums::Right:
176  {
177  // as above: 3d position
178  LocalPoint rightPoint3D(rightPoint.x(), newHit1D.localPosition().y(), rightPoint.z());
179  newHit1D.setPositionAndError(rightPoint3D, error);
180  break;
181  }
182 
183  default:
184  throw cms::Exception("InvalidDTCellSide") << "[DTLinearDriftAlgo] Compute at Step "
185  << step << ", Hit side "
186  << newHit1D.lrSide()
187  << " is invalid!" << endl;
188  return false;
189  }
190 
191  return true;
192  }else {
193  return false;
194  }
195 }
float wirePosition(int wireNumber) const
Returns the x position in the layer of a given wire number.
Definition: DTTopology.cc:86
DTLayerId id() const
Return the DetId of this SL.
Definition: DTLayer.cc:46
GlobalPoint toGlobal(const Local2DPoint &lp) const
Conversion to the global R.F. from the R.F. of the GeomDet.
Definition: GeomDet.h:54
double offset(const DTLayer *layer, const DTWireId &wireId, const GlobalPoint &globalPos)
LocalVector drift(const StripGeomDetUnit *, const MagneticField &, const SiStripLorentzAngle &)
Definition: ShallowTools.cc:38
T y() const
Definition: PV3DBase.h:63
def setup(process, global_tag, zero_tesla=False)
Definition: GeneralSetup.py:1
Definition: config.py:1
virtual void setES(const edm::EventSetup &setup)
Pass the Event Setup to the algo at each event.
int wire() const
Return wire number.
Definition: DTDigi.cc:67
virtual void setES(const edm::EventSetup &setup)=0
Pass the Event Setup to the synchronization module at each event.
const DTTopology & specificTopology() const
Definition: DTLayer.cc:42
double time() const
Get time in ns.
Definition: DTDigi.cc:63
std::vector< DeviationSensor2D * > vd
T z() const
Definition: PV3DBase.h:64
float digiTime() const
Return the time (ns) of the digi used to build the rechit.
Definition: DTRecHit1D.h:113
Definition: DTDigi.h:17
virtual LocalError localPositionError() const
Return the 3-dimensional error on the local position.
Definition: DTRecHit1D.h:66
DTTTrigBaseSync * theSync
virtual LocalPoint localPosition() const
Return the 3-dimensional local position.
Definition: DTRecHit1D.h:60
int wire() const
Return the wire number.
Definition: DTWireId.h:56
const float hitResolution
#define debug
Definition: HDRShower.cc:19
DTLinearDriftAlgo(const edm::ParameterSet &config)
Constructor.
virtual bool compute(const DTLayer *layer, const DTDigi &digi, LocalPoint &leftPoint, LocalPoint &rightPoint, LocalError &error) const
virtual ~DTLinearDriftAlgo()
Destructor.
HLT enums.
bool isWireValid(const int wireNumber) const
Definition: DTTopology.h:65
Local3DPoint LocalPoint
Definition: LocalPoint.h:11
step
void setPositionAndError(LocalPoint pos, LocalError err)
Set the local position and its error.
Definition: DTRecHit1D.h:100
T x() const
Definition: PV3DBase.h:62
DTEnums::DTCellSide lrSide() const
The side of the cell.
Definition: DTRecHit1D.h:82
T angle(T x1, T y1, T z1, T x2, T y2, T z2)
Definition: angle.h:11
DTWireId wireId() const
Return the wireId.
Definition: DTRecHit1D.h:107