ATLAS Offline Software
Public Member Functions | Static Public Member Functions | Protected Member Functions | Protected Attributes | Private Member Functions | Private Attributes | List of all members
EventInfoByteStreamAuxCnv Class Reference

This is the class definition of ByteStream converter for xAOD::EventInfoAux Event Info is built from RawEvent when reading. Nothing is done when writing ByteStream. More...

#include <EventInfoByteStreamAuxCnv.h>

Inheritance diagram for EventInfoByteStreamAuxCnv:
Collaboration diagram for EventInfoByteStreamAuxCnv:

Public Member Functions

 EventInfoByteStreamAuxCnv (ISvcLocator *svcloc)
 
virtual ~EventInfoByteStreamAuxCnv () override
 
virtual StatusCode initialize () override
 
virtual StatusCode finalize () override
 
virtual StatusCode createObj (IOpaqueAddress *pAddr, DataObject *&pObj) override
 converter method to create object More...
 
virtual StatusCode createRep (DataObject *pObj, IOpaqueAddress *&pAddr) override
 converter method to write object More...
 
virtual long repSvcType () const override
 Storage type and class ID. More...
 
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. More...
 
MsgStream & msg () const
 The standard message stream. More...
 
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream. More...
 
void setLevel (MSG::Level lvl)
 Change the current logging level. More...
 

Static Public Member Functions

static long storageType ()
 
static const CLIDclassID ()
 

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. More...
 
void initMessaging () const
 Initialize our message level and MessageSvc. More...
 

Private Attributes

ByteStreamCnvSvcBasem_ByteStreamCnvSvc
 pointer to BS CnvSvc More...
 
ServiceHandle< IROBDataProviderSvcm_robDataProvider
 RODDataProviderSvc handle. More...
 
ServiceHandle< StoreGateSvcm_mdSvc
 TDS handle. More...
 
bool m_isSimulation
 
bool m_isTestbeam
 
bool m_isCalibration
 
std::string m_nm
 Message source name. More...
 
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels) More...
 
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer. More...
 
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level. More...
 
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging) More...
 

Detailed Description

This is the class definition of ByteStream converter for xAOD::EventInfoAux Event Info is built from RawEvent when reading. Nothing is done when writing ByteStream.

Definition at line 29 of file EventInfoByteStreamAuxCnv.h.

Constructor & Destructor Documentation

◆ EventInfoByteStreamAuxCnv()

EventInfoByteStreamAuxCnv::EventInfoByteStreamAuxCnv ( ISvcLocator *  svcloc)

Definition at line 30 of file EventInfoByteStreamAuxCnv.cxx.

31  : Converter(storageType(), classID(), svcloc)
32  , AthMessaging(svcloc != nullptr ? msgSvc() : nullptr, "EventInfoByteStreamAuxCnv")
33  , m_ByteStreamCnvSvc(nullptr)
34  , m_robDataProvider("ROBDataProviderSvc", "EventInfoByteStreamAuxCnv")
35  , m_mdSvc("InputMetaDataStore", "EventInfoByteStreamAuxCnv")
36  , m_isSimulation(false)
37  , m_isTestbeam(false)
38  , m_isCalibration(false)
39 {
40 }

◆ ~EventInfoByteStreamAuxCnv()

virtual EventInfoByteStreamAuxCnv::~EventInfoByteStreamAuxCnv ( )
inlineoverridevirtual

Definition at line 33 of file EventInfoByteStreamAuxCnv.h.

33 {}

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  }

◆ ascTime()

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

convert timestamp to ascii time.

Definition at line 281 of file EventInfoByteStreamAuxCnv.cxx.

282 {
283  struct tm t;
284  t.tm_sec = tstamp;
285  t.tm_min = 0;
286  t.tm_hour = 0;
287  t.tm_mday = 0;
288  t.tm_mon = 0;
289  t.tm_year = 70;
290  t.tm_wday = 00;
291  t.tm_yday = 00;
292  t.tm_isdst = 0;
293  time_t ct = mktime(&t);
294  struct tm t2;
295  gmtime_r(&ct, &t2);
296  char buf[32];
297  asctime_r (&t2, buf);
298  return std::string (buf);
299 }

◆ classID()

const CLID & EventInfoByteStreamAuxCnv::classID ( )
static

Definition at line 42 of file EventInfoByteStreamAuxCnv.cxx.

43 {
45 }

◆ 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 121 of file EventInfoByteStreamAuxCnv.cxx.

122 {
123  ByteStreamAddress *pRE_Addr{nullptr};
124  pRE_Addr = dynamic_cast<ByteStreamAddress*>(pAddr);
125  if (!pRE_Addr) {
126  ATH_MSG_ERROR("Cannot cast to ByteStreamAddress ");
127  return StatusCode::FAILURE;
128  }
129 
130  ATH_MSG_DEBUG("Creating Objects");
131 
132  // get RawEvent
133  const RawEvent* re = m_robDataProvider->getEvent();
134  if (!re) {
135  ATH_MSG_ERROR("Can not get RawEvent ");
136  return StatusCode::FAILURE;
137  }
138 
139  // Run Number
140  int runNumber = re->run_no();
141 
142  // Event Number
144  if (re->version() < 0x03010000) {
145  eventNumber=re->lvl1_id();
146  } else {
147  eventNumber=re->global_id();
148  }
149 
150  // Time Stamp
151  uint32_t bc_time_sec = re->bc_time_seconds();
152  uint32_t bc_time_ns = re->bc_time_nanoseconds();
153  // bc_time_ns should be lt 1e9.
154  if (bc_time_ns > 1000000000) {
155  if (runNumber < 20920) {
156  // In M4 we saw otherwise, because sec/ns was swapped in raw data.
157  uint32_t temp = bc_time_ns;
158  bc_time_ns = bc_time_sec;
159  bc_time_sec= temp;
160  ATH_MSG_DEBUG("bc_time second/nanosecond swapped, sec/ns = " << bc_time_sec << " " << bc_time_ns);
161  }
162  else {
163  // For later runs, the nanosecond clock sometimes is not reset, making it overrun 1e9. Round it off to 1e9
164  ATH_MSG_WARNING("bc_time nanosecond number larger than 1e9, it is " << bc_time_ns << ", reset it to 1 sec");
165  bc_time_ns = 1000000000;
166  }
167  }
168 
169  // luminosity block number
170  uint16_t lumiBlock = re->lumi_block();
171 
172  // bunch crossing identifier
173  uint16_t bcID = re->bc_id();
174 
175  unsigned int detMask0 = 0xFFFFFFFF, detMask1 = 0xFFFFFFFF, detMask2 = 0xFFFFFFFF, detMask3 = 0xFFFFFFFF;
176  // Get ByteStream Metadata from Input MetaData Store
177  const ByteStreamMetadataContainer* metadatacont{nullptr};
178  StatusCode status = m_mdSvc->retrieve(metadatacont, "ByteStreamMetadata");
179  if (!status.isSuccess()) {
180  ATH_MSG_WARNING("Unable to retrieve Input MetaData for ByteStream");
181  }
182  else {
183  const ByteStreamMetadata* metadata = *(metadatacont->begin());
184  uint64_t detectorMask = metadata->getDetectorMask();
185  detMask0 = (unsigned int)(detectorMask & 0x00000000FFFFFFFF);
186  detMask1 = (unsigned int)(detectorMask >> 32);
187  uint64_t detectorMask2 = metadata->getDetectorMask2();
188  detMask2 = (unsigned int)(detectorMask2 & 0x00000000FFFFFFFF);
189  detMask3 = (unsigned int)(detectorMask2 >> 32);
190  }
191 
192 
193  xAOD::EventInfo evtInfo;
194  xAOD::EventAuxInfo* pEvtInfoAux = new xAOD::EventAuxInfo();
195  evtInfo.setStore(pEvtInfoAux);
196 
197  evtInfo.setRunNumber(runNumber);
198  evtInfo.setEventNumber(eventNumber);
199  evtInfo.setLumiBlock(lumiBlock);
200  evtInfo.setTimeStamp(bc_time_sec);
201  evtInfo.setTimeStampNSOffset(bc_time_ns);
202  evtInfo.setBCID(bcID);
203  evtInfo.setDetectorMask(detMask0,detMask1);
204  evtInfo.setDetectorMaskExt(detMask2,detMask3);
205 
206  // The following values were implicitly set by the BS converter of the legacy EventInfo
207  // Setting them here too
208  evtInfo.setMCChannelNumber(0);
209  evtInfo.setMCEventNumber(0);
210  evtInfo.setMCEventWeights(std::vector<float>(1,1));
211 
212  // Set Event Type
213  uint32_t eventTypeBitmask{0};
214  if (m_isSimulation) {
215  eventTypeBitmask |= xAOD::EventInfo::IS_SIMULATION;
216  }
217  if (m_isTestbeam) {
218  eventTypeBitmask |= xAOD::EventInfo::IS_TESTBEAM;
219  }
220  if (m_isCalibration) {
221  eventTypeBitmask |= xAOD::EventInfo::IS_CALIBRATION;
222  }
223  evtInfo.setEventTypeBitmask(eventTypeBitmask);
224 
225  // Trigger Info
227  // status element
228  re->status(buffer);
229  uint32_t statusElement = *buffer;
230 
231  // extended LVL1ID
232  uint32_t extendedLevel1ID = re->lvl1_id();
233 
234  // LVL1 trigger type
235  uint32_t level1TriggerType = re->lvl1_trigger_type();
236 
237  // stream tag
238  std::vector<xAOD::EventInfo::StreamTag> streamTags;
239  std::vector<eformat::helper::StreamTag> onl_streamTags;
240  re->stream_tag(buffer);
241  eformat::helper::decode(re->nstream_tag(), buffer, onl_streamTags);
242  for (const eformat::helper::StreamTag& onl_streamTag : onl_streamTags) {
243  std::set<uint32_t> tmp_off_dets = std::set<uint32_t>();
244  if (!onl_streamTag.dets.empty()) {
245  std::set<eformat::SubDetector> tmp_onl_dets = onl_streamTag.dets;
246  for (const eformat::SubDetector& subdet : tmp_onl_dets) {
247  tmp_off_dets.insert((uint32_t) subdet);
248  }
249  }
250  streamTags.push_back(xAOD::EventInfo::StreamTag(onl_streamTag.name
251  , onl_streamTag.type
252  , onl_streamTag.obeys_lumiblock
253  , onl_streamTag.robs
254  , tmp_off_dets)
255  );
256  }
257 
258  evtInfo.setStatusElement(statusElement);
259  evtInfo.setExtendedLevel1ID(extendedLevel1ID);
260  evtInfo.setLevel1TriggerType(level1TriggerType);
261  evtInfo.setStreamTags(streamTags);
262 
263  // record EventInfo
264  evtInfo.setEventFlags(xAOD::EventInfo::Core, m_robDataProvider->getEventStatus());
265  pObj = SG::asStorable(pEvtInfoAux);
266 
267  ATH_MSG_DEBUG(" New xAOD::EventAuxInfo made, run/event= " << runNumber
268  << " " << eventNumber
269  << " Time stamp = " << ascTime(bc_time_sec)
270  );
271 
272  return StatusCode::SUCCESS;
273 }

◆ createRep()

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

converter method to write object

Definition at line 275 of file EventInfoByteStreamAuxCnv.cxx.

276 {
277  ATH_MSG_DEBUG("Nothing to be done for xAOD::EventAuxInfo createReps");
278  return StatusCode::SUCCESS;
279 }

◆ finalize()

StatusCode EventInfoByteStreamAuxCnv::finalize ( )
overridevirtual

Definition at line 110 of file EventInfoByteStreamAuxCnv.cxx.

111 {
112  ATH_MSG_DEBUG("Finalize");
113 
115  if (sc.isFailure()) {
116  ATH_MSG_WARNING("Converter::finalize() failed");
117  }
118  return sc;
119 }

◆ initialize()

StatusCode EventInfoByteStreamAuxCnv::initialize ( )
overridevirtual

Definition at line 52 of file EventInfoByteStreamAuxCnv.cxx.

53 {
54  ATH_MSG_DEBUG("Initialize");
55 
57 
58  // Check ByteStreamCnvSvc
59  IService* svc{nullptr};
60  StatusCode sc = serviceLocator()->getService("ByteStreamCnvSvc", svc);
61  if (!sc.isSuccess()) {
62  ATH_MSG_ERROR("Cannot get ByteStreamCnvSvc ");
63  return sc;
64  }
66  if (!m_ByteStreamCnvSvc) {
67  ATH_MSG_ERROR("Cannot cast to ByteStreamCnvSvcBase");
68  return StatusCode::FAILURE;
69  }
70 
71  CHECK(m_robDataProvider.retrieve());
72  CHECK(m_mdSvc.retrieve());
73 
74  SimpleProperty<bool> propIsSimulation("IsSimulation", m_isSimulation);
75  sc = m_ByteStreamCnvSvc->getProperty(&propIsSimulation);
76  if (sc.isSuccess()) {
77  m_isSimulation = propIsSimulation.value();
78  ATH_MSG_INFO("IsSimulation : " << m_isSimulation);
79  }
80  else {
81  ATH_MSG_ERROR("Cannot get IsSimulation");
82  return sc;
83  }
84 
85  SimpleProperty<bool> propIsTestbeam("IsTestbeam", m_isTestbeam);
86  sc = m_ByteStreamCnvSvc->getProperty(&propIsTestbeam);
87  if (sc.isSuccess()) {
88  m_isTestbeam = propIsTestbeam.value();
89  ATH_MSG_INFO("IsTestbeam : " << m_isTestbeam);
90  }
91  else {
92  ATH_MSG_ERROR("Cannot get IsTestbeam");
93  return sc;
94  }
95 
96  SimpleProperty<bool> propIsCalibration("IsCalibration", m_isCalibration);
97  sc = m_ByteStreamCnvSvc->getProperty(&propIsCalibration);
98  if (sc.isSuccess()) {
99  m_isCalibration = propIsCalibration.value();
100  ATH_MSG_INFO("IsCalibration : " << m_isCalibration);
101  }
102  else {
103  ATH_MSG_ERROR("Cannot get IsCalibration");
104  return sc;
105  }
106 
107  return StatusCode::SUCCESS;
108 }

◆ 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  m_lvl = m_imsg ?
43  static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
44  MSG::INFO;
45 }

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

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

165 {
166  MsgStream* ms = m_msg_tls.get();
167  if (!ms) {
168  if (!m_initialized.test_and_set()) initMessaging();
169  ms = new MsgStream(m_imsg,m_nm);
170  m_msg_tls.reset( ms );
171  }
172 
173  ms->setLevel (m_lvl);
174  return *ms;
175 }

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

180 { return msg() << lvl; }

◆ 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_initialized.test_and_set()) initMessaging();
154  if (m_lvl <= lvl) {
155  msg() << lvl;
156  return true;
157  } else {
158  return false;
159  }
160 }

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

◆ repSvcType()

virtual long EventInfoByteStreamAuxCnv::repSvcType ( ) const
inlineoverridevirtual

Storage type and class ID.

Definition at line 44 of file EventInfoByteStreamAuxCnv.h.

44 { 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  }

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

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

ByteStreamCnvSvcBase* EventInfoByteStreamAuxCnv::m_ByteStreamCnvSvc
private

pointer to BS CnvSvc

Definition at line 50 of file EventInfoByteStreamAuxCnv.h.

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

◆ m_isCalibration

bool EventInfoByteStreamAuxCnv::m_isCalibration
private

Definition at line 57 of file EventInfoByteStreamAuxCnv.h.

◆ m_isSimulation

bool EventInfoByteStreamAuxCnv::m_isSimulation
private

Definition at line 55 of file EventInfoByteStreamAuxCnv.h.

◆ m_isTestbeam

bool EventInfoByteStreamAuxCnv::m_isTestbeam
private

Definition at line 56 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.

◆ m_mdSvc

ServiceHandle<StoreGateSvc> EventInfoByteStreamAuxCnv::m_mdSvc
private

TDS handle.

Definition at line 52 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 51 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:
AthMessaging::m_lvl
std::atomic< MSG::Level > m_lvl
Current logging level.
Definition: AthMessaging.h:138
Trk::numberOfPixelHits
@ numberOfPixelHits
number of pixel layers on track with absence of hits
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:57
Converter::Converter
Converter()
Definition: Converter.h:31
CalculateHighPtTerm.pT
pT
Definition: ICHEP2016/CalculateHighPtTerm.py:57
Converter::ipCorr
void ipCorr(double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
Definition: Converter.h:257
python.tests.PyTestsLib.finalize
def finalize(self)
_info( "content of StoreGate..." ) self.sg.dump()
Definition: PyTestsLib.py:53
DataModel_detail::const_iterator
Const iterator class for DataVector/DataList.
Definition: DVLIterator.h:82
Trk::numberOfTRTHighThresholdHits
@ numberOfTRTHighThresholdHits
total number of TRT hits which pass the high threshold
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:87
Converter::m_beamY
double m_beamY
Definition: Converter.h:320
EventInfoByteStreamAuxCnv::ascTime
std::string ascTime(unsigned int t)
convert timestamp to ascii time.
Definition: EventInfoByteStreamAuxCnv.cxx:281
xAOD::EventInfo_v1::setEventNumber
void setEventNumber(uint64_t value)
Set the current event's event number.
phi
Scalar phi() const
phi method
Definition: AmgMatrixBasePlugin.h:64
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
OFFLINE_FRAGMENTS_NAMESPACE::DataType
uint32_t DataType
Definition: RawEvent.h:24
CaloCellPos2Ntuple.int
int
Definition: CaloCellPos2Ntuple.py:24
TauGNNUtils::Variables::Track::nPixelHits
bool nPixelHits(const xAOD::TauJet &, const xAOD::TauTrack &track, double &out)
Definition: TauGNNUtils.cxx:542
xAOD::uint32_t
setEventNumber uint32_t
Definition: EventInfo_v1.cxx:127
eta
Scalar eta() const
pseudorapidity method
Definition: AmgMatrixBasePlugin.h:79
Trk::ParametersT
Dummy class used to allow special convertors to be called for surfaces owned by a detector element.
Definition: EMErrorDetail.h:25
initialize
void initialize()
Definition: run_EoverP.cxx:894
xAOD::EventAuxInfo_v3
Auxiliary information about the event.
Definition: EventAuxInfo_v3.h:28
InDetAccessor::phi0
@ phi0
Definition: InDetAccessor.h:33
theta
Scalar theta() const
theta method
Definition: AmgMatrixBasePlugin.h:71
conifer::pow
constexpr int pow(int x)
Definition: conifer.h:20
xAOD::JetInput::Track
@ Track
Definition: JetContainerInfo.h:61
xAOD::EventInfo_v1::IS_CALIBRATION
@ IS_CALIBRATION
true: calibration, false: physics
Definition: EventInfo_v1.h:155
RawEvent
OFFLINE_FRAGMENTS_NAMESPACE::FullEventFragment RawEvent
data type for reading raw event
Definition: RawEvent.h:37
Trk::TrackParticleBase::trackSummary
const TrackSummary * trackSummary() const
accessor function for TrackSummary.
Definition: TrackParticleBase.h:247
test_pyathena.pt
pt
Definition: test_pyathena.py:11
M_PI
#define M_PI
Definition: ActiveFraction.h:11
Trk::z0
@ z0
Definition: ParamDefs.h:70
SG::asStorable
DataObject * asStorable(T *pObject)
Definition: StorableConversions.h:158
xAOD::EventInfo_v1::setExtendedLevel1ID
void setExtendedLevel1ID(uint32_t value)
Set the extended Level-1 identifier.
python.SystemOfUnits.TeV
int TeV
Definition: SystemOfUnits.py:158
ByteStreamMetadata
This class is the StoreGate data object for bytestream metadata.
Definition: ByteStreamMetadata.h:25
EventInfoByteStreamAuxCnv::m_isTestbeam
bool m_isTestbeam
Definition: EventInfoByteStreamAuxCnv.h:56
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
drawFromPickle.cos
cos
Definition: drawFromPickle.py:36
MCP::ScaleSmearParam::r2
@ r2
drawFromPickle.exp
exp
Definition: drawFromPickle.py:36
xAOD::EventInfo_v1::IS_SIMULATION
@ IS_SIMULATION
true: simulation, false: data
Definition: EventInfo_v1.h:151
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
AthenaPoolTestRead.sc
sc
Definition: AthenaPoolTestRead.py:27
Trk::numberOfBLayerHits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:51
Converter::phiCorr
double phiCorr(double phi)
Definition: Converter.h:248
python.checkMetadata.metadata
metadata
Definition: checkMetadata.py:175
xAOD::EventInfo_v1::setEventFlags
bool setEventFlags(EventFlagSubDet subDet, uint32_t flags)
Set the event flags for a particular sub-detector.
Definition: EventInfo_v1.cxx:719
ClassID_traits::ID
static const CLID & ID()
the CLID of T
Definition: Control/AthenaKernel/AthenaKernel/ClassID_traits.h:50
xAOD::EventInfo_v1::setStreamTags
void setStreamTags(const std::vector< StreamTag > &value)
Set the streams that the event was put in.
Definition: EventInfo_v1.cxx:342
AthMessaging::AthMessaging
AthMessaging()
Default constructor:
xAOD::EventInfo_v1::setLevel1TriggerType
void setLevel1TriggerType(uint16_t value)
Set the Level-1 trigger type.
TauGNNUtils::Variables::Track::nSiHits
bool nSiHits(const xAOD::TauJet &, const xAOD::TauTrack &track, double &out)
Definition: TauGNNUtils.cxx:691
createCoolChannelIdFile.buffer
buffer
Definition: createCoolChannelIdFile.py:12
EventInfoByteStreamAuxCnv::m_mdSvc
ServiceHandle< StoreGateSvc > m_mdSvc
TDS handle.
Definition: EventInfoByteStreamAuxCnv.h:52
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
xAOD::EventInfo_v1::setMCEventNumber
void setMCEventNumber(uint64_t value)
Set the MC generator's event number.
xAOD::EventInfo_v1::setEventTypeBitmask
void setEventTypeBitmask(uint32_t value)
Set the event type bitmask.
xAOD::uint16_t
setWord1 uint16_t
Definition: eFexEMRoI_v1.cxx:88
ByteStreamMetadataContainer
This class is the StoreGate data object for bytestream metadata.
Definition: ByteStreamMetadataContainer.h:22
StdJOSetup.msgSvc
msgSvc
Provide convenience handles for various services.
Definition: StdJOSetup.py:36
SG::AuxElement::setStore
void setStore(const SG::IConstAuxStore *store)
Set the store associated with this object.
Definition: AuxElement.cxx:221
EventInfoByteStreamAuxCnv::m_isSimulation
bool m_isSimulation
Definition: EventInfoByteStreamAuxCnv.h:55
Converter::m_beamX
double m_beamX
Definition: Converter.h:320
python.DecayParser.buf
buf
print ("=> [%s]"cmd)
Definition: DecayParser.py:27
xAOD::EventInfo_v1::setDetectorMask
void setDetectorMask(uint32_t mask0, uint32_t mask1)
Set the bit fields indicating with TTC timezones were present.
Definition: EventInfo_v1.cxx:149
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
Trk::numberOfSCTHits
@ numberOfSCTHits
number of SCT holes
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:71
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
ByteStreamAddress
IOpaqueAddress for ByteStreamCnvSvc, with ROB ids.
Definition: ByteStreamAddress.h:28
Trk::TrackParticleBase::fitQuality
const FitQuality * fitQuality() const
accessor function for FitQuality.
Definition: TrackParticleBase.h:259
chi2
double chi2(TH1 *h0, TH1 *h1)
Definition: comparitor.cxx:522
TRT::Track::d0
@ d0
Definition: InnerDetector/InDetCalibEvent/TRT_CalibData/TRT_CalibData/TrackInfo.h:62
xAOD::uint64_t
uint64_t
Definition: EventInfo_v1.cxx:123
CHECK
#define CHECK(...)
Evaluate an expression and check for errors.
Definition: Control/AthenaKernel/AthenaKernel/errorcheck.h:422
drawFromPickle.tan
tan
Definition: drawFromPickle.py:36
Trk::FitQuality
Class to represent and store fit qualities from track reconstruction in terms of and number of degre...
Definition: FitQuality.h:97
xAOD::eventNumber
eventNumber
Definition: EventInfo_v1.cxx:124
Handler::svc
AthROOTErrorHandlerSvc * svc
Definition: AthROOTErrorHandlerSvc.cxx:10
TRT::Track::z0
@ z0
Definition: InnerDetector/InDetCalibEvent/TRT_CalibData/TRT_CalibData/TrackInfo.h:63
xAOD::EventInfo_v1::setStatusElement
void setStatusElement(uint32_t value)
Set the trigger status element.
xAOD::EventInfo_v1::setTimeStamp
void setTimeStamp(uint32_t value)
Set the POSIX time of the event.
xAOD::EventInfo_v1::setBCID
void setBCID(uint32_t value)
Set the bunch crossing ID of the event.
EventInfoByteStreamAuxCnv::storageType
static long storageType()
Definition: EventInfoByteStreamAuxCnv.cxx:47
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
Converter::addTrack
void addTrack(TIDA::Track *t)
Definition: Converter.h:45
calibdata.ct
ct
Definition: calibdata.py:418
xAOD::EventAuxInfo
EventAuxInfo_v3 EventAuxInfo
Definition of the latest event auxiliary info version.
Definition: EventAuxInfo.h:15
EventInfoByteStreamAuxCnv::m_robDataProvider
ServiceHandle< IROBDataProviderSvc > m_robDataProvider
RODDataProviderSvc handle.
Definition: EventInfoByteStreamAuxCnv.h:51
Trk::numberOfTRTHits
@ numberOfTRTHits
number of TRT outliers
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:79
ByteStreamAddress::storageType
static constexpr long storageType()
Definition: ByteStreamAddress.h:51
Trk::TrackSummary
A summary of the information contained by a track.
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:287
Trk::d0
@ d0
Definition: ParamDefs.h:69
python.PerfMonSerializer.decode
def decode(s)
Definition: PerfMonSerializer.py:388
xAOD::EventInfo_v1::setDetectorMaskExt
void setDetectorMaskExt(uint32_t mask2, uint32_t mask3)
Set the bit fields indicating with TTC timezones were present.
Definition: EventInfo_v1.cxx:170
xAOD::EventInfo_v1
Class describing the basic event information.
Definition: EventInfo_v1.h:43
Rec::TrackParticle
Definition: Reconstruction/Particle/Particle/TrackParticle.h:47
Rec::TrackParticle::measuredPerigee
const Trk::Perigee * measuredPerigee() const
Accessor method for Perigee.
Definition: Reconstruction/Particle/Particle/TrackParticle.h:180
xAOD::EventInfo_v1::setTimeStampNSOffset
void setTimeStampNSOffset(uint32_t value)
Set the nanosecond offset wrt. the time stamp.
DataVector::end
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
xAOD::EventInfo_v1::setMCChannelNumber
void setMCChannelNumber(uint32_t value)
Set the MC generator's channel number.
DeMoAtlasDataLoss.runNumber
string runNumber
Definition: DeMoAtlasDataLoss.py:64
ALFA_EventTPCnv_Dict::t2
std::vector< ALFA_RawDataContainer_p1 > t2
Definition: ALFA_EventTPCnvDict.h:44
Trk::DetectorType
DetectorType
enumerates the various detector types currently accessible from the isHit() method.
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:231
EventInfoByteStreamAuxCnv::m_isCalibration
bool m_isCalibration
Definition: EventInfoByteStreamAuxCnv.h:57
ByteStreamCnvSvcBase
The base class for offline and HLT ByteStream conversion services.
Definition: ByteStreamCnvSvcBase.h:19
EventInfoByteStreamAuxCnv::m_ByteStreamCnvSvc
ByteStreamCnvSvcBase * m_ByteStreamCnvSvc
pointer to BS CnvSvc
Definition: EventInfoByteStreamAuxCnv.h:50
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
xAOD::EventInfo_v1::setRunNumber
void setRunNumber(uint32_t value)
Set the current event's run number.
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
re
const boost::regex re(r_e)
TIDA::Track
Definition: Trigger/TrigAnalysis/TrigInDetAnalysis/TrigInDetAnalysis/Track.h:26
Trk::FitQuality::chiSquared
double chiSquared() const
returns the of the overall track fit
Definition: FitQuality.h:56
Trk::FitQuality::numberDoF
int numberDoF() const
returns the number of degrees of freedom of the overall track or vertex fit as integer
Definition: FitQuality.h:60
merge.status
status
Definition: merge.py:17
EventInfoByteStreamAuxCnv::classID
static const CLID & classID()
Definition: EventInfoByteStreamAuxCnv.cxx:42
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx:39
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
MCP::ScaleSmearParam::r1
@ r1
xAOD::EventInfo_v1::setLumiBlock
void setLumiBlock(uint32_t value)
Set the current event's luminosity block number.
AthMessaging::m_msg_tls
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
Definition: AthMessaging.h:132
xAOD::lumiBlock
setTeId lumiBlock
Definition: L2StandAloneMuon_v1.cxx:327
Converter::m_tracks
std::vector< TIDA::Track * > m_tracks
Definition: Converter.h:321
xAOD::EventInfo_v1::IS_TESTBEAM
@ IS_TESTBEAM
true: testbeam, false: full detector
Definition: EventInfo_v1.h:153
xAOD::EventInfo_v1::Core
@ Core
Core flags describing the event.
Definition: EventInfo_v1.h:339
Trk::phi0
@ phi0
Definition: ParamDefs.h:71
xAOD::EventInfo_v1::StreamTag
Class describing a stream tag on the event.
Definition: EventInfo_v1.h:190
python.trfValidateRootFile.rc
rc
Definition: trfValidateRootFile.py:350
DataVector::begin
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
xAOD::EventInfo_v1::setMCEventWeights
void setMCEventWeights(const std::vector< float > &value)
Set the weights of all the MC events used in the simulation.
SCT_Monitoring::summary
@ summary
Definition: SCT_MonitoringNumbers.h:65