ATLAS Offline Software
Loading...
Searching...
No Matches
HLT::HLTResultMTByteStreamCnv Class Reference

ByteStream converter for HLTResultMT. More...

#include <HLTResultMTByteStreamCnv.h>

Inheritance diagram for HLT::HLTResultMTByteStreamCnv:
Collaboration diagram for HLT::HLTResultMTByteStreamCnv:

Classes

struct  Cache
 Cache tracking memory allocation for serialised stream tag data and ROBFragment objects. More...

Public Member Functions

 HLTResultMTByteStreamCnv (ISvcLocator *svcLoc)
 Standard constructor.
virtual ~HLTResultMTByteStreamCnv ()
 Standard destructor.
virtual StatusCode initialize () override
virtual StatusCode finalize () override
virtual StatusCode createObj (IOpaqueAddress *pAddr, DataObject *&pObj) override
 Create RDO (HLTResultMT) from ByteStream.
virtual StatusCode createRep (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Create ByteStream from RDO (HLTResultMT)
long repSvcType () const override
 return repSvcType
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 ()
 Storage type used by this converter.
static const CLIDclassID ()
 CLID of the class HLTResultMT converted by this converter.

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

void initMessaging () const
 Initialize our message level and MessageSvc.

Private Attributes

ServiceHandle< IByteStreamEventAccessm_ByteStreamEventAccess
 Helper to obtain the RawEvent pointer.
SG::SlotSpecificObj< Cachem_cache
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 HLTResultMT.

Definition at line 21 of file HLTResultMTByteStreamCnv.h.

Constructor & Destructor Documentation

◆ HLTResultMTByteStreamCnv()

HLT::HLTResultMTByteStreamCnv::HLTResultMTByteStreamCnv ( ISvcLocator * svcLoc)

Standard constructor.

Definition at line 51 of file HLTResultMTByteStreamCnv.cxx.

51 :
52 Converter(storageType(), classID(), svcLoc),
53 AthMessaging(msgSvc(), "HLTResultMTByteStreamCnv"),
54 m_ByteStreamEventAccess("ByteStreamCnvSvc", "HLTResultMTByteStreamCnv") {}
AthMessaging()
Default constructor:
static const CLID & classID()
CLID of the class HLTResultMT converted by this converter.
static long storageType()
Storage type used by this converter.
ServiceHandle< IByteStreamEventAccess > m_ByteStreamEventAccess
Helper to obtain the RawEvent pointer.
msgSvc
Provide convenience handles for various services.
Definition StdJOSetup.py:36

◆ ~HLTResultMTByteStreamCnv()

HLT::HLTResultMTByteStreamCnv::~HLTResultMTByteStreamCnv ( )
virtual

Standard destructor.

Definition at line 59 of file HLTResultMTByteStreamCnv.cxx.

59{}

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

◆ classID()

const CLID & HLT::HLTResultMTByteStreamCnv::classID ( )
static

CLID of the class HLTResultMT converted by this converter.

Definition at line 253 of file HLTResultMTByteStreamCnv.cxx.

◆ clear()

void Converter::clear ( )
inlineinherited

Definition at line 53 of file Converter.h.

53{m_tracks.clear();}

◆ createObj()

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

Create RDO (HLTResultMT) from ByteStream.

Definition at line 85 of file HLTResultMTByteStreamCnv.cxx.

85 {
86 ATH_MSG_ERROR("Using BS converter to decode HLTResultMT is not supported!"
87 << " Use HLTResultMTByteStreamDecoderAlg instead");
88 return StatusCode::FAILURE;
89}
#define ATH_MSG_ERROR(x)

◆ createRep()

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

Create ByteStream from RDO (HLTResultMT)

Definition at line 94 of file HLTResultMTByteStreamCnv.cxx.

94 {
95 ATH_MSG_VERBOSE("start of " << __FUNCTION__);
96
97 // Find the cache corresponding to the current slot
98 Cache* cache = m_cache.get(); // TODO: find a way to avoid using thread-local context here
99
100 // Clear the cache which is required to remain valid between being filled here
101 // and sending out the correspoding RawEventWrite in (Trig)ByteStreamCnvSvc::commitOutput
102 cache->clear();
103
104 // Cast the DataObject to HLTResultMT
105 HLT::HLTResultMT* hltResult = nullptr;
106 bool castSuccessful = SG::fromStorable(pObj, hltResult);
107 if (!castSuccessful || !hltResult) {
108 ATH_MSG_ERROR("Failed to convert DataObject to HLTResultMT");
109 return StatusCode::FAILURE;
110 }
111
112 // Check ROD minor version
113 const HLT::HLTResultMT::RODMinorVersion hltRodMinorVersion = hltResult->getVersion();
114 if (hltRodMinorVersion == HLT::HLTResultMT::RODMinorVersion{0xff,0xff}) {
115 ATH_MSG_ERROR("Invalid HLT ROD minor version {0xff, 0xff}");
116 return StatusCode::FAILURE;
117 }
118 // Encode version X.Y (two 8-bit numbers) into a single 16-bit number
119 const uint16_t hltRodMinorVersion16 = (hltRodMinorVersion.first << 8u) | hltRodMinorVersion.second;
120 ATH_MSG_DEBUG("HLT ROD minor version is " << hltRodMinorVersion.first << "." << hltRodMinorVersion.second
121 << " (0x" << MSG::hex << hltRodMinorVersion16 << MSG::dec << ")");
122
123 // Obtain the RawEventWrite (aka eformat::write::FullEventFragment) pointer
124 RawEventWrite* re = m_ByteStreamEventAccess->getRawEvent();
125 if (!re) {
126 ATH_MSG_ERROR("Failed to obtain a pointer to RawEventWrite");
127 return StatusCode::FAILURE;
128 }
129 ATH_MSG_VERBOSE("Obtained RawEventWrite pointer = " << re);
130
131 // Fill the status words (error code)
132 re->status(hltResult->getStatus().size(), hltResult->getStatus().data());
133
134 // Read the stream tags to check for debug stream tag and decide which HLT ROBFragments to write out
135 std::set<eformat::helper::SourceIdentifier> resultIdsToWrite;
136 bool debugEvent=false;
137 std::string unknownTypeStreams;
138 for (const eformat::helper::StreamTag& st : hltResult->getStreamTags()) {
139 // Flag events with unknown stream type
140 if (isUnknownStreamTag(st)) {
141 unknownTypeStreams += st.type + "_" + st.name + " ";
142 }
143 // Flag debug stream events
144 if (isDebugStreamTag(st)) debugEvent=true;
145 // In case of full event building, add the full result ID
146 if (st.robs.empty() && st.dets.empty()) {
147 eformat::helper::SourceIdentifier sid(eformat::SubDetector::TDAQ_HLT, fullResultModuleId);
148 resultIdsToWrite.insert(sid);
149 }
150 // In case of partial event building, add the results explicitly requested in the stream tag
151 for (const uint32_t robid : st.robs) {
152 eformat::helper::SourceIdentifier sid(robid);
153 if (sid.subdetector_id() == eformat::SubDetector::TDAQ_HLT)
154 resultIdsToWrite.insert(sid);
155 }
156 }
157 // Fail if the event is not already failed (debug stream) and unknown stream type was found
158 if (!debugEvent && !unknownTypeStreams.empty()) {
159 ATH_MSG_ERROR("Found stream tag(s) with unknown type: " << unknownTypeStreams);
160 return StatusCode::FAILURE;
161 }
162
163 // If the event goes to the debug stream, remove all non-debug stream tags
164 // and force full event building in all debug streams
165 if (debugEvent) {
166 std::vector<eformat::helper::StreamTag>& writableStreamTags = hltResult->getStreamTagsNonConst();
167 writableStreamTags.erase(
168 std::remove_if(writableStreamTags.begin(),writableStreamTags.end(),std::not_fn(isDebugStreamTag)),
169 writableStreamTags.end()
170 );
171 for (eformat::helper::StreamTag& st : writableStreamTags) {
172 st.robs.clear();
173 st.dets.clear();
174 }
175 }
176
177 // Fill the stream tags
178 uint32_t nStreamTagWords = eformat::helper::size_word(hltResult->getStreamTags());
179 cache->streamTagData = std::make_unique<uint32_t[]>(nStreamTagWords);
180 try {
181 // encode can throw exceptions if the encoding fails
182 eformat::helper::encode(hltResult->getStreamTags(),nStreamTagWords,cache->streamTagData.get());
183 }
184 catch (const std::exception& e) {
185 ATH_MSG_ERROR("StreamTag encoding failed, caught an unexpected std::exception " << e.what());
186 return StatusCode::FAILURE;
187 }
188 catch (...) {
189 ATH_MSG_ERROR("StreamTag encoding failed, caught an unexpected exception");
190 return StatusCode::FAILURE;
191 }
192 ATH_MSG_DEBUG("Encoded the stream tags successfully");
193 re->stream_tag(nStreamTagWords, cache->streamTagData.get());
194
195 // Fill the HLT bits
196 const std::vector<uint32_t>& hltBits = hltResult->getHltBitsAsWords();
197 re->hlt_info(hltBits.size(), hltBits.data());
198
199 // Loop over the module IDs and fill the ROBFragments
200 ATH_MSG_DEBUG("Iterating over " << resultIdsToWrite.size() << " HLT result IDs to assemble output data");
201 const std::unordered_map<uint16_t, std::vector<uint32_t>>& serialisedData = hltResult->getSerialisedData();
202 for (const eformat::helper::SourceIdentifier& resultId : resultIdsToWrite) {
203 // Find the serialised data for this module ID
204 const auto it = serialisedData.find(resultId.module_id());
205 if (it==serialisedData.end()) {
206 if (debugEvent) {
207 ATH_MSG_DEBUG("HLT result with ID 0x" << MSG::hex << resultId.code() << MSG::dec
208 << " requested by a debug stream tag, but missing in the serialised data - skipping this result");
209 continue;
210 }
211 ATH_MSG_ERROR("HLT result with ID 0x" << MSG::hex << resultId.code() << MSG::dec
212 << " requested by a stream tag, but missing in the serialised data");
213 return StatusCode::FAILURE;
214 }
215 const std::vector<uint32_t>& data = it->second;
216
217 // Create an HLT ROBFragment and append it to the full event
218 auto hltROB = std::make_unique<OFFLINE_FRAGMENTS_NAMESPACE_WRITE::ROBFragment>(
219 resultId.code(),
220 re->run_no(),
221 re->lvl1_id(),
222 re->bc_id(),
223 re->lvl1_trigger_type(),
224 0, // detev_type not used by HLT
225 data.size(),
226 data.data(),
227 eformat::STATUS_BACK
228 );
229 hltROB->rod_minor_version(hltRodMinorVersion16);
230 // Fill the ROB status words
231 const std::vector<uint32_t>& status = hltResult->getRobStatus(resultId.module_id());
232 hltROB->status(status.size(), status.data());
233
234 re->append(hltROB.get());
235 cache->robFragments.push_back(std::move(hltROB));
236 ATH_MSG_DEBUG("Appended data for HLT result ID 0x" << MSG::hex << resultId.code() << MSG::dec << " with "
237 << data.size() << " words of serialised payload to the output full event");
238 }
239
240 // Create a ByteStreamAddress for HLTResultMT
241 if ( pAddr != nullptr ) pAddr->release();
242 ByteStreamAddress* bsAddr = new ByteStreamAddress(classID(), pObj->registry()->name(), "");
243 pAddr = static_cast<IOpaqueAddress*>(bsAddr);
244 pAddr->addRef();
245
246 ATH_MSG_VERBOSE("end of " << __FUNCTION__);
247 return StatusCode::SUCCESS;
248}
const boost::regex re(r_e)
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_DEBUG(x)
char data[hepevt_bytes_allocation_ATLAS]
Definition HepEvt.cxx:11
OFFLINE_FRAGMENTS_NAMESPACE_WRITE::FullEventFragment RawEventWrite
data type for writing raw event
Definition RawEvent.h:39
SG::SlotSpecificObj< Cache > m_cache
const std::vector< uint32_t > & getHltBitsAsWords() const
Const-getter for HLT bits as uint32_t array. Ordering: PassRaw, Prescaled.
RODMinorVersion getVersion() const
ROD minor version getter.
const std::vector< eformat::helper::StreamTag > & getStreamTags() const
Const-getter for stream tags.
std::pair< uint8_t, uint8_t > RODMinorVersion
Type to store decoded ROD minor version (16-bit version split into two 8-bit numbers)
Definition HLTResultMT.h:50
const std::unordered_map< uint16_t, std::vector< uint32_t > > & getSerialisedData() const
Serialised data getter.
const std::vector< uint32_t > & getStatus() const
Full event status reference getter (1 bit-mask status word + error code words)
const std::vector< uint32_t > & getRobStatus(uint16_t moduleId) const
Status words for ROB with given moduleId.
std::vector< eformat::helper::StreamTag > & getStreamTagsNonConst()
Non-const-getter for stream tags needed by the result maker to remove disabled ROBs/SubDets.
bool fromStorable(DataObject *pDObj, T *&pTrans, bool quiet=false, IRegisterTransient *irt=0, bool isConst=true)
status
Definition merge.py:16
DataModel_detail::iterator< DVL > remove_if(typename DataModel_detail::iterator< DVL > beg, typename DataModel_detail::iterator< DVL > end, Predicate pred)
Specialization of remove_if for DataVector/List.
setWord1 uint16_t
setEventNumber uint32_t
Cache tracking memory allocation for serialised stream tag data and ROBFragment objects.

◆ finalize()

StatusCode HLT::HLTResultMTByteStreamCnv::finalize ( )
overridevirtual

Definition at line 74 of file HLTResultMTByteStreamCnv.cxx.

74 {
75 ATH_MSG_VERBOSE("start of " << __FUNCTION__);
76 if (m_ByteStreamEventAccess.release().isFailure())
77 ATH_MSG_WARNING("Failed to release service " << m_ByteStreamEventAccess.typeAndName());
78 ATH_MSG_VERBOSE("end of " << __FUNCTION__);
79 return StatusCode::SUCCESS;
80}
#define ATH_MSG_WARNING(x)

◆ initialize()

StatusCode HLT::HLTResultMTByteStreamCnv::initialize ( )
overridevirtual

Definition at line 64 of file HLTResultMTByteStreamCnv.cxx.

64 {
65 ATH_MSG_VERBOSE("start of " << __FUNCTION__);
67 ATH_MSG_VERBOSE("end of " << __FUNCTION__);
68 return StatusCode::SUCCESS;
69}
#define ATH_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
constexpr int pow(int base, int exp) noexcept
double m_beamX
Definition Converter.h:320
double phiCorr(double phi)
Definition Converter.h:248
double m_beamY
Definition Converter.h:320

◆ 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{
165 MsgStream* ms = m_msg_tls.get();
166 if (!ms) {
167 if (!m_initialized.test_and_set()) initMessaging();
168 ms = new MsgStream(m_imsg,m_nm);
169 m_msg_tls.reset( ms );
170 }
171
172 ms->setLevel (m_lvl);
173 return *ms;
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
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 (m_lvl <= lvl) {
154 msg() << lvl;
155 return true;
156 } else {
157 return false;
158 }
159}

◆ 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()

long HLT::HLTResultMTByteStreamCnv::repSvcType ( ) const
inlineoverride

return repSvcType

Definition at line 43 of file HLTResultMTByteStreamCnv.h.

◆ 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_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
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)
@ 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
Perigee MeasuredPerigee

◆ 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 HLT::HLTResultMTByteStreamCnv::storageType ( )
static

Storage type used by this converter.

Definition at line 257 of file HLTResultMTByteStreamCnv.cxx.

258{
260}
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_ByteStreamEventAccess

ServiceHandle<IByteStreamEventAccess> HLT::HLTResultMTByteStreamCnv::m_ByteStreamEventAccess
private

Helper to obtain the RawEvent pointer.

Definition at line 47 of file HLTResultMTByteStreamCnv.h.

◆ m_cache

SG::SlotSpecificObj<Cache> HLT::HLTResultMTByteStreamCnv::m_cache
private

Definition at line 61 of file HLTResultMTByteStreamCnv.h.

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ 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_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_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: