CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Classes | Public Member Functions | Private Member Functions | Private Attributes
L1TwinMux::PrimitiveCombiner Class Reference

#include <PrimitiveCombiner.h>

Classes

struct  resolutions
 a struct useful for resulution info sharing More...
 
struct  results
 a struct for internal usage: store results More...
 

Public Member Functions

void addDt (const TriggerPrimitive &prim)
 feed the combiner with the available primitives More...
 
void addDtHI (const TriggerPrimitive &prim)
 
void addDtHO (const TriggerPrimitive &prim)
 
void addRpcIn (const TriggerPrimitive &prim)
 
void addRpcOut (const TriggerPrimitive &prim)
 
int bendingAngle () const
 
int bendingResol () const
 
int bx () const
 output result variables More...
 
void combine ()
 do combine the primitives More...
 
int getUncorrelatedQuality16 () const
 
int getUncorrelatedQuality7 () const
 FIXME END. More...
 
bool isValid () const
 valid if we have at least: 1 rpc; 1 dt + 1 any More...
 
float phiBCombined (const float &xDt, const float &zDt, const float &xRpc, const float &zRpc)
 FIXME : Calculates new phiBending, check how to use. More...
 
float phiBCombinedResol (const float &resol_xDt, const float &resol_xRpc, const float &zDt, const float &zRpc)
 FIXME END. More...
 
 PrimitiveCombiner (const resolutions &res, edm::ESHandle< DTGeometry > &muonGeom)
 
int radialAngle () const
 

Private Member Functions

results combineDt (const TriggerPrimitive *dt, const TriggerPrimitive *rpc)
 Calculates new phiBending, check how to use weights. More...
 
results combineDtRpc (const TriggerPrimitive *dt, const TriggerPrimitive *rpc)
 Calculates new phiBending, check how to use weights. More...
 
results combineRpcRpc (const TriggerPrimitive *rpc1, const TriggerPrimitive *rpc2)
 Calculates new phiBending, check how to use weights. More...
 
results dummyCombineDt (const TriggerPrimitive *dt)
 
int radialAngleFromGlobalPhi (const TriggerPrimitive *rpc)
 

Private Attributes

int _bendingAngle
 
int _bendingResol
 
int _bx
 
const TriggerPrimitive_dtHI
 
const TriggerPrimitive_dtHO
 
edm::ESHandle< DTGeometry_muonGeom
 
int _radialAngle
 
resolutions _resol
 
const TriggerPrimitive_rpcIn
 
const TriggerPrimitive_rpcOut
 

Detailed Description

Definition at line 25 of file PrimitiveCombiner.h.

Constructor & Destructor Documentation

PrimitiveCombiner::PrimitiveCombiner ( const resolutions res,
edm::ESHandle< DTGeometry > &  muonGeom 
)
explicit

Definition at line 19 of file PrimitivesCombiner.cc.

Member Function Documentation

void PrimitiveCombiner::addDt ( const TriggerPrimitive prim)

feed the combiner with the available primitives

Definition at line 28 of file PrimitivesCombiner.cc.

References addDtHI(), addDtHO(), Exception, L1TMuon::TriggerPrimitive::getDTData(), and L1TMuon::TriggerPrimitive::DTData::qualityCode.

Referenced by L1ITMuonBarrelPrimitiveProducer::produce().

29 {
30  int qualityCode = dt.getDTData().qualityCode;
31  switch ( qualityCode ) {
32  case 2 : addDtHO( dt ); break;
33  case 3 : addDtHI( dt ); break;
34  default :
35  throw cms::Exception("Invalid DT Quality")
36  << "This module can combine only HI to HO (quality2/3), provided : "
37  << qualityCode << std::endl;
38  }
39 
40 }
float dt
Definition: AMPTWrapper.h:126
void addDtHI(const TriggerPrimitive &prim)
void addDtHO(const TriggerPrimitive &prim)
void PrimitiveCombiner::addDtHI ( const TriggerPrimitive prim)

Definition at line 43 of file PrimitivesCombiner.cc.

References _dtHI, and Exception.

Referenced by addDt().

44 {
45  if ( _dtHI )
46  throw cms::Exception("Invalid DT Quality")
47  << "DT primitive with quality HI already provided"
48  << std::endl;
49 
50  _dtHI = &prim;
51 }
const TriggerPrimitive * _dtHI
void PrimitiveCombiner::addDtHO ( const TriggerPrimitive prim)

Definition at line 54 of file PrimitivesCombiner.cc.

References _dtHO, and Exception.

Referenced by addDt().

55 {
56  if ( _dtHO )
57  throw cms::Exception("Invalid DT Quality")
58  << "DT primitive with quality HO already provided"
59  << std::endl;
60 
61  _dtHO = &prim;
62 }
const TriggerPrimitive * _dtHO
void PrimitiveCombiner::addRpcIn ( const TriggerPrimitive prim)

Definition at line 65 of file PrimitivesCombiner.cc.

References _rpcIn.

Referenced by L1ITMuonBarrelPrimitiveProducer::produce().

66 {
67  _rpcIn = &prim;
68 }
const TriggerPrimitive * _rpcIn
void PrimitiveCombiner::addRpcOut ( const TriggerPrimitive prim)

Definition at line 71 of file PrimitivesCombiner.cc.

References _rpcOut.

Referenced by L1ITMuonBarrelPrimitiveProducer::produce().

72 {
73  _rpcOut = &prim;
74 }
const TriggerPrimitive * _rpcOut
int L1TwinMux::PrimitiveCombiner::bendingAngle ( ) const
inline
int L1TwinMux::PrimitiveCombiner::bendingResol ( ) const
inline

Definition at line 57 of file PrimitiveCombiner.h.

int L1TwinMux::PrimitiveCombiner::bx ( ) const
inline

output result variables

Definition at line 54 of file PrimitiveCombiner.h.

Referenced by L1ITMuonBarrelPrimitiveProducer::produce().

void PrimitiveCombiner::combine ( )

do combine the primitives

Definition at line 78 of file PrimitivesCombiner.cc.

References _bendingAngle, _bendingResol, _dtHI, _dtHO, _radialAngle, _rpcIn, _rpcOut, combineDt(), combineDtRpc(), combineRpcRpc(), L1TMuon::TriggerPrimitive::getDTData(), isValid(), L1TMuon::TriggerPrimitive::DTData::radialAngle, L1TwinMux::PrimitiveCombiner::results::radialAngle, radialAngleFromGlobalPhi(), and mathSSE::sqrt().

Referenced by L1ITMuonBarrelPrimitiveProducer::produce().

79 {
80  if ( !isValid() ) return;
81 
82  typedef PrimitiveCombiner::results localResult;
83  std::vector<localResult> localResults;
84 
85  _radialAngle = 0;
86  // inner and outer DT
87  if ( _dtHI && _dtHO ) {
88  localResults.push_back( combineDt( _dtHI, _dtHO ) );
89  _radialAngle = localResults.back().radialAngle;
90  }
91  // inner DT
92  else if ( _dtHI ) {
93  // if (!_dtHO) localResults.push_back(dummyCombineDt(_dtHI));
94  if ( _rpcIn ) {
95  localResults.push_back( combineDtRpc( _dtHI, _rpcIn ) );
97  }
98  if ( _rpcOut ) {
99  localResults.push_back( combineDtRpc( _dtHI, _rpcOut ) );
101  }
102  }
103  //outer DT
104  else if ( _dtHO ) {
105  // if (!_dtHI) localResults.push_back(dummyCombineDt(_dtHO));
106  if ( _rpcIn ) {
107  localResults.push_back( combineDtRpc( _dtHO, _rpcIn ) );
109  }
110  if ( _rpcOut ) {
111  localResults.push_back( combineDtRpc( _dtHO, _rpcOut ) );
113  }
114  }
115  // no DT
116  else if ( !_dtHI && !_dtHO ) {
117  if ( _rpcIn && _rpcOut ) {
118  results local = combineRpcRpc( _rpcIn, _rpcOut );
119  localResults.push_back( local );
120  _radialAngle = local.radialAngle;
121  //std::cout<<"Entered RPC-IN-OUT thing..."<<std::endl;
122  } else if ( _rpcIn ) {
123  //std::cout<<"Entered RPC-IN-ONLY thing..."<<std::endl;
125  _bendingAngle = -666;
126  return;
127  } else if ( _rpcOut ) {
128  //std::cout<<"Entered RPC-OUT-only thing..."<<std::endl;
130  _bendingAngle = -666;
131  return;
132  }
133  }
134  double weightSum = 0;
135  _bendingResol = 0;
136  _bendingAngle = 0;
137 
138  std::vector<localResult>::const_iterator it = localResults.begin();
139  std::vector<localResult>::const_iterator itend = localResults.end();
140  int kcount=0;
141  for ( ; it != itend; ++it ) {
142  //weightSum += it->bendingResol;
143  //_bendingAngle += it->bendingResol * it->bendingAngle;
144  kcount++;
145  //std::cout<<"combining result "<<kcount<<" with resolution "<<it->bendingResol<<std::endl;
146  weightSum += 1.0/(( it->bendingResol)*(it->bendingResol));
147  _bendingAngle += double(it->bendingAngle)/((it->bendingResol) * (it->bendingResol));
148  _bendingResol += it->bendingResol * it->bendingResol;
149  }
150 
151  _bendingAngle /= weightSum;
153 
154 }
const TriggerPrimitive * _rpcOut
const DTData getDTData() const
bool isValid() const
valid if we have at least: 1 rpc; 1 dt + 1 any
const TriggerPrimitive * _dtHI
const TriggerPrimitive * _rpcIn
a struct for internal usage: store results
T sqrt(T t)
Definition: SSEVec.h:18
tuple results
Definition: mps_update.py:44
results combineDtRpc(const TriggerPrimitive *dt, const TriggerPrimitive *rpc)
Calculates new phiBending, check how to use weights.
results combineRpcRpc(const TriggerPrimitive *rpc1, const TriggerPrimitive *rpc2)
Calculates new phiBending, check how to use weights.
int radialAngleFromGlobalPhi(const TriggerPrimitive *rpc)
const TriggerPrimitive * _dtHO
results combineDt(const TriggerPrimitive *dt, const TriggerPrimitive *rpc)
Calculates new phiBending, check how to use weights.
PrimitiveCombiner::results PrimitiveCombiner::combineDt ( const TriggerPrimitive dt,
const TriggerPrimitive rpc 
)
private

Calculates new phiBending, check how to use weights.

PhiB calculation : atan( (x2-x1)/(z2-z1) is the bending angle needs to be corrected w.r.t.the direction phi (4096 scale) and ported to 512 scale

positive chambers

Definition at line 173 of file PrimitivesCombiner.cc.

References _muonGeom, _resol, L1TwinMux::PrimitiveCombiner::results::bendingAngle, L1TwinMux::PrimitiveCombiner::results::bendingResol, L1TMuon::TriggerPrimitive::detId(), L1TMuon::TriggerPrimitive::getCMSGlobalPoint(), L1TMuon::TriggerPrimitive::getDTData(), phiBCombined(), phiBCombinedResol(), L1TMuon::TriggerPrimitive::DTData::radialAngle, L1TwinMux::PrimitiveCombiner::results::radialAngle, L1TMuon::TriggerPrimitive::DTData::sector, GeomDet::toLocal(), L1TMuon::TriggerPrimitive::DTData::wheel, PV3DBase< T, PVType, FrameType >::x(), L1TwinMux::PrimitiveCombiner::resolutions::xDt, and PV3DBase< T, PVType, FrameType >::z().

Referenced by combine().

175 {
176 
177  const DTChamber* chamb1 = _muonGeom->chamber( dt1->detId<DTChamberId>() );
178  LocalPoint point1 = chamb1->toLocal( dt1->getCMSGlobalPoint() );
179 
180  const DTChamber* chamb2 = _muonGeom->chamber( dt2->detId<DTChamberId>() );
181  LocalPoint point2 = chamb2->toLocal( dt2->getCMSGlobalPoint() );
182 
183  results localResult;
184  localResult.radialAngle = 0.5 * ( dt1->getDTData().radialAngle + dt2->getDTData().radialAngle );
185 
190  if ( ( dt1->getDTData().wheel > 0 ) ||
191  ( ( dt1->getDTData().wheel == 0 ) &&
192  !( dt1->getDTData().sector == 0 || dt1->getDTData().sector == 3
193  || dt1->getDTData().sector == 4 || dt1->getDTData().sector == 7
194  || dt1->getDTData().sector == 8 || dt1->getDTData().sector == 11 ) )
195  ) {
197  localResult.bendingAngle = ( atan ( phiBCombined( point1.x(), point1.z(),
198  point2.x(), point2.z() )
199  )
200  - ( localResult.radialAngle/4096.0 )
201  ) * 512;
202  } else {
203  // negative chambers
204  localResult.bendingAngle = ( atan ( -phiBCombined( point1.x(), point1.z(),
205  point2.x(), point2.z() )
206  )
207  - ( localResult.radialAngle/4096.0)
208  ) * 512;
209  }
210  localResult.bendingResol = phiBCombinedResol( _resol.xDt, _resol.xDt,
211  point1.z(), point2.z() );
212 
213  //std::cout<<" == === COMBINING DT-DT === == "<<std::endl;
214  //std::cout << "dt-dt radial : " << dt1->getDTData().radialAngle << " * " << dt2->getDTData().radialAngle << " = " << localResult.radialAngle << '\n';
215  //std::cout << " " << point1.x() << " " << point1.z() << " " << dt1->getDTData().qualityCode << '\n';
216  //std::cout << " " << point2.x() << " " << point2.z() << " " << dt2->getDTData().qualityCode << '\n';
217  //std::cout << "dt-dt bending : " << dt1->getDTData().bendingAngle << " * " << dt2->getDTData().bendingAngle << " = "
218  // << localResult.bendingAngle << '\n';
219  //std::cout<<" --- this was sector "<<dt1->getDTData().sector<<" and wheel "<<dt1->getDTData().wheel<<std::endl;
220 
221  return localResult;
222 
223 }
LocalPoint toLocal(const GlobalPoint &gp) const
Conversion to the R.F. of the GeomDet.
Definition: GeomDet.h:67
float phiBCombined(const float &xDt, const float &zDt, const float &xRpc, const float &zRpc)
FIXME : Calculates new phiBending, check how to use.
T z() const
Definition: PV3DBase.h:64
tuple results
Definition: mps_update.py:44
float phiBCombinedResol(const float &resol_xDt, const float &resol_xRpc, const float &zDt, const float &zRpc)
FIXME END.
T x() const
Definition: PV3DBase.h:62
edm::ESHandle< DTGeometry > _muonGeom
PrimitiveCombiner::results PrimitiveCombiner::combineDtRpc ( const TriggerPrimitive dt,
const TriggerPrimitive rpc 
)
private

Calculates new phiBending, check how to use weights.

Definition at line 226 of file PrimitivesCombiner.cc.

References _muonGeom, _resol, L1TwinMux::PrimitiveCombiner::results::bendingAngle, L1TwinMux::PrimitiveCombiner::results::bendingResol, L1TMuon::TriggerPrimitive::detId(), DTChamberId, L1TMuon::TriggerPrimitive::getCMSGlobalPoint(), L1TMuon::TriggerPrimitive::getDTData(), phiBCombined(), phiBCombinedResol(), L1TMuon::TriggerPrimitive::DTData::radialAngle, L1TwinMux::PrimitiveCombiner::results::radialAngle, relativeConstraints::ring, L1TMuon::TriggerPrimitive::DTData::sector, relativeConstraints::station, GeomDet::toLocal(), L1TMuon::TriggerPrimitive::DTData::wheel, PV3DBase< T, PVType, FrameType >::x(), L1TwinMux::PrimitiveCombiner::resolutions::xDt, L1TwinMux::PrimitiveCombiner::resolutions::xRpc, and PV3DBase< T, PVType, FrameType >::z().

Referenced by combine().

228 {
229 
230  results localResult;
231  localResult.radialAngle = dt->getDTData().radialAngle;
232 
233  const DTChamber* chamb1 = _muonGeom->chamber( dt->detId<DTChamberId>() );
234  LocalPoint point1 = chamb1->toLocal( dt->getCMSGlobalPoint() );
235  int station = rpc->detId<RPCDetId>().station();
236  int sector = rpc->detId<RPCDetId>().sector();
237  int wheel = rpc->detId<RPCDetId>().ring();
238  const DTChamber* chamb2 = _muonGeom->chamber( DTChamberId( wheel, station, sector ) );
239  LocalPoint point2 = chamb2->toLocal( rpc->getCMSGlobalPoint() );
240 
241  if ( ( dt->getDTData().wheel > 0 ) ||
242  ( ( dt->getDTData().wheel == 0 ) &&
243  !( dt->getDTData().sector == 0 || dt->getDTData().sector==3
244  || dt->getDTData().sector==4 || dt->getDTData().sector==7
245  || dt->getDTData().sector==8 || dt->getDTData().sector==11 ) )
246  ) {
247  // positive wheels
248  localResult.bendingAngle = ( atan( phiBCombined( point1.x(), point1.z(),
249  point2.x(), point2.z() )
250  )
251  - ( localResult.radialAngle/4096.0 )
252  ) * 512;
253  } else {
254  // negative wheels
255  localResult.bendingAngle = ( atan( -phiBCombined( point1.x(), point1.z(),
256  point2.x(), point2.z() )
257  )
258  - ( localResult.radialAngle/4096.0 )
259  ) * 512;
260  }
261  localResult.bendingResol = phiBCombinedResol( _resol.xDt, _resol.xRpc,
262  point1.z(), point2.z() );
263 
264  return localResult;
265 
266 }
const DTData getDTData() const
LocalPoint toLocal(const GlobalPoint &gp) const
Conversion to the R.F. of the GeomDet.
Definition: GeomDet.h:67
float phiBCombined(const float &xDt, const float &zDt, const float &xRpc, const float &zRpc)
FIXME : Calculates new phiBending, check how to use.
T z() const
Definition: PV3DBase.h:64
tuple results
Definition: mps_update.py:44
const GlobalPoint getCMSGlobalPoint() const
float phiBCombinedResol(const float &resol_xDt, const float &resol_xRpc, const float &zDt, const float &zRpc)
FIXME END.
T x() const
Definition: PV3DBase.h:62
edm::ESHandle< DTGeometry > _muonGeom
PrimitiveCombiner::results PrimitiveCombiner::combineRpcRpc ( const TriggerPrimitive rpc1,
const TriggerPrimitive rpc2 
)
private

Calculates new phiBending, check how to use weights.

Definition at line 297 of file PrimitivesCombiner.cc.

References _muonGeom, _resol, L1TwinMux::PrimitiveCombiner::results::bendingAngle, L1TwinMux::PrimitiveCombiner::results::bendingResol, L1TMuon::TriggerPrimitive::detId(), DTChamberId, L1TMuon::TriggerPrimitive::getCMSGlobalPoint(), phiBCombined(), phiBCombinedResol(), L1TwinMux::PrimitiveCombiner::results::radialAngle, radialAngleFromGlobalPhi(), relativeConstraints::ring, relativeConstraints::station, GeomDet::toLocal(), PV3DBase< T, PVType, FrameType >::x(), L1TwinMux::PrimitiveCombiner::resolutions::xRpc, and PV3DBase< T, PVType, FrameType >::z().

Referenced by combine().

299 {
300  int station = rpc1->detId<RPCDetId>().station();
301  int sector = rpc1->detId<RPCDetId>().sector();
302  int wheel = rpc1->detId<RPCDetId>().ring();
303  const DTChamber* chamb1 = _muonGeom->chamber( DTChamberId( wheel, station, sector ) );
304  LocalPoint point1 = chamb1->toLocal( rpc1->getCMSGlobalPoint() );
305 
306 
307  station = rpc2->detId<RPCDetId>().station();
308  sector = rpc2->detId<RPCDetId>().sector();
309  wheel = rpc2->detId<RPCDetId>().ring();
310  const DTChamber* chamb2 = _muonGeom->chamber( DTChamberId( wheel, station, sector ) );
311  LocalPoint point2 = chamb2->toLocal( rpc2->getCMSGlobalPoint() );
312 
313 
314  results localResult;
315  localResult.radialAngle = 0.5*(radialAngleFromGlobalPhi( rpc1 )+radialAngleFromGlobalPhi( rpc2 )) ;
316 
317  if ( ( wheel>0 ) ||
318  ( ( wheel==0 ) &&
319  !( sector==0 || sector==3 || sector==4 || sector==7 || sector==8 || sector==11 ) ) )
320  localResult.bendingAngle = ( atan ( phiBCombined( point1.x(),
321  point1.z(),
322  point2.x(),
323  point2.z() )
324  - ( localResult.radialAngle / 4096.0 )
325  ) ) * 512;
326  else
327  localResult.bendingAngle = ( atan (-phiBCombined( point1.x(),
328  point1.z(),
329  point2.x(),
330  point2.z() )
331  - ( localResult.radialAngle/4096.0 )
332  ) ) * 512;
333  localResult.bendingResol = phiBCombinedResol( _resol.xRpc, _resol.xRpc, point1.z(), point2.z());
334 
335 
336  return localResult;
337 
338 }
LocalPoint toLocal(const GlobalPoint &gp) const
Conversion to the R.F. of the GeomDet.
Definition: GeomDet.h:67
float phiBCombined(const float &xDt, const float &zDt, const float &xRpc, const float &zRpc)
FIXME : Calculates new phiBending, check how to use.
T z() const
Definition: PV3DBase.h:64
tuple results
Definition: mps_update.py:44
int radialAngleFromGlobalPhi(const TriggerPrimitive *rpc)
const GlobalPoint getCMSGlobalPoint() const
float phiBCombinedResol(const float &resol_xDt, const float &resol_xRpc, const float &zDt, const float &zRpc)
FIXME END.
T x() const
Definition: PV3DBase.h:62
edm::ESHandle< DTGeometry > _muonGeom
PrimitiveCombiner::results PrimitiveCombiner::dummyCombineDt ( const TriggerPrimitive dt)
private

Definition at line 157 of file PrimitivesCombiner.cc.

References _resol, L1TMuon::TriggerPrimitive::DTData::bendingAngle, L1TwinMux::PrimitiveCombiner::results::bendingAngle, L1TwinMux::PrimitiveCombiner::results::bendingResol, L1TMuon::TriggerPrimitive::getDTData(), L1TwinMux::PrimitiveCombiner::resolutions::phibDtUnCorr, L1TMuon::TriggerPrimitive::DTData::radialAngle, and L1TwinMux::PrimitiveCombiner::results::radialAngle.

158 {
159 
160  // i want to combine also the DT data alone
161  results localResult;
162  localResult.radialAngle = dt->getDTData().radialAngle;
163  //std::cout<<" HEY!!! I am adding a DT benfing as a combination result! "<<std::endl;
164  localResult.bendingAngle=dt->getDTData().bendingAngle;
165  localResult.bendingResol=_resol.phibDtUnCorr;
166  return localResult;
167 }
const DTData getDTData() const
tuple results
Definition: mps_update.py:44
int L1TwinMux::PrimitiveCombiner::getUncorrelatedQuality16 ( ) const
inline

Definition at line 111 of file PrimitiveCombiner.h.

Referenced by L1ITMuonBarrelPrimitiveProducer::produce().

111  {
112 
113  int qualityCode = 0;
114  if ( _dtHI && _dtHO ) {
115  if ( _rpcIn && _rpcOut ) qualityCode = 12;
116  else qualityCode = 11;
117  } else if ( _dtHO ) {// HO quality == 3
118  if ( _rpcIn && _rpcOut ) qualityCode = 10;
119  else if ( _rpcOut ) qualityCode = 8;
120  else if ( _rpcIn ) qualityCode = 6;
121  else qualityCode = 4;
122  } else if ( _dtHI ) {// HI, quality == 2
123  if ( _rpcIn && _rpcOut ) qualityCode = 9;
124  else if ( _rpcOut ) qualityCode = 7;
125  else if ( _rpcIn ) qualityCode = 5;
126  else qualityCode = 3;
127  } else {
128  if ( _rpcIn && _rpcOut ) qualityCode = 2;
129  else if ( _rpcOut ) qualityCode = 1;
130  else if ( _rpcIn ) qualityCode = 0;
131  }
132  return qualityCode;
133  }
const TriggerPrimitive * _rpcOut
const TriggerPrimitive * _dtHI
const TriggerPrimitive * _rpcIn
const TriggerPrimitive * _dtHO
int L1TwinMux::PrimitiveCombiner::getUncorrelatedQuality7 ( ) const
inline

FIXME END.

Definition at line 87 of file PrimitiveCombiner.h.

Referenced by L1ITMuonBarrelPrimitiveProducer::produce().

87  {
88 
89  int qualityCode = 0;
90  if ( _dtHI && _dtHO ) {
91  if ( _rpcIn && _rpcOut ) qualityCode = 5;
92  else qualityCode = 5;
93  } else if ( _dtHO ) {// HO quality == 3
94  if ( _rpcIn && _rpcOut ) qualityCode = 4;
95  else if ( _rpcOut ) qualityCode = 4;
96  else if ( _rpcIn ) qualityCode = 4;
97  else qualityCode = 2;
98  } else if ( _dtHI ) {// HI, quality == 2
99  if ( _rpcIn && _rpcOut ) qualityCode = 3;
100  else if ( _rpcOut ) qualityCode = 3;
101  else if ( _rpcIn ) qualityCode = 3;
102  else qualityCode = 1;
103  } else {
104  if ( _rpcIn && _rpcOut ) qualityCode = 0;
105  else if ( _rpcOut ) qualityCode = -1;
106  else if ( _rpcIn ) qualityCode = -1;
107  }
108  return qualityCode;
109  }
const TriggerPrimitive * _rpcOut
const TriggerPrimitive * _dtHI
const TriggerPrimitive * _rpcIn
const TriggerPrimitive * _dtHO
bool L1TwinMux::PrimitiveCombiner::isValid ( void  ) const
inline

valid if we have at least: 1 rpc; 1 dt + 1 any

Definition at line 60 of file PrimitiveCombiner.h.

References runTheMatrix::ret.

Referenced by combine(), L1ITMuonBarrelPrimitiveProducer::produce(), and core.AutoHandle.AutoHandle::ReallyLoad().

60  {
61  int ret = _dtHI ? 1 : 0;
62  ret += _dtHO ? 1 : 0;
63  ret += _rpcIn ? 2 : 0;
64  ret += _rpcOut ? 2 : 0;
65  return ret > 1 ;
66  };
tuple ret
prodAgent to be discontinued
const TriggerPrimitive * _rpcOut
const TriggerPrimitive * _dtHI
const TriggerPrimitive * _rpcIn
const TriggerPrimitive * _dtHO
float L1TwinMux::PrimitiveCombiner::phiBCombined ( const float &  xDt,
const float &  zDt,
const float &  xRpc,
const float &  zRpc 
)
inline

FIXME : Calculates new phiBending, check how to use.

Definition at line 69 of file PrimitiveCombiner.h.

Referenced by combineDt(), combineDtRpc(), and combineRpcRpc().

71  {
72  return (xRpc - xDt) / (zRpc - zDt);
73  };
float L1TwinMux::PrimitiveCombiner::phiBCombinedResol ( const float &  resol_xDt,
const float &  resol_xRpc,
const float &  zDt,
const float &  zRpc 
)
inline

FIXME END.

FIXME : Calculates new phiBending resolution

Definition at line 77 of file PrimitiveCombiner.h.

References mathSSE::sqrt().

Referenced by combineDt(), combineDtRpc(), and combineRpcRpc().

82  {
83  return std::sqrt( resol_xRpc*resol_xRpc + resol_xDt*resol_xDt )/std::fabs(zDt-zRpc);
84  };
T sqrt(T t)
Definition: SSEVec.h:18
int L1TwinMux::PrimitiveCombiner::radialAngle ( ) const
inline
int PrimitiveCombiner::radialAngleFromGlobalPhi ( const TriggerPrimitive rpc)
private

Definition at line 274 of file PrimitivesCombiner.cc.

References L1TMuon::TriggerPrimitive::detId(), L1TMuon::TriggerPrimitive::getCMSGlobalPhi(), Geom::pi(), and radialAngle().

Referenced by combine(), and combineRpcRpc().

275 {
276  int radialAngle = 0;
277  int radialAngle2 = 0;
278  int sector = rpc->detId<RPCDetId>().sector();
279  float phiGlobal = rpc->getCMSGlobalPhi();
280  // int wheel = rpc->detId<RPCDetId>().ring();
281  // from phiGlobal to radialAngle of the primitive in sector sec in [1..12]
282  if ( sector == 1) radialAngle = int( phiGlobal*4096 );
283  else {
284  if ( phiGlobal >= 0) radialAngle = int( (phiGlobal-(sector-1)*Geom::pi()/6)*4096 );
285  else radialAngle = int( (phiGlobal+(13-sector)*Geom::pi()/6)*4096 );
286  }
287  //if ( ( wheel>0 ) ||
288  // ( ( wheel==0 ) &&
289  // ( sector==0 || sector==3 || sector==4 || sector==7 || sector==8 || sector==11 ) ) )
290  radialAngle2 = radialAngle;
291  //else
292  // radialAngle2 = -radialAngle;
293  return radialAngle2;
294 }
const double getCMSGlobalPhi() const
double pi()
Definition: Pi.h:31

Member Data Documentation

int L1TwinMux::PrimitiveCombiner::_bendingAngle
private

Definition at line 169 of file PrimitiveCombiner.h.

Referenced by combine().

int L1TwinMux::PrimitiveCombiner::_bendingResol
private

Definition at line 170 of file PrimitiveCombiner.h.

Referenced by combine().

int L1TwinMux::PrimitiveCombiner::_bx
private

Definition at line 167 of file PrimitiveCombiner.h.

const TriggerPrimitive* L1TwinMux::PrimitiveCombiner::_dtHI
private

Definition at line 172 of file PrimitiveCombiner.h.

Referenced by addDtHI(), and combine().

const TriggerPrimitive* L1TwinMux::PrimitiveCombiner::_dtHO
private

Definition at line 173 of file PrimitiveCombiner.h.

Referenced by addDtHO(), and combine().

edm::ESHandle<DTGeometry> L1TwinMux::PrimitiveCombiner::_muonGeom
private

Definition at line 165 of file PrimitiveCombiner.h.

Referenced by combineDt(), combineDtRpc(), and combineRpcRpc().

int L1TwinMux::PrimitiveCombiner::_radialAngle
private

Definition at line 168 of file PrimitiveCombiner.h.

Referenced by combine().

resolutions L1TwinMux::PrimitiveCombiner::_resol
private

Definition at line 164 of file PrimitiveCombiner.h.

Referenced by combineDt(), combineDtRpc(), combineRpcRpc(), and dummyCombineDt().

const TriggerPrimitive* L1TwinMux::PrimitiveCombiner::_rpcIn
private

Definition at line 174 of file PrimitiveCombiner.h.

Referenced by addRpcIn(), and combine().

const TriggerPrimitive* L1TwinMux::PrimitiveCombiner::_rpcOut
private

Definition at line 175 of file PrimitiveCombiner.h.

Referenced by addRpcOut(), and combine().