ATLAS Offline Software
Loading...
Searching...
No Matches
EventInfoByteStreamAuxCnv Class Reference

ByteStream converter for xAOD::EventAuxInfo. More...

#include <EventInfoByteStreamAuxCnv.h>

Inheritance diagram for EventInfoByteStreamAuxCnv:
Collaboration diagram for EventInfoByteStreamAuxCnv:

Public Member Functions

 EventInfoByteStreamAuxCnv (ISvcLocator *svcloc)
virtual ~EventInfoByteStreamAuxCnv () override=default
virtual StatusCode initialize () override
virtual StatusCode finalize () override
virtual StatusCode createObj (IOpaqueAddress *pAddr, DataObject *&pObj) override
 converter method to create object
virtual StatusCode createRep (DataObject *pObj, IOpaqueAddress *&pAddr) override
 converter method to write object
virtual long repSvcType () const override
 Storage type and class ID.
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.

Static Public Member Functions

static long storageType ()
static CLID classID ()

Protected Member Functions

double phiCorr (double phi)
void ipCorr (double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)

Protected Attributes

double m_beamX
double m_beamY
double m_beamZ
std::vector< TIDA::Track * > m_tracks

Private Member Functions

std::string ascTime (unsigned int t)
 convert timestamp to ascii time.
void initMessaging () const
 Initialize our message level and MessageSvc.

Private Attributes

ServiceHandle< IROBDataProviderSvcm_robDataProvider
 RODDataProviderSvc handle.
ServiceHandle< StoreGateSvcm_mdSvc
 TDS handle.
ToolHandle< IMCEventInfoByteStreamToolm_mcEventInfoTool {"MCEventInfoByteStreamTool"}
 Tool for decoding MC EventInfo from ROB.
bool m_isSimulation
bool m_isTestbeam
bool m_isCalibration
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).

Detailed Description

ByteStream converter for xAOD::EventAuxInfo.

Reading: EventInfo is built from the RawEvent header. For MC ByteStream files, MC-specific fields are decoded from a dedicated ROB fragment via MCEventInfoByteStreamTool.

Writing: For MC files, MC-specific EventInfo fields are encoded to a dedicated ROB fragment via MCEventInfoByteStreamTool.

Definition at line 35 of file EventInfoByteStreamAuxCnv.h.

Constructor & Destructor Documentation

◆ EventInfoByteStreamAuxCnv()

EventInfoByteStreamAuxCnv::EventInfoByteStreamAuxCnv ( ISvcLocator * svcloc)

Definition at line 31 of file EventInfoByteStreamAuxCnv.cxx.

32 : Converter(storageType(), classID(), svcloc)
33 , AthMessaging(svcloc != nullptr ? msgSvc() : nullptr, "EventInfoByteStreamAuxCnv")
34 , m_robDataProvider("ROBDataProviderSvc", "EventInfoByteStreamAuxCnv")
35 , m_mdSvc("InputMetaDataStore", "EventInfoByteStreamAuxCnv")
36 , m_isSimulation(false)
37 , m_isTestbeam(false)
38 , m_isCalibration(false)
39{
40}
AthMessaging()
Default constructor:
ServiceHandle< IROBDataProviderSvc > m_robDataProvider
RODDataProviderSvc handle.
ServiceHandle< StoreGateSvc > m_mdSvc
TDS handle.

◆ ~EventInfoByteStreamAuxCnv()

virtual EventInfoByteStreamAuxCnv::~EventInfoByteStreamAuxCnv ( )
overridevirtualdefault

Member Function Documentation

◆ addTrack()

void Converter::addTrack ( TIDA::Track * t)
inlineinherited

Definition at line 45 of file Converter.h.

45 {
46 m_tracks.push_back(t);
47 }
std::vector< TIDA::Track * > m_tracks
Definition Converter.h:321

◆ ascTime()

std::string EventInfoByteStreamAuxCnv::ascTime ( unsigned int t)
private

convert timestamp to ascii time.

Definition at line 339 of file EventInfoByteStreamAuxCnv.cxx.

340{
341 struct tm t;
342 t.tm_sec = tstamp;
343 t.tm_min = 0;
344 t.tm_hour = 0;
345 t.tm_mday = 0;
346 t.tm_mon = 0;
347 t.tm_year = 70;
348 t.tm_wday = 00;
349 t.tm_yday = 00;
350 t.tm_isdst = 0;
351 time_t ct = mktime(&t);
352 struct tm t2;
353 gmtime_r(&ct, &t2);
354 char buf[32];
355 asctime_r (&t2, buf);
356 return std::string (buf);
357}
std::vector< ALFA_RawDataContainer_p1 > t2

◆ classID()

CLID EventInfoByteStreamAuxCnv::classID ( )
static

◆ clear()

void Converter::clear ( )
inlineinherited

Definition at line 53 of file Converter.h.

53{m_tracks.clear();}

◆ createObj()

StatusCode EventInfoByteStreamAuxCnv::createObj ( IOpaqueAddress * pAddr,
DataObject *& pObj )
overridevirtual

converter method to create object

Definition at line 123 of file EventInfoByteStreamAuxCnv.cxx.

124{
125 ByteStreamAddress *pRE_Addr{nullptr};
126 pRE_Addr = dynamic_cast<ByteStreamAddress*>(pAddr);
127 if (!pRE_Addr) {
128 ATH_MSG_ERROR("Cannot cast to ByteStreamAddress ");
129 return StatusCode::FAILURE;
130 }
131
132 ATH_MSG_DEBUG("Creating Objects");
133
134 // get RawEvent
135 const RawEvent* re = m_robDataProvider->getEvent(Gaudi::Hive::currentContext());
136 if (!re) {
137 ATH_MSG_ERROR("Can not get RawEvent ");
138 return StatusCode::FAILURE;
139 }
140
141 // Run Number
142 int runNumber = re->run_no();
143
144 // Event Number
146 if (re->version() < 0x03010000) {
147 eventNumber=re->lvl1_id();
148 } else {
149 eventNumber=re->global_id();
150 }
151
152 // Time Stamp
153 uint32_t bc_time_sec = re->bc_time_seconds();
154 uint32_t bc_time_ns = re->bc_time_nanoseconds();
155 // bc_time_ns should be lt 1e9.
156 if (bc_time_ns > 1000000000) {
157 if (runNumber < 20920) {
158 // In M4 we saw otherwise, because sec/ns was swapped in raw data.
159 uint32_t temp = bc_time_ns;
160 bc_time_ns = bc_time_sec;
161 bc_time_sec= temp;
162 ATH_MSG_DEBUG("bc_time second/nanosecond swapped, sec/ns = " << bc_time_sec << " " << bc_time_ns);
163 }
164 else {
165 // For later runs, the nanosecond clock sometimes is not reset, making it overrun 1e9. Round it off to 1e9
166 ATH_MSG_WARNING("bc_time nanosecond number larger than 1e9, it is " << bc_time_ns << ", reset it to 1 sec");
167 bc_time_ns = 1000000000;
168 }
169 }
170
171 // luminosity block number
172 uint16_t lumiBlock = re->lumi_block();
173
174 // bunch crossing identifier
175 uint16_t bcID = re->bc_id();
176
177 unsigned int detMask0 = 0xFFFFFFFF, detMask1 = 0xFFFFFFFF, detMask2 = 0xFFFFFFFF, detMask3 = 0xFFFFFFFF;
178 // Get ByteStream Metadata from Input MetaData Store
179 const ByteStreamMetadataContainer* metadatacont{nullptr};
180 StatusCode status = m_mdSvc->retrieve(metadatacont, "ByteStreamMetadata");
181 if (!status.isSuccess()) {
182 ATH_MSG_WARNING("Unable to retrieve Input MetaData for ByteStream");
183 }
184 else {
185 const ByteStreamMetadata* metadata = *(metadatacont->begin());
186 uint64_t detectorMask = metadata->getDetectorMask();
187 detMask0 = (unsigned int)(detectorMask & 0x00000000FFFFFFFF);
188 detMask1 = (unsigned int)(detectorMask >> 32);
189 uint64_t detectorMask2 = metadata->getDetectorMask2();
190 detMask2 = (unsigned int)(detectorMask2 & 0x00000000FFFFFFFF);
191 detMask3 = (unsigned int)(detectorMask2 >> 32);
192 }
193
194
195 xAOD::EventInfo evtInfo;
196 xAOD::EventAuxInfo* pEvtInfoAux = new xAOD::EventAuxInfo();
197 evtInfo.setStore(pEvtInfoAux);
198
199 evtInfo.setRunNumber(runNumber);
200 evtInfo.setEventNumber(eventNumber);
201 evtInfo.setLumiBlock(lumiBlock);
202 evtInfo.setTimeStamp(bc_time_sec);
203 evtInfo.setTimeStampNSOffset(bc_time_ns);
204 evtInfo.setBCID(bcID);
205 evtInfo.setDetectorMask(detMask0,detMask1);
206 evtInfo.setDetectorMaskExt(detMask2,detMask3);
207
208 // Set default MC values (will be overwritten if MC ROB is present)
209 evtInfo.setMCChannelNumber(0);
210 evtInfo.setMCEventNumber(0);
211 evtInfo.setMCEventWeights(std::vector<float>(1,1));
212
213 // Set Event Type
214 uint32_t eventTypeBitmask{0};
215 if (m_isSimulation) {
216 eventTypeBitmask |= xAOD::EventInfo::IS_SIMULATION;
217 }
218 if (m_isTestbeam) {
219 eventTypeBitmask |= xAOD::EventInfo::IS_TESTBEAM;
220 }
221 if (m_isCalibration) {
222 eventTypeBitmask |= xAOD::EventInfo::IS_CALIBRATION;
223 }
224 evtInfo.setEventTypeBitmask(eventTypeBitmask);
225
226 // Try to decode MC EventInfo from dedicated ROB fragment (for MC ByteStream files)
227 bool mcEventInfoDecoded = false;
228 if (m_isSimulation && m_mcEventInfoTool.isEnabled()) {
229 // Request the MC EventInfo ROB
230 std::vector<uint32_t> mcRobIds = m_mcEventInfoTool->robIds();
231 std::vector<const OFFLINE_FRAGMENTS_NAMESPACE::ROBFragment*> mcRobFragments;
232 m_robDataProvider->getROBData(Gaudi::Hive::currentContext(), mcRobIds, mcRobFragments, "EventInfoByteStreamAuxCnv");
233
234 if (!mcRobFragments.empty()) {
235 ATH_MSG_DEBUG("Found MC EventInfo ROB fragment, decoding...");
236 StatusCode sc = m_mcEventInfoTool->convertFromBS(mcRobFragments[0], evtInfo);
237 if (sc.isFailure()) {
238 ATH_MSG_WARNING("Failed to decode MC EventInfo from ROB fragment, using default values");
239 } else {
240 ATH_MSG_DEBUG("Successfully decoded MC EventInfo from ROB fragment");
241 mcEventInfoDecoded = true;
242 }
243 } else {
244 ATH_MSG_DEBUG("No MC EventInfo ROB fragment found, using default values");
245 }
246 }
247
248 // Trigger Info
250 // status element
251 re->status(buffer);
252 uint32_t statusElement = *buffer;
253
254 // extended LVL1ID
255 uint32_t extendedLevel1ID = re->lvl1_id();
256
257 // LVL1 trigger type
258 uint32_t level1TriggerType = re->lvl1_trigger_type();
259
260 // stream tag
261 std::vector<xAOD::EventInfo::StreamTag> streamTags;
262 std::vector<eformat::helper::StreamTag> onl_streamTags;
263 re->stream_tag(buffer);
264 eformat::helper::decode(re->nstream_tag(), buffer, onl_streamTags);
265 for (const eformat::helper::StreamTag& onl_streamTag : onl_streamTags) {
266 std::set<uint32_t> tmp_off_dets = std::set<uint32_t>();
267 if (!onl_streamTag.dets.empty()) {
268 std::set<eformat::SubDetector> tmp_onl_dets = onl_streamTag.dets;
269 for (const eformat::SubDetector& subdet : tmp_onl_dets) {
270 tmp_off_dets.insert((uint32_t) subdet);
271 }
272 }
273 streamTags.push_back(xAOD::EventInfo::StreamTag(onl_streamTag.name
274 , onl_streamTag.type
275 , onl_streamTag.obeys_lumiblock
276 , onl_streamTag.robs
277 , tmp_off_dets)
278 );
279 }
280
281 evtInfo.setStatusElement(statusElement);
282 // Only set extendedLevel1ID from RawEvent header if MC EventInfo wasn't decoded
283 // (MC EventInfo ROB contains the original extendedLevel1ID value)
284 if (!mcEventInfoDecoded) {
285 evtInfo.setExtendedLevel1ID(extendedLevel1ID);
286 }
287 evtInfo.setLevel1TriggerType(level1TriggerType);
288 evtInfo.setStreamTags(streamTags);
289
290 // record EventInfo
291 evtInfo.setEventFlags(xAOD::EventInfo::Core, m_robDataProvider->getEventStatus(Gaudi::Hive::currentContext()));
292 pObj = SG::asStorable(pEvtInfoAux);
293
294 ATH_MSG_DEBUG(" New xAOD::EventAuxInfo made, run/event= " << runNumber
295 << " " << eventNumber
296 << " Time stamp = " << ascTime(bc_time_sec)
297 );
298
299 return StatusCode::SUCCESS;
300}
const boost::regex re(r_e)
#define ATH_MSG_ERROR(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
ByteStreamMetadataContainer
static Double_t sc
OFFLINE_FRAGMENTS_NAMESPACE::FullEventFragment RawEvent
data type for reading raw event
Definition RawEvent.h:37
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
std::string ascTime(unsigned int t)
convert timestamp to ascii time.
ToolHandle< IMCEventInfoByteStreamTool > m_mcEventInfoTool
Tool for decoding MC EventInfo from ROB.
void setBCID(uint32_t value)
Set the bunch crossing ID of the event.
void setDetectorMask(uint32_t mask0, uint32_t mask1)
Set the bit fields indicating with TTC timezones were present.
void setTimeStampNSOffset(uint32_t value)
Set the nanosecond offset wrt. the time stamp.
void setMCEventNumber(uint64_t value)
Set the MC generator's event number.
@ Core
Core flags describing the event.
void setStreamTags(const std::vector< StreamTag > &value)
Set the streams that the event was put in.
void setTimeStamp(uint32_t value)
Set the POSIX time of the event.
void setLevel1TriggerType(uint16_t value)
Set the Level-1 trigger type.
bool setEventFlags(EventFlagSubDet subDet, uint32_t flags)
Set the event flags for a particular sub-detector.
void setDetectorMaskExt(uint32_t mask2, uint32_t mask3)
Set the bit fields indicating with TTC timezones were present.
void setEventNumber(uint64_t value)
Set the current event's event number.
void setEventTypeBitmask(uint32_t value)
Set the event type bitmask.
void setMCChannelNumber(uint32_t value)
Set the MC generator's channel number.
void setExtendedLevel1ID(uint32_t value)
Set the extended Level-1 identifier.
void setMCEventWeights(const std::vector< float > &value)
Set the weights of all the MC events used in the simulation.
void setRunNumber(uint32_t value)
Set the current event's run number.
@ IS_CALIBRATION
true: calibration, false: physics
@ IS_SIMULATION
true: simulation, false: data
@ IS_TESTBEAM
true: testbeam, false: full detector
void setStatusElement(uint32_t value)
Set the trigger status element.
void setLumiBlock(uint32_t value)
Set the current event's luminosity block number.
::StatusCode StatusCode
StatusCode definition for legacy code.
DataObject * asStorable(SG::DataObjectSharedPtr< T > pObject)
status
Definition merge.py:16
EventInfo_v1 EventInfo
Definition of the latest event info version.
setTeId lumiBlock
setWord1 uint16_t
EventAuxInfo_v3 EventAuxInfo
Definition of the latest event auxiliary info version.
setEventNumber uint32_t

◆ createRep()

StatusCode EventInfoByteStreamAuxCnv::createRep ( DataObject * pObj,
IOpaqueAddress *& pAddr )
overridevirtual

converter method to write object

Definition at line 302 of file EventInfoByteStreamAuxCnv.cxx.

303{
304 ATH_MSG_DEBUG("createRep for xAOD::EventAuxInfo");
305
306 // For MC ByteStream files, create the MC EventInfo ROB fragment
307 if (m_isSimulation && m_mcEventInfoTool.isEnabled()) {
308 ATH_MSG_DEBUG("Creating MC EventInfo ROB fragment for simulation");
309
310 // Get RawEventWrite via ByteStreamCnvSvc
311 SmartIF<IByteStreamEventAccess> byteStreamCnvSvc(service("ByteStreamCnvSvc"));
312 if (!byteStreamCnvSvc.isValid()) {
313 ATH_MSG_ERROR("Failed to retrieve ByteStreamCnvSvc");
314 return StatusCode::FAILURE;
315 }
316 RawEventWrite* re = byteStreamCnvSvc->getRawEvent();
317 if (!re) {
318 ATH_MSG_ERROR("Failed to get RawEventWrite");
319 return StatusCode::FAILURE;
320 }
321
322 // Create MC EventInfo ROB fragment
323 std::vector<OFFLINE_FRAGMENTS_NAMESPACE_WRITE::ROBFragment*> mcRobs;
324 ATH_CHECK(m_mcEventInfoTool->convertToBS(mcRobs, Gaudi::Hive::currentContext()));
325
326 // Append ROB fragments to the event
327 for (auto* rob : mcRobs) {
328 // Set LVL1 ID and trigger type from the full event
329 rob->rod_lvl1_id(re->lvl1_id());
330 rob->rod_lvl1_type(re->lvl1_trigger_type());
331 re->append(rob);
332 ATH_MSG_DEBUG("Added MC EventInfo ROB fragment to output event");
333 }
334 }
335
336 return StatusCode::SUCCESS;
337}
#define ATH_CHECK
Evaluate an expression and check for errors.
OFFLINE_FRAGMENTS_NAMESPACE_WRITE::FullEventFragment RawEventWrite
data type for writing raw event
Definition RawEvent.h:39

◆ finalize()

StatusCode EventInfoByteStreamAuxCnv::finalize ( )
overridevirtual

Definition at line 112 of file EventInfoByteStreamAuxCnv.cxx.

113{
114 ATH_MSG_DEBUG("Finalize");
115
116 StatusCode sc = Converter::finalize();
117 if (sc.isFailure()) {
118 ATH_MSG_WARNING("Converter::finalize() failed");
119 }
120 return sc;
121}

◆ initialize()

StatusCode EventInfoByteStreamAuxCnv::initialize ( )
overridevirtual

Definition at line 52 of file EventInfoByteStreamAuxCnv.cxx.

53{
54 ATH_MSG_DEBUG("Initialize");
55
56 CHECK(Converter::initialize());
57
58 CHECK(m_robDataProvider.retrieve());
59 CHECK(m_mdSvc.retrieve());
60
61 SmartIF<IProperty> byteStreamCnvSvc(service("ByteStreamCnvSvc"));
62 CHECK( byteStreamCnvSvc.isValid() );
63
64 SimpleProperty<bool> propIsSimulation("IsSimulation", m_isSimulation);
65 StatusCode sc = byteStreamCnvSvc->getProperty(&propIsSimulation);
66 if (sc.isSuccess()) {
67 m_isSimulation = propIsSimulation.value();
68 ATH_MSG_INFO("IsSimulation : " << m_isSimulation);
69 }
70 else {
71 ATH_MSG_ERROR("Cannot get IsSimulation");
72 return sc;
73 }
74
75 SimpleProperty<bool> propIsTestbeam("IsTestbeam", m_isTestbeam);
76 sc = byteStreamCnvSvc->getProperty(&propIsTestbeam);
77 if (sc.isSuccess()) {
78 m_isTestbeam = propIsTestbeam.value();
79 ATH_MSG_INFO("IsTestbeam : " << m_isTestbeam);
80 }
81 else {
82 ATH_MSG_ERROR("Cannot get IsTestbeam");
83 return sc;
84 }
85
86 SimpleProperty<bool> propIsCalibration("IsCalibration", m_isCalibration);
87 sc = byteStreamCnvSvc->getProperty(&propIsCalibration);
88 if (sc.isSuccess()) {
89 m_isCalibration = propIsCalibration.value();
90 ATH_MSG_INFO("IsCalibration : " << m_isCalibration);
91 }
92 else {
93 ATH_MSG_ERROR("Cannot get IsCalibration");
94 return sc;
95 }
96
97 // Retrieve MC EventInfo decoder tool (optional - only needed for MC BS files)
98 if (m_isSimulation) {
99 if (m_mcEventInfoTool.retrieve().isFailure()) {
100 ATH_MSG_WARNING("Failed to retrieve MCEventInfoByteStreamTool - MC EventInfo will use default values");
101 m_mcEventInfoTool.disable();
102 } else {
103 ATH_MSG_DEBUG("MCEventInfoByteStreamTool retrieved successfully");
104 }
105 } else {
106 m_mcEventInfoTool.disable();
107 }
108
109 return StatusCode::SUCCESS;
110}
#define ATH_MSG_INFO(x)
#define CHECK(...)
Evaluate an expression and check for errors.

◆ 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 // If user did not set an explicit level, set a default
43 if (m_lvl == MSG::NIL) {
44 m_lvl = m_imsg ?
45 static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
46 MSG::INFO;
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
266 d0c = d0 + m_beamX*sn - m_beamY*cs;
267
268 } else {
269
270 double rc = fabs(pt)*15.0/(9.0*1.042);
271
272 double xc = (fabs(d0)-spt*sd0*rc)*cos(phi0+M_PI/2*sd0) - m_beamX;
273 double yc = (fabs(d0)-spt*sd0*rc)*sin(phi0+M_PI/2*sd0) - m_beamY;
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
296 double phi1 = phiCorr(phiV+M_PI/2);
297 double phi2 = phiCorr(phiV-M_PI/2);
298
299 if (fabs(phiCorr(phi1-phi0))<=fabs(phiCorr(phi2-phi0)))
300 newphi = phi1;
301 else
302 newphi = phi2;
303
304 d0c = fabs(sqrt(xc*xc+yc*yc)-rc)*sin(phiV-newphi);
305
306 double theta=2*atan2(exp(-eta),1);
307 double theta_save=theta;
308 theta = theta - (1+spt)/2*M_PI;
309 if (theta>0) theta = theta_save;
310
311 double deltaz0= -spt*rc/tan(theta)*phiCorr(phiCorr(newphi)-phiCorr(phi0));
312 z0c = z0 + deltaz0;
313
314 }
315 }
#define M_PI
Scalar eta() const
pseudorapidity method
Scalar theta() const
theta method
static Double_t rc
double m_beamX
Definition Converter.h:320
double phiCorr(double phi)
Definition Converter.h:248
double m_beamY
Definition Converter.h:320
constexpr int pow(int x)
Definition conifer.h:27

◆ 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 167 of file AthMessaging.h.

168{
169 MsgStream* ms = m_msg_tls.get();
170 if (!ms) {
171 if (!m_initialized.test_and_set()) initMessaging();
172 ms = new MsgStream(m_imsg,m_nm);
173 m_msg_tls.reset( ms );
174 }
175
176 ms->setLevel (m_lvl);
177 return *ms;
178}
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 182 of file AthMessaging.h.

183{ 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
lvlThe message level to test against
Returns
boolean Indicating if messages at given level will be printed
Return values
trueMessages at level "lvl" will be printed

Definition at line 151 of file AthMessaging.h.

152{
153 // If user did not set explicit message level we have to initialize
154 // the messaging and retrieve the default via the MessageSvc.
155 if (m_lvl==MSG::NIL && !m_initialized.test_and_set()) initMessaging();
156
157 if (m_lvl <= lvl) {
158 msg() << lvl;
159 return true;
160 } else {
161 return false;
162 }
163}

◆ 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
253 return phi;
254 }
Scalar phi() const
phi method

◆ repSvcType()

virtual long EventInfoByteStreamAuxCnv::repSvcType ( ) const
inlineoverridevirtual

Storage type and class ID.

Definition at line 50 of file EventInfoByteStreamAuxCnv.h.

50{ return i_repSvcType(); }

◆ selectTracks() [1/3]

void Converter::selectTracks ( const Analysis::MuonContainer * muontracks)
inlineinherited

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
181 Analysis::MuonContainer::const_iterator muonitr = muontracks->begin();
182 Analysis::MuonContainer::const_iterator muonend = muontracks->end();
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
192 const Trk::MeasuredPerigee* measPer = trackitr->measuredPerigee();
193
194 CLHEP::HepVector perigeeParams = measPer->parameters();
195 double pT = measPer->pT();
196 double eta = measPer->eta();
197 double phi = perigeeParams[Trk::phi0];
198 double z0 = perigeeParams[Trk::z0];
199 double d0 = perigeeParams[Trk::d0];
200 //double theta = perigeeParams[Trk::theta];
201
202 double deta = 1;
203 double dphi = 1;
204 double dz0 = 1;
205 double dd0 = 1;
206 double dpT = 1;
207
208 // Check number of hits
209 // NB: a spacepoint is two offline "hits", so a pixel spacepoint is really
210 // 2 "hits" and an offline SCT "hit" is really a 1D cluster, so two intersetcting
211 // stereo clusters making a spacepoint are two "hits"
212 const Trk::TrackSummary *summary = trackitr->trackSummary();
213 int nBlayerHits = 2*summary->get(Trk::numberOfBLayerHits);
215 int nSctHits = summary->get(Trk::numberOfSCTHits);
216 int nStrawHits = summary->get(Trk::numberOfTRTHits);
217 int nTrHits = summary->get(Trk::numberOfTRTHighThresholdHits);
218
219 int nSiHits = nPixelHits + nSctHits;
220
221 const Trk::FitQuality *quality = trackitr->fitQuality();
222 double chi2 = quality->chiSquared();
223 double dof = quality->quality->numberDoF();
224
225 unsigned bitmap = 0;
226
227 for ( int ih=0 ; ih<20 ; ih++ ) {
228 if ( summary->isHit(Trk::DetectorType(ih)) ) bitmap |= ( 1<<hpmap[ih] );
229 }
230
231 // Shift d0 and z0 according to beam position
232 ipCorr(d0, z0, d0, z0, phi, eta, pT);
233
234 // Create and save Track
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
241 addTrack(t);
242 }
243
244 }
void addTrack(TIDA::Track *t)
Definition Converter.h:45
void ipCorr(double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
Definition Converter.h:257
DataModel_detail::const_iterator< DataVector > const_iterator
Definition DataVector.h:838
const_iterator end() const noexcept
Return a const_iterator pointing past the end 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
Definition FitQuality.h:60
double chiSquared() const
returns the of the overall track fit
Definition FitQuality.h:56
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)
Perigee MeasuredPerigee
@ phi0
Definition ParamDefs.h:65
@ d0
Definition ParamDefs.h:63
@ z0
Definition ParamDefs.h:64
DetectorType
enumerates the various detector types currently accessible from the isHit() method.
@ numberOfPixelHits
number of pixel layers on track with absence of hits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?
@ numberOfTRTHighThresholdHits
total number of TRT hits which pass the high threshold

◆ selectTracks() [2/3]

void Converter::selectTracks ( const Rec::TrackParticleContainer * trigtracks)
inlineinherited

Definition at line 111 of file Converter.h.

111 {
112
113 Rec::TrackParticleContainer::const_iterator trackitr = trigtracks->begin();
114 Rec::TrackParticleContainer::const_iterator trackend = trigtracks->end();
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
120 const Trk::MeasuredPerigee* measPer = (*trackitr)->measuredPerigee();
121
122 CLHEP::HepVector perigeeParams = measPer->parameters();
123 double pT = measPer->pT();
124 double eta = measPer->eta();
125 double phi = perigeeParams[Trk::phi0];
126 double z0 = perigeeParams[Trk::z0];
127 double d0 = perigeeParams[Trk::d0];
128 //double theta = perigeeParams[Trk::theta];
129
130 double deta = 1;
131 double dphi = 1;
132 double dz0 = 1;
133 double dd0 = 1;
134 double dpT = 1;
135
136 // Check number of hits
137 // NB: a spacepoint is two offline "hits", so a pixel spacepoint is really
138 // 2 "hits" and an offline SCT "hit" is really a 1D cluster, so two intersetcting
139 // stereo clusters making a spacepoint are two "hits"
140 const Trk::TrackSummary *summary = (*trackitr)->trackSummary();
141 int nBlayerHits = 2*summary->get(Trk::numberOfBLayerHits);
143 int nSctHits = summary->get(Trk::numberOfSCTHits);
144 int nStrawHits = summary->get(Trk::numberOfTRTHits);
145 int nTrHits = summary->get(Trk::numberOfTRTHighThresholdHits);
146 int nSiHits = nPixelHits + nSctHits;
147 bool expectBL = false; // Not stored for Rec::TrackParticle
148
149 const Trk::FitQuality *quality = (*trackitr)->fitQuality();
150 double chi2 = quality->chiSquared();
151 double dof = quality->numberDoF();
152
153 unsigned bitmap = 0;
154
155 for ( int ih=0 ; ih<20 ; ih++ ) {
156 if ( summary->isHit(Trk::DetectorType(ih)) ) bitmap |= ( 1<<hpmap[ih] );
157 }
158
159 // Shift d0 and z0 according to beam position
160 ipCorr(d0, z0, d0, z0, phi, eta, pT);
161
162 // Create and save Track
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
170 addTrack(t);
171 trackitr++;
172 }
173
174 }

◆ selectTracks() [3/3]

void Converter::selectTracks ( const TrigInDetTrackCollection * trigtracks)
inlineinherited

Definition at line 56 of file Converter.h.

56 {
57
58 TrigInDetTrackCollection::const_iterator trackitr = trigtracks->begin();
59 TrigInDetTrackCollection::const_iterator trackend = trigtracks->end();
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 //double theta = 2*atan2(exp(-(*trackitr)->param()->eta()),1);
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(); // NB: for comparison with offline
80 int nSctHits = 2*(*trackitr)->NSCT_SpacePoints(); // a spacepoint is 2 "hits"
81 int nStrawHits = (*trackitr)->NStrawHits();
82 int nTrHits = (*trackitr)->NTRHits();
83
84 int nSiHits = nPixelHits + nSctHits;
85 bool expectBL = false; //not available with TrigInDetTrack
86
87 unsigned hitPattern = (*trackitr)->HitPattern();
88 unsigned multiPattern = 0;
89
90 double chi2 = (*trackitr)->chi2();
91 double dof = 0;
92
93 // Shift d0 and z0 according to beam position
94 ipCorr(d0, z0, d0, z0, phi, eta, pT);
95
96 // Create and save Track
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
104 addTrack(t);
105 trackitr++;
106 }
107 }

◆ setLevel()

void AthMessaging::setLevel ( MSG::Level lvl)
inherited

Change the current logging level.

Use this rather than msg().setLevel() for proper operation with MT.

Definition at line 28 of file AthMessaging.cxx.

29{
30 m_lvl = lvl;
31}

◆ storageType()

long EventInfoByteStreamAuxCnv::storageType ( )
static

Definition at line 47 of file EventInfoByteStreamAuxCnv.cxx.

48{
50}
static constexpr long storageType()

◆ tracks()

const std::vector< TIDA::Track * > & Converter::tracks ( ) const
inlineinherited

Definition at line 50 of file Converter.h.

50{return m_tracks;}

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
mutableprivateinherited

Messaging initialized (initMessaging).

Definition at line 141 of file AthMessaging.h.

◆ m_beamX

double Converter::m_beamX
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_beamY

double Converter::m_beamY
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_beamZ

double Converter::m_beamZ
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_imsg

std::atomic<IMessageSvc*> AthMessaging::m_imsg { nullptr }
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_isCalibration

bool EventInfoByteStreamAuxCnv::m_isCalibration
private

Definition at line 63 of file EventInfoByteStreamAuxCnv.h.

◆ m_isSimulation

bool EventInfoByteStreamAuxCnv::m_isSimulation
private

Definition at line 61 of file EventInfoByteStreamAuxCnv.h.

◆ m_isTestbeam

bool EventInfoByteStreamAuxCnv::m_isTestbeam
private

Definition at line 62 of file EventInfoByteStreamAuxCnv.h.

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl { MSG::NIL }
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

138{ MSG::NIL };

◆ m_mcEventInfoTool

ToolHandle<IMCEventInfoByteStreamTool> EventInfoByteStreamAuxCnv::m_mcEventInfoTool {"MCEventInfoByteStreamTool"}
private

Tool for decoding MC EventInfo from ROB.

Definition at line 58 of file EventInfoByteStreamAuxCnv.h.

58{"MCEventInfoByteStreamTool"};

◆ m_mdSvc

ServiceHandle<StoreGateSvc> EventInfoByteStreamAuxCnv::m_mdSvc
private

TDS handle.

Definition at line 57 of file EventInfoByteStreamAuxCnv.h.

◆ 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_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_robDataProvider

ServiceHandle<IROBDataProviderSvc> EventInfoByteStreamAuxCnv::m_robDataProvider
private

RODDataProviderSvc handle.

Definition at line 56 of file EventInfoByteStreamAuxCnv.h.

◆ m_tracks

std::vector<TIDA::Track*> Converter::m_tracks
protectedinherited

Definition at line 321 of file Converter.h.


The documentation for this class was generated from the following files: