Gaudi converter base class with const interfaces.
More...
#include <AthConstConverter.h>
Inherits Converter, and AthMessaging.
Inherited by LVL1BS::CpReadByteStreamV1Cnv< CPMHitsCollection >, LVL1BS::CpReadByteStreamV1Cnv< CMMCPHitsCollection >, LVL1BS::JepReadByteStreamV1Cnv< CMMJetHitsCollection >, LVL1BS::JepReadByteStreamV1Cnv< CMMEtSumsCollection >, LVL1BS::JepReadByteStreamV1Cnv< JEMHitsCollection >, LVL1BS::JepReadByteStreamV1V2Cnv< JetElementCollection >, LVL1BS::JepReadByteStreamV1V2Cnv< JEMEtSumsCollection >, LVL1BS::JepRoiReadByteStreamV1Cnv< JEMRoICollection >, LVL1BS::JepRoiReadByteStreamV1Cnv< LVL1::CMMRoI >, LVL1BS::JepRoiReadByteStreamV2Cnv< LVL1::CMXRoI >, BCM_RawContByteStreamCnv, CscRdoContByteStreamCnv, ITkPixelRawContByteStreamCnv, ITkStripsRawContByteStreamCnv, L1TopoByteStreamCnv, LArAccumulatedCalibDigitContByteStreamCnv, LArAccumulatedDigitContByteStreamCnv, LArCalibDigitContByteStreamCnv, LArDigitContByteStreamCnv, LArFebHeaderContByteStreamCnv, LArLATOMEHeaderContByteStreamCnv, LArRawChannelContByteStreamCnv, LVL1BS::CpByteStreamCnv, LVL1BS::CpByteStreamV1Cnv, LVL1BS::CpByteStreamV2Cnv, LVL1BS::CpReadByteStreamV1Cnv< Container >, LVL1BS::CpReadByteStreamV1V2Cnv, LVL1BS::CpReadByteStreamV2Cnv< Container >, LVL1BS::CpmRoiByteStreamCnv, LVL1BS::CpmRoiByteStreamV1Cnv, LVL1BS::CpmRoiByteStreamV2Cnv, LVL1BS::JepByteStreamCnv, LVL1BS::JepByteStreamV1Cnv, LVL1BS::JepByteStreamV2Cnv, LVL1BS::JepReadByteStreamV1Cnv< Container >, LVL1BS::JepReadByteStreamV1V2Cnv< Container >, LVL1BS::JepReadByteStreamV2Cnv< Container >, LVL1BS::JepRoiByteStreamCnv, LVL1BS::JepRoiByteStreamV1Cnv, LVL1BS::JepRoiByteStreamV2Cnv, LVL1BS::JepRoiReadByteStreamV1Cnv< Container >, LVL1BS::JepRoiReadByteStreamV2Cnv< Container >, LVL1BS::L1CaloErrorByteStreamCnv, LVL1BS::PpmByteStreamV1Cnv, LVL1BS::RodHeaderByteStreamCnv, MdtCsmContByteStreamCnv, PixelRawContByteStreamCnv, RpcPadContByteStreamCnv, SCTRawContByteStreamCnv, TRTRawContByteStreamCnv, TgcRdoContByteStreamCnv, TileBeamElemContByteStreamCnv, TileDigitsContByteStreamCnv, TileL2ContByteStreamCnv, TileLaserObjByteStreamCnv, TileMuRcvContByteStreamCnv, TileRawChannelContByteStreamCnv, and ZdcByteStreamCnv.
|
| | AthConstConverter (long storage_type, const CLID &class_type, ISvcLocator *svc, const std::string &name) |
| virtual StatusCode | createObjConst (IOpaqueAddress *pAddress, DataObject *&refpObject) const |
| | Create the transient representation of an object.
|
| virtual StatusCode | createRepConst (DataObject *pObject, IOpaqueAddress *&refpAddress) const |
| | Convert the transient object to the requested representation.
|
| virtual StatusCode | createObj (IOpaqueAddress *pAddress, DataObject *&refpObject) override final |
| | Create the transient representation of an object.
|
| virtual StatusCode | createRep (DataObject *pObject, IOpaqueAddress *&refpAddress) override final |
| | Convert the transient object to the requested representation.
|
| const std::string & | name () const |
| void | addTrack (TIDA::Track *t) |
| const std::vector< TIDA::Track * > & | tracks () const |
| void | clear () |
| void | selectTracks (const TrigInDetTrackCollection *trigtracks) |
| void | selectTracks (const Rec::TrackParticleContainer *trigtracks) |
| void | selectTracks (const Analysis::MuonContainer *muontracks) |
| bool | msgLvl (const MSG::Level lvl) const |
| | Test the output level.
|
| MsgStream & | msg () const |
| | The standard message stream.
|
| MsgStream & | msg (const MSG::Level lvl) const |
| | The standard message stream.
|
| void | setLevel (MSG::Level lvl) |
| | Change the current logging level.
|
|
| double | phiCorr (double phi) |
| void | ipCorr (double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt) |
|
| void | initMessaging () const |
| | Initialize our message level and MessageSvc.
|
|
| std::string | m_name |
| std::string | m_nm |
| | Message source name.
|
| boost::thread_specific_ptr< MsgStream > | m_msg_tls |
| | MsgStream instance (a std::cout like with print-out levels)
|
| std::atomic< IMessageSvc * > | m_imsg { nullptr } |
| | MessageSvc pointer.
|
| std::atomic< MSG::Level > | m_lvl { MSG::NIL } |
| | Current logging level.
|
| std::atomic_flag m_initialized | ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT |
| | Messaging initialized (initMessaging)
|
Gaudi converter base class with const interfaces.
This is a version of Gaudi Converter which uses const createRepConst and createObjConst methods instead of createObj and createRep. This can be used for converters that one wants to execute concurrently in MT jobs.
As a bonus, we also include AthMessaging functionality.
Definition at line 32 of file AthConstConverter.h.
◆ AthConstConverter()
| AthConstConverter::AthConstConverter |
( |
long | storage_type, |
|
|
const CLID & | class_type, |
|
|
ISvcLocator * | svc, |
|
|
const std::string & | name ) |
|
inline |
Definition at line 35 of file AthConstConverter.h.
39 :
Converter (storage_type, class_type, svc),
42 {
43 }
const std::string & name() const
AthMessaging()
Default constructor:
T * get(TKey *tobj)
get a TObject* from a TKey* (why can't a TObject be a TKey?)
msgSvc
Provide convenience handles for various services.
◆ addTrack()
Definition at line 45 of file Converter.h.
45 {
47 }
std::vector< TIDA::Track * > m_tracks
◆ clear()
| void Converter::clear |
( |
| ) |
|
|
inlineinherited |
◆ createObj()
| StatusCode AthConstConverter::createObj |
( |
IOpaqueAddress * | pAddress, |
|
|
DataObject *& | refpObject ) |
|
finaloverridevirtual |
Create the transient representation of an object.
Non-const version; just calls the const version.
Definition at line 44 of file AthConstConverter.cxx.
46{
48}
virtual StatusCode createObjConst(IOpaqueAddress *pAddress, DataObject *&refpObject) const
Create the transient representation of an object.
◆ createObjConst()
| StatusCode AthConstConverter::createObjConst |
( |
IOpaqueAddress * | pAddress, |
|
|
DataObject *& | refpObject ) const |
|
virtual |
Create the transient representation of an object.
The default implementation is a no-op.
Reimplemented in CscRdoContByteStreamCnv, ITkStripsRawContByteStreamCnv, L1TopoByteStreamCnv, LArAccumulatedCalibDigitContByteStreamCnv, LArAccumulatedDigitContByteStreamCnv, LArCalibDigitContByteStreamCnv, LArDigitContByteStreamCnv, LArFebHeaderContByteStreamCnv, LArLATOMEHeaderContByteStreamCnv, LArRawChannelContByteStreamCnv, LVL1BS::CpmRoiByteStreamCnv, LVL1BS::CpmRoiByteStreamV1Cnv, LVL1BS::CpmRoiByteStreamV2Cnv, LVL1BS::CpReadByteStreamV1Cnv< Container >, LVL1BS::CpReadByteStreamV1Cnv< CMMCPHitsCollection >, LVL1BS::CpReadByteStreamV1Cnv< CPMHitsCollection >, LVL1BS::CpReadByteStreamV1V2Cnv, LVL1BS::CpReadByteStreamV2Cnv< Container >, LVL1BS::JepReadByteStreamV1Cnv< Container >, LVL1BS::JepReadByteStreamV1Cnv< CMMEtSumsCollection >, LVL1BS::JepReadByteStreamV1Cnv< CMMJetHitsCollection >, LVL1BS::JepReadByteStreamV1Cnv< JEMHitsCollection >, LVL1BS::JepReadByteStreamV1V2Cnv< Container >, LVL1BS::JepReadByteStreamV1V2Cnv< JEMEtSumsCollection >, LVL1BS::JepReadByteStreamV1V2Cnv< JetElementCollection >, LVL1BS::JepReadByteStreamV2Cnv< Container >, LVL1BS::JepRoiReadByteStreamV1Cnv< Container >, LVL1BS::JepRoiReadByteStreamV1Cnv< JEMRoICollection >, LVL1BS::JepRoiReadByteStreamV1Cnv< LVL1::CMMRoI >, LVL1BS::JepRoiReadByteStreamV2Cnv< Container >, LVL1BS::JepRoiReadByteStreamV2Cnv< LVL1::CMXRoI >, LVL1BS::L1CaloErrorByteStreamCnv, LVL1BS::PpmByteStreamV1Cnv, LVL1BS::RodHeaderByteStreamCnv, MdtCsmContByteStreamCnv, RpcPadContByteStreamCnv, SCTRawContByteStreamCnv, TgcRdoContByteStreamCnv, TileBeamElemContByteStreamCnv, TileDigitsContByteStreamCnv, TileL2ContByteStreamCnv, TileLaserObjByteStreamCnv, TileMuRcvContByteStreamCnv, TileRawChannelContByteStreamCnv, TRTRawContByteStreamCnv, and ZdcByteStreamCnv.
Definition at line 20 of file AthConstConverter.cxx.
22{
23 return StatusCode::SUCCESS;
24}
◆ createRep()
| StatusCode AthConstConverter::createRep |
( |
DataObject * | pObject, |
|
|
IOpaqueAddress *& | refpAddress ) |
|
finaloverridevirtual |
Convert the transient object to the requested representation.
Non-const version; just calls the const version.
Definition at line 56 of file AthConstConverter.cxx.
58{
60}
virtual StatusCode createRepConst(DataObject *pObject, IOpaqueAddress *&refpAddress) const
Convert the transient object to the requested representation.
◆ createRepConst()
| StatusCode AthConstConverter::createRepConst |
( |
DataObject * | pObject, |
|
|
IOpaqueAddress *& | refpAddress ) const |
|
virtual |
Convert the transient object to the requested representation.
The default implementation is a no-op.
Reimplemented in BCM_RawContByteStreamCnv, CscRdoContByteStreamCnv, ITkPixelRawContByteStreamCnv, ITkStripsRawContByteStreamCnv, L1TopoByteStreamCnv, LArAccumulatedCalibDigitContByteStreamCnv, LArAccumulatedDigitContByteStreamCnv, LArCalibDigitContByteStreamCnv, LArDigitContByteStreamCnv, LArFebHeaderContByteStreamCnv, LArLATOMEHeaderContByteStreamCnv, LArRawChannelContByteStreamCnv, LVL1BS::CpByteStreamCnv, LVL1BS::CpByteStreamV1Cnv, LVL1BS::CpByteStreamV2Cnv, LVL1BS::CpmRoiByteStreamCnv, LVL1BS::CpmRoiByteStreamV1Cnv, LVL1BS::CpmRoiByteStreamV2Cnv, LVL1BS::JepByteStreamCnv, LVL1BS::JepByteStreamV1Cnv, LVL1BS::JepByteStreamV2Cnv, LVL1BS::JepRoiByteStreamCnv, LVL1BS::JepRoiByteStreamV1Cnv, LVL1BS::JepRoiByteStreamV2Cnv, LVL1BS::PpmByteStreamV1Cnv, MdtCsmContByteStreamCnv, PixelRawContByteStreamCnv, RpcPadContByteStreamCnv, SCTRawContByteStreamCnv, TgcRdoContByteStreamCnv, TileBeamElemContByteStreamCnv, TileDigitsContByteStreamCnv, TileL2ContByteStreamCnv, TileLaserObjByteStreamCnv, TileMuRcvContByteStreamCnv, TileRawChannelContByteStreamCnv, and TRTRawContByteStreamCnv.
Definition at line 32 of file AthConstConverter.cxx.
34{
35 return StatusCode::SUCCESS;
36}
◆ initMessaging()
| void AthMessaging::initMessaging |
( |
| ) |
const |
|
privateinherited |
Initialize our message level and MessageSvc.
This method should only be called once.
Definition at line 39 of file AthMessaging.cxx.
40{
42
43 if (
m_lvl == MSG::NIL) {
47 }
48}
std::string m_nm
Message source name.
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
Current logging level.
IMessageSvc * getMessageSvc(bool quiet=false)
◆ ipCorr()
| void Converter::ipCorr |
( |
double | d0, |
|
|
double | z0, |
|
|
double & | d0c, |
|
|
double & | z0c, |
|
|
double | phi0, |
|
|
double | eta, |
|
|
double | pt ) |
|
inlineprotectedinherited |
Definition at line 257 of file Converter.h.
257 {
258
259 double sn =
sin(phi0);
260 double cs =
cos(phi0);
261 double sd0 = (
d0 != 0 ?
d0/fabs(d0) : 1);
262 double spt = (
pt != 0 ?
pt/fabs(pt) : 1);
263
264 if (fabs(pt) >= 1*CLHEP::TeV) {
265
267
268 } else {
269
270 double rc = fabs(pt)*15.0/(9.0*1.042);
271
274
275 double newphi;
276 double xd01,yd01,xd02,yd02;
277
278 if (xc == 0) {
279 xd01 = 0; yd01 =
rc+yc;
280 xd02 = 0; yd02 = -
rc+yc;
281 } else {
282 xd01 = xc+yc/xc*yc+sqrt(
pow((xc+yc/xc*yc),2)-xc*xc-yc*yc+
rc*
rc); yd01 = yc/xc*xd01;
283 xd02 = xc+yc/xc*yc-sqrt(
pow((xc+yc/xc*yc),2)-xc*xc-yc*yc+
rc*
rc); yd02 = yc/xc*xd02;
284 }
285
286 double r1 = sqrt(xd01*xd01+yd01*yd01);
287 double r2 = sqrt(xd02*xd02+yd02*yd02);
288
289 double phiV;
290
291 if (r1 < r2)
292 phiV = atan2(yd01,xd01);
293 else
294 phiV = atan2(yd02,xd02);
295
298
300 newphi = phi1;
301 else
302 newphi = phi2;
303
304 d0c = fabs(sqrt(xc*xc+yc*yc)-
rc)*
sin(phiV-newphi);
305
307 double theta_save=
theta;
310
313
314 }
315 }
Scalar eta() const
pseudorapidity method
Scalar theta() const
theta method
constexpr int pow(int base, int exp) noexcept
double phiCorr(double phi)
◆ msg() [1/2]
| MsgStream & AthMessaging::msg |
( |
| ) |
const |
|
inlineinherited |
The standard message stream.
Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.
Definition at line 163 of file AthMessaging.h.
164{
166 if (!ms) {
170 }
171
174}
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
void initMessaging() const
Initialize our message level and MessageSvc.
◆ msg() [2/2]
| MsgStream & AthMessaging::msg |
( |
const MSG::Level | lvl | ) |
const |
|
inlineinherited |
The standard message stream.
Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.
Definition at line 178 of file AthMessaging.h.
179{
return msg() << lvl; }
MsgStream & msg() const
The standard message stream.
◆ msgLvl()
| bool AthMessaging::msgLvl |
( |
const MSG::Level | lvl | ) |
const |
|
inlineinherited |
Test the output level.
- Parameters
-
| lvl | The message level to test against |
- Returns
- boolean Indicating if messages at given level will be printed
- Return values
-
| true | Messages at level "lvl" will be printed |
Definition at line 151 of file AthMessaging.h.
152{
155 return true;
156 } else {
157 return false;
158 }
159}
◆ name()
| const std::string & AthConstConverter::name |
( |
| ) |
const |
|
inline |
◆ phiCorr()
| double Converter::phiCorr |
( |
double | phi | ) |
|
|
inlineprotectedinherited |
Definition at line 248 of file Converter.h.
248 {
249
250 if (
phi < -TMath::Pi())
phi += 2*TMath::Pi();
251 if (
phi > TMath::Pi())
phi -= 2*TMath::Pi();
252
254 }
Scalar phi() const
phi method
◆ selectTracks() [1/3]
Definition at line 177 of file Converter.h.
177 {
178
179 static int hpmap[20] = { 0, 1, 2, 7, 8, 9, 3, 4, 5, 6, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19 };
180
183
184 while(muonitr!=muonend) {
185
186 bool hasInDet = (*muonitr)->hasInDetTrackParticle();
187 const Rec::TrackParticle *trackitr=NULL;
188 if(hasInDet) trackitr=(*muonitr)->inDetTrackParticle();
189 muonitr++;
190 if(!hasInDet) continue;
191
193
194 CLHEP::HepVector perigeeParams = measPer->parameters();
195 double pT = measPer->
pT();
196 double eta = measPer->
eta();
200
201
202 double deta = 1;
203 double dphi = 1;
204 double dz0 = 1;
205 double dd0 = 1;
206 double dpT = 1;
207
208
209
210
211
218
220
221 const Trk::FitQuality *quality = trackitr->
fitQuality();
223 double dof = quality->quality->
numberDoF();
224
225 unsigned bitmap = 0;
226
227 for ( int ih=0 ; ih<20 ; ih++ ) {
229 }
230
231
233
234
235 TIDA::Track*
t =
new TIDA::Track(
eta,
phi, z0, d0, pT,
chi2, dof,
236 deta, dphi, dz0, dd0, dpT,
237 nBlayerHits, nPixelHits, nSctHits, nSiHits,
238 nStrawHits, nTrHits, bitmap, 0,
239 -1) ;
240
242 }
243
244 }
void addTrack(TIDA::Track *t)
void ipCorr(double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
DataModel_detail::const_iterator< DataVector > const_iterator
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
const Trk::Perigee * measuredPerigee() const
Accessor method for Perigee.
int numberDoF() const
returns the number of degrees of freedom of the overall track or vertex fit as integer
double chiSquared() const
returns the of the overall track fit
double eta() const
Access method for pseudorapidity - from momentum.
double pT() const
Access method for transverse momentum.
const FitQuality * fitQuality() const
accessor function for FitQuality.
const TrackSummary * trackSummary() const
accessor function for TrackSummary.
double chi2(TH1 *h0, TH1 *h1)
float nSiHits(const U &p)
float nPixelHits(const U &p)
DetectorType
enumerates the various detector types currently accessible from the isHit() method.
@ numberOfSCTHits
number of SCT holes
@ numberOfPixelHits
number of pixel layers on track with absence of hits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?
@ numberOfTRTHits
number of TRT outliers
@ numberOfTRTHighThresholdHits
total number of TRT hits which pass the high threshold
◆ selectTracks() [2/3]
Definition at line 111 of file Converter.h.
111 {
112
115
116 static int hpmap[20] = { 0, 1, 2, 7, 8, 9, 3, 4, 5, 6, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19 };
117
118 while ( trackitr!=trackend ) {
119
121
122 CLHEP::HepVector perigeeParams = measPer->parameters();
123 double pT = measPer->
pT();
124 double eta = measPer->
eta();
128
129
130 double deta = 1;
131 double dphi = 1;
132 double dz0 = 1;
133 double dd0 = 1;
134 double dpT = 1;
135
136
137
138
139
140 const Trk::TrackSummary *
summary = (*trackitr)->trackSummary();
147 bool expectBL = false;
148
149 const Trk::FitQuality *quality = (*trackitr)->fitQuality();
152
153 unsigned bitmap = 0;
154
155 for ( int ih=0 ; ih<20 ; ih++ ) {
157 }
158
159
161
162
163 TIDA::Track*
t =
new TIDA::Track(
eta,
phi, z0, d0, pT,
chi2, dof,
164 deta, dphi, dz0, dd0, dpT,
165 nBlayerHits, nPixelHits, nSctHits, nSiHits,
166 nStrawHits, nTrHits, bitmap, 0,
167 -1,
168 expectBL) ;
169
171 trackitr++;
172 }
173
174 }
◆ selectTracks() [3/3]
Definition at line 56 of file Converter.h.
56 {
57
60
61 while ( trackitr!=trackend ) {
62
63 double eta = (*trackitr)->param()->eta();
64 double phi = (*trackitr)->param()->phi0();
65 double z0 = (*trackitr)->param()->z0();
66 double pT = (*trackitr)->param()->pT();
67 double d0 = (*trackitr)->param()->a0();
68
69
70 double deta = (*trackitr)->param()->eeta();
71 double dphi = (*trackitr)->param()->ephi0();
72 double dz0 = (*trackitr)->param()->ez0();
73 double dpT = (*trackitr)->param()->epT();
74 double dd0 = (*trackitr)->param()->ea0();
75
76 int algoid = (*trackitr)->algorithmId();
77
78 int nBlayerHits = ((*trackitr)->HitPattern() & 0x1);
79 int nPixelHits = 2*(*trackitr)->NPixelSpacePoints();
80 int nSctHits = 2*(*trackitr)->NSCT_SpacePoints();
81 int nStrawHits = (*trackitr)->NStrawHits();
82 int nTrHits = (*trackitr)->NTRHits();
83
85 bool expectBL = false;
86
87 unsigned hitPattern = (*trackitr)->HitPattern();
88 unsigned multiPattern = 0;
89
90 double chi2 = (*trackitr)->chi2();
91 double dof = 0;
92
93
95
96
97 TIDA::Track*
t =
new TIDA::Track(
eta,
phi, z0, d0, pT,
chi2, dof,
98 deta, dphi, dz0, dd0, dpT,
99 nBlayerHits, nPixelHits, nSctHits, nSiHits,
100 nStrawHits, nTrHits, hitPattern, multiPattern,
101 algoid,
102 expectBL ) ;
103
105 trackitr++;
106 }
107 }
◆ setLevel()
| void AthMessaging::setLevel |
( |
MSG::Level | lvl | ) |
|
|
inherited |
◆ tracks()
| const std::vector< TIDA::Track * > & Converter::tracks |
( |
| ) |
const |
|
inlineinherited |
◆ ATLAS_THREAD_SAFE
| std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT |
|
mutableprivateinherited |
◆ m_beamX
| double Converter::m_beamX |
|
protectedinherited |
◆ m_beamY
| double Converter::m_beamY |
|
protectedinherited |
◆ m_beamZ
| double Converter::m_beamZ |
|
protectedinherited |
◆ m_imsg
| std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr } |
|
mutableprivateinherited |
◆ m_lvl
| std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL } |
|
mutableprivateinherited |
◆ m_msg_tls
| boost::thread_specific_ptr<MsgStream> AthMessaging::m_msg_tls |
|
mutableprivateinherited |
MsgStream instance (a std::cout like with print-out levels)
Definition at line 132 of file AthMessaging.h.
◆ m_name
| std::string AthConstConverter::m_name |
|
private |
◆ m_nm
| std::string AthMessaging::m_nm |
|
privateinherited |
◆ m_tracks
The documentation for this class was generated from the following files: