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

Converter for the DetDescrCnvSvc which parses the identifier xml dictionaries and creates an IdDictManager in the DetectorStore. This is used by the IdHelpers to initialize themselves. More...

#include <IdDictDetDescrCnv.h>

Inheritance diagram for IdDictDetDescrCnv:
Collaboration diagram for IdDictDetDescrCnv:

Public Member Functions

virtual long int repSvcType () const override
 
virtual StatusCode initialize () override
 
virtual StatusCode finalize () override
 
virtual StatusCode createObj (IOpaqueAddress *pAddr, DataObject *&pObj) override
 
 IdDictDetDescrCnv (ISvcLocator *svcloc)
 
virtual StatusCode fillObjRefs (IOpaqueAddress *pAddr, DataObject *pObj)
 
virtual StatusCode createRep (DataObject *pObj, IOpaqueAddress *&pAddr)
 
virtual StatusCode fillRepRefs (IOpaqueAddress *pAddr, DataObject *pObj)
 
const ServiceHandle< StoreGateSvc > & detStore () const
 Handle to DetectorStore. 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 int storageType ()
 Storage type and class ID (used by CnvFactory) More...
 
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

template<class dType >
StatusCode loadProperty (const std::string &propertyName, dType &pipeTo)
 Loads the property from the DetDecrCnvSvc and pipes its value Returns failure if either the service, the property don't exist or the data type is wrong. More...
 
template<class dType >
StatusCode loadPropertyWithParse (const std::string &propertyName, dType &pipeTo)
 Same as loadProperty but additionally m_doParsing is set to true if the input value does not match the set property value. More...
 
StatusCode getFileNamesFromProperties ()
 Get file names from properties. More...
 
StatusCode getFileNamesFromTags ()
 Get file names from properties. More...
 
StatusCode registerFilesWithParser ()
 Register the requested files with the xml parser. More...
 
StatusCode registerInfoWithDicts ()
 Register the requested files and tag with the created id dicts. More...
 
void printDicts (const IdDictManager *dictMgr)
 Print out the contained dictionaries and version. More...
 
StatusCode parseXMLDescription ()
 Create and (re)initialize the IdDictManager - only create the first time. More...
 
void collectCaloNeighbors (IRDBRecordset_ptr recordset)
 A helper function for collecting calo neighbor file names from the database. More...
 
void initMessaging () const
 Initialize our message level and MessageSvc. More...
 

Private Attributes

ServiceHandle< IGeoDbTagSvcm_geoDbTagSvc {"GeoDbTagSvc/GeoDbTagSvc", "IdDictDetDescrCnv"}
 
ServiceHandle< IRDBAccessSvcm_rdbAccessSvc {"RDBAccessSvc/RDBAccessSvc", "IdDictDetDescrCnv"}
 
SmartIF< IProperty > m_detDescrProxy
 Propxy to the DetDescrCnvSvc. More...
 
std::unique_ptr< IdDictParserm_parser {}
 The xml parser for the dictionary descriptions. More...
 
bool m_doChecks {false}
 Flag to tell helpers to do Checks. More...
 
bool m_doNeighbours {true}
 Flag to generate neighbor information - for calos. More...
 
std::string m_idDictName {}
 Name of top-level xml dict file. More...
 
bool m_idDictFromRDB {false}
 Flag to get dict parameters from Relational DetDescr DB. More...
 
bool m_doParsing {true}
 Flag to which determines whether the xml files are parsed or not. More...
 
std::string m_atlasIDFileName {}
 File to be read for top-level subsystem ids values. More...
 
std::string m_inDetIDFileName {}
 File to be read for InDet ids. More...
 
std::string m_larIDFileName {}
 File to be read for LAr ids. More...
 
std::string m_tileIDFileName {}
 File to be read for Tile ids. More...
 
std::string m_caloIDFileName {}
 File to be read for Calo ids. More...
 
std::string m_fullAtlasNeighborsName {}
 Files for Calo Neighbors. More...
 
std::string m_fcal2dNeighborsName {}
 
std::string m_fcal3dNeighborsNextName {}
 
std::string m_fcal3dNeighborsPrevName {}
 
std::string m_tileNeighborsName {}
 
std::string m_muonIDFileName {}
 File to be read for Muon ids. More...
 
std::string m_forwardIDFileName {}
 File to be read for Forward det ids. More...
 
std::string m_atlasIdDictTag {}
 Tag of RDB record for Atlas top-level ids. More...
 
std::string m_inDetIdDictTag {}
 Tag of RDB record for InDet ids. More...
 
std::string m_larIdDictTag {}
 Tag of RDB record for LAr ids. More...
 
std::string m_tileIdDictTag {}
 Tag of RDB record for Tile ids. More...
 
std::string m_caloIdDictTag {}
 Tag of RDB record for Calo ids. More...
 
std::string m_muonIdDictTag {}
 Tag of RDB record for Muon ids. More...
 
std::string m_forwardIdDictTag {}
 Tag of RDB record for forwards det ids. More...
 
std::string m_inDetIDTag {}
 Internal InDet id tag. More...
 
bool m_useGeomDB_InDet {false}
 
ServiceHandle< StoreGateSvcm_detStore
 
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

Converter for the DetDescrCnvSvc which parses the identifier xml dictionaries and creates an IdDictManager in the DetectorStore. This is used by the IdHelpers to initialize themselves.

Definition at line 42 of file IdDictDetDescrCnv.h.

Constructor & Destructor Documentation

◆ IdDictDetDescrCnv()

IdDictDetDescrCnv::IdDictDetDescrCnv ( ISvcLocator *  svcloc)

Definition at line 265 of file IdDictDetDescrCnv.cxx.

266  : DetDescrConverter(ClassID_traits<IdDictManager>::ID(), svcloc, "IdDictDetDescrCnv")
267 {}

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  }

◆ classID()

const CLID & IdDictDetDescrCnv::classID ( )
static

Definition at line 260 of file IdDictDetDescrCnv.cxx.

260  {
262 }

◆ clear()

void Converter::clear ( )
inlineinherited

Definition at line 53 of file Converter.h.

53 {m_tracks.clear();}

◆ collectCaloNeighbors()

void IdDictDetDescrCnv::collectCaloNeighbors ( IRDBRecordset_ptr  recordset)
private

A helper function for collecting calo neighbor file names from the database.

Definition at line 236 of file IdDictDetDescrCnv.cxx.

237 {
238  const IRDBRecord *neighborTable = (*recordset)[0];
239  m_fullAtlasNeighborsName = neighborTable->getString("FULLATLASNEIGHBORS");
240  m_fcal2dNeighborsName = neighborTable->getString("FCAL2DNEIGHBORS");
241  m_fcal3dNeighborsNextName = neighborTable->getString("FCAL3DNEIGHBORSNEXT");
242  m_fcal3dNeighborsPrevName = neighborTable->getString("FCAL3DNEIGHBORSPREV");
243  m_tileNeighborsName = neighborTable->getString("TILENEIGHBORS");
244  ATH_MSG_DEBUG(" using neighbor files: ");
245  ATH_MSG_DEBUG(" FullAtlasNeighborsFileName: " << m_fullAtlasNeighborsName);
246  ATH_MSG_DEBUG(" FCAL2DNeighborsFileName: " << m_fcal2dNeighborsName);
247  ATH_MSG_DEBUG(" FCAL3DNeighborsNextFileName: " << m_fcal3dNeighborsNextName);
248  ATH_MSG_DEBUG(" FCAL3DNeighborsPrevFileName: " << m_fcal3dNeighborsPrevName);
249  ATH_MSG_DEBUG(" TileNeighborsFileName: " << m_tileNeighborsName);
250  return;
251 }

◆ createObj()

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

Implements DetDescrConverter.

Definition at line 54 of file IdDictDetDescrCnv.cxx.

55  {
56  //
57  // Here we create an IdDictManager and provide it with an
58  // IdDictMgr which has been filled by an IdDictParser. This mgr
59  // is used by each IdHelper to initialize itself.
60  //
61  // Lifetime management:
62  //
63  // IdDictDetDescrCnv holds onto ONE IdDictParser, which in
64  // turn holds the same IdDictMgr.
65  //
66  // Multiple initializations are possible. parseXMLDescription
67  // will look for a new set of xml files, clear any
68  // pre-existing IdDictMgr help by the parser and then parse
69  // the new xml files, filling the IdDictMgr.
70  //
71  // Since the parser "refills" the same IdDictMgr, one has the
72  // option to delete and recreate the IdDictManager, or just
73  // keep the same one which will be refreshed with the new
74  // description.
75  //
77  "in createObj: creating a IdDictManager object in the detector store");
78  DetDescrAddress *ddAddr = dynamic_cast<DetDescrAddress *>(pAddr);
79  if (!ddAddr) {
80  ATH_MSG_ERROR("Could not cast to DetDescrAddress.");
81  return StatusCode::FAILURE;
82  }
83 
84  // Get the StoreGate key of this container.
85  std::string mgrKey = *(ddAddr->par());
86  if (mgrKey.empty())
87  ATH_MSG_DEBUG("No Manager key ");
88  else
89  ATH_MSG_DEBUG("Manager key is " << mgrKey);
90 
92 
93  // Create the manager - only once
94  IdDictManager *dictMgr = new IdDictManager(m_parser->m_idd);
95 
96  ATH_MSG_DEBUG("Created IdDictManager ");
97 
98  // Print out the dictionary names
99  printDicts(dictMgr);
100 
101  // Pass a pointer to the container to the Persistency service
102  // by reference.
103  pObj = SG::asStorable(dictMgr);
104 
105  return StatusCode::SUCCESS;
106 }

◆ createRep()

StatusCode DetDescrConverter::createRep ( DataObject *  pObj,
IOpaqueAddress *&  pAddr 
)
virtualinherited

Definition at line 20 of file DetDescrConverter.cxx.

21  {
22  return StatusCode::SUCCESS;
23 }

◆ detStore()

const ServiceHandle<StoreGateSvc>& DetDescrConverter::detStore ( ) const
inlineinherited

Handle to DetectorStore.

Definition at line 33 of file DetDescrConverter.h.

33 { return m_detStore; }

◆ fillObjRefs()

StatusCode DetDescrConverter::fillObjRefs ( IOpaqueAddress *  pAddr,
DataObject *  pObj 
)
virtualinherited

Definition at line 15 of file DetDescrConverter.cxx.

16  {
17  return StatusCode::SUCCESS;
18 }

◆ fillRepRefs()

StatusCode DetDescrConverter::fillRepRefs ( IOpaqueAddress *  pAddr,
DataObject *  pObj 
)
virtualinherited

Definition at line 25 of file DetDescrConverter.cxx.

26  {
27  return StatusCode::SUCCESS;
28 }

◆ finalize()

StatusCode IdDictDetDescrCnv::finalize ( )
overridevirtual

Definition at line 48 of file IdDictDetDescrCnv.cxx.

48  {
49  ATH_MSG_INFO("in finalize");
50  return StatusCode::SUCCESS;
51 }

◆ getFileNamesFromProperties()

StatusCode IdDictDetDescrCnv::getFileNamesFromProperties ( )
private

Get file names from properties.

Definition at line 312 of file IdDictDetDescrCnv.cxx.

312  {
313  // Check whether non-default names have been specified for the
314  // IdDict files of the subsystems
315 
316  // Atlas IDs
317  ATH_CHECK(loadProperty("AtlasIDFileName", m_atlasIDFileName));
318  // InDet Ids
319  ATH_CHECK(loadProperty("InDetIDFileName", m_inDetIDFileName));
320  // LAr ids
321  ATH_CHECK(loadProperty("LArIDFileName", m_larIDFileName));
322  // Tile ids
323  ATH_CHECK(loadProperty("TileIDFileName", m_tileIDFileName));
324  // Calo ids
325  ATH_CHECK(loadProperty("CaloIDFileName", m_caloIDFileName));
326  // Calo neighbor files
327  ATH_CHECK(loadProperty("FullAtlasNeighborsFileName", m_fullAtlasNeighborsName));
328  ATH_CHECK(loadProperty("FCAL2DNeighborsFileName", m_fcal2dNeighborsName));
329  ATH_CHECK(loadProperty("FCAL3DNeighborsNextFileName", m_fcal3dNeighborsNextName));
330  ATH_CHECK(loadProperty("FCAL3DNeighborsPrevFileName", m_fcal3dNeighborsPrevName));
331 
332  ATH_CHECK(loadProperty("TileNeighborsFileName", m_tileNeighborsName));
333  // Muon ids
334  ATH_CHECK(loadProperty("MuonIDFileName", m_muonIDFileName));
335  // ForwardDetectors ids
336  ATH_CHECK(loadProperty("ForwardIDFileName", m_forwardIDFileName));
337  return StatusCode::SUCCESS;
338 }

◆ getFileNamesFromTags()

StatusCode IdDictDetDescrCnv::getFileNamesFromTags ( )
private

Get file names from properties.

Definition at line 341 of file IdDictDetDescrCnv.cxx.

341  {
342  // Fetch file names and tags from the RDB
343  ATH_CHECK(m_geoDbTagSvc.retrieve());
344  bool skipDbDictAccess = m_geoDbTagSvc->getParamSvcName().empty();
345  std::string paramSvcName = skipDbDictAccess ? "RDBAccessSvc" : m_geoDbTagSvc->getParamSvcName();
346  ATH_MSG_DEBUG("Accessed " << paramSvcName);
347  m_rdbAccessSvc.setName(paramSvcName);
348  ATH_CHECK(m_rdbAccessSvc.retrieve());
349 
350  if(skipDbDictAccess) {
351  ATH_MSG_WARNING("Unable to determine RDBAccessSvc backend. Using default dictionaries");
352  // Get Calo Neighbor tables from Oracle and return
353  IRDBRecordset_ptr caloNeighborTable = m_rdbAccessSvc->getRecordsetPtr("CaloNeighborTable", "CaloNeighborTable-00");
354  collectCaloNeighbors(caloNeighborTable);
355  return StatusCode::SUCCESS;
356  }
357 
358  auto assignTagAndName = [this](const IRDBRecordset_ptr &idDictSet,
359  std::string &fileName,
360  std::string &dictTag) {
361  if (idDictSet->size()) {
362  const IRDBRecord *idDictTable = (*idDictSet)[0];
363  const std::string dictName = idDictTable->getString("DICT_NAME");
364  fileName = idDictTable->getString("DICT_FILENAME");
365  dictTag = idDictSet->tagName();
366  // NOTE: the internal tag for IdDict is global, but is
367  // only used for InDet and thus is defined by InDet
368  if (!idDictTable->isFieldNull("DICT_TAG")) {
369  m_inDetIDTag = idDictTable->getString("DICT_TAG");
370  }
371  ATH_MSG_DEBUG(" using dictionary: "
372  << dictName << ", file: " << fileName
373  << ", with internal tag: " << m_inDetIDTag
374  << ", dictionary tag: " << dictTag);
375 
376  } else {
377  ATH_MSG_WARNING(" no record set found for dictionary"<<idDictSet->nodeName()<< " - using default dictionary ");
378  }
379  };
380 
381  // Function for reading ID dictionary as a BLOB from SQLite
382  // and writing it on the disk in the run directory
383  auto getEmbeddedDict = [this](const std::string& dictName,
384  std::string &fileName,
385  std::string &dictTag) -> bool
386  {
387  ATH_MSG_DEBUG("Try to access "<<dictName);
388  IRDBRecordset_ptr rec = m_rdbAccessSvc->getRecordsetPtr(dictName,"","");
389  if(rec->size()>0) {
390  const IRDBRecord *dictRecord = (*rec)[0];
391  std::string dictString = dictRecord->getString("CONTENTS");
392  // write to the temporary file
393  std::string dictFileName = dictName+"-fromSQLite.xml";
394  std::ofstream dictFile;
395  dictFile.open(dictFileName);
396  dictFile << dictString;
397  dictFile.close();
398 
399  fileName = dictFileName;
400  dictTag.clear(); // This may change in the future if we also write dict tags into SQLite
401 
402  ATH_MSG_DEBUG(dictName << " read from the SQLite database as a BLOB");
403  return true;
404  }
405  return false;
406  };
407 
408  bool useGeomDB = (m_geoDbTagSvc->getSqliteReader() == nullptr);
409 
410  std::string detTag{""}, detNode{""}, dictName{""};
411  DecodeVersionKey detectorKey("ATLAS");
412  IRDBRecordset_ptr idDictSet{};
413 
414  bool embeddedDict{false};
415 
416  // Get InDet
417  if (m_useGeomDB_InDet) {
418  // Get Innner Detector xml and write to the temporary file
419  // InDetIdDict.xml
420  detectorKey = DecodeVersionKey(m_geoDbTagSvc.get(), "InnerDetector");
421  ATH_MSG_DEBUG("From Version Tag: " << detectorKey.tag() << " at Node: "
422  << detectorKey.node());
423  detTag = detectorKey.tag();
424  detNode = detectorKey.node();
425  idDictSet = m_rdbAccessSvc->getRecordsetPtr("DICTXDD", detTag, detNode);
426 
427  // Size == 0 if not found
428  if (idDictSet->size()) {
429  const IRDBRecord *recordInDet = (*idDictSet)[0];
430  std::string InDetString = recordInDet->getString("XMLCLOB");
431 
432  // write to the temporary file
433  std::ofstream blobFile;
434  blobFile.open("InDetIdDict.xml");
435  blobFile << InDetString << std::endl;
436  blobFile.close();
437  } else {
438  ATH_MSG_WARNING(" no record set found for InDetIdentifier - using default dictionary ");
439  }
440  } else {
441  // Attempt to read the embedded disctionary from SQLite
442  embeddedDict = !useGeomDB && getEmbeddedDict("IdDictInnerDetector",m_inDetIDFileName,m_inDetIdDictTag);
443  if(!embeddedDict) {
444  // Fall back on getting file names from the database
445  if (useGeomDB) {
446  detectorKey = DecodeVersionKey(m_geoDbTagSvc.get(), "InnerDetector");
447  ATH_MSG_DEBUG("From Version Tag: " << detectorKey.tag() << " at Node: " << detectorKey.node());
448  detTag = detectorKey.tag();
449  detNode = detectorKey.node();
450  }
451  idDictSet = m_rdbAccessSvc->getRecordsetPtr("InDetIdentifier", detTag, detNode);
452  assignTagAndName(idDictSet, m_inDetIDFileName, m_inDetIdDictTag);
453  }
454  }
455 
456  // Get LAr
457  // Attempt to read the embedded disctionary from SQLite
458  embeddedDict = !useGeomDB && getEmbeddedDict("IdDictLArCalorimeter",m_larIDFileName,m_larIdDictTag);
459  if(!embeddedDict) {
460  // Fall back on getting file names from the database
461  if (useGeomDB) {
462  detectorKey = DecodeVersionKey(m_geoDbTagSvc.get(), "LAr");
463  ATH_MSG_DEBUG( "From Version Tag: " << detectorKey.tag() << " at Node: " << detectorKey.node() );
464  detTag = detectorKey.tag();
465  detNode = detectorKey.node();
466  }
467  idDictSet = m_rdbAccessSvc->getRecordsetPtr("LArIdentifier", detTag, detNode);
468  assignTagAndName(idDictSet, m_larIDFileName, m_larIdDictTag);
469  }
470 
471  // Get Tile
472  // Attempt to read the embedded disctionary from SQLite
473  embeddedDict = !useGeomDB && getEmbeddedDict("IdDictTileCalorimeter",m_tileIDFileName,m_tileIdDictTag);
474  if(!embeddedDict) {
475  // Fall back on getting file names from the database
476  if (useGeomDB) {
477  detectorKey = DecodeVersionKey(m_geoDbTagSvc.get(), "TileCal");
478  ATH_MSG_DEBUG( "From Version Tag: " << detectorKey.tag() << " at Node: " << detectorKey.node() );
479  detTag = detectorKey.tag();
480  detNode = detectorKey.node();
481  }
482  idDictSet = m_rdbAccessSvc->getRecordsetPtr("TileIdentifier", detTag, detNode);
483  assignTagAndName(idDictSet, m_tileIDFileName, m_tileIdDictTag);
484  }
485 
486  // Get Calo
487  // Attempt to read the embedded disctionary from SQLite
488  embeddedDict = !useGeomDB && getEmbeddedDict("IdDictCalorimeter",m_caloIDFileName,m_caloIdDictTag);
489  if(!embeddedDict) {
490  // Fall back on getting file names from the database
491  if (useGeomDB) {
492  detectorKey = DecodeVersionKey(m_geoDbTagSvc.get(), "Calorimeter");
493  ATH_MSG_DEBUG( "From Version Tag: " << detectorKey.tag()<< " at Node: " << detectorKey.node() );
494  detTag = detectorKey.tag();
495  detNode = detectorKey.node();
496  }
497  idDictSet = m_rdbAccessSvc->getRecordsetPtr("CaloIdentifier", detTag, detNode);
498  assignTagAndName(idDictSet, m_caloIDFileName, m_caloIdDictTag);
499  }
500  // Calo neighbor files:
501  IRDBRecordset_ptr caloNeighborTable = m_rdbAccessSvc->getRecordsetPtr("CaloNeighborTable", detTag, detNode);
502 
503  if (caloNeighborTable->size() == 0 && useGeomDB) {
504  caloNeighborTable = m_rdbAccessSvc->getRecordsetPtr("CaloNeighborTable", "CaloNeighborTable-00");
505  }
506  // Size == 0 if not found
507  if (caloNeighborTable->size()) {
508  collectCaloNeighbors(caloNeighborTable);
509  }
510 
511  // Get Muon
512  // Attempt to read the embedded disctionary from SQLite
513  embeddedDict = !useGeomDB && getEmbeddedDict("IdDictMuonSpectrometer", m_muonIDFileName, m_muonIdDictTag);
514  if(!embeddedDict) {
515  // Fall back on getting file names from the database
516  if (useGeomDB) {
517  detectorKey = DecodeVersionKey(m_geoDbTagSvc.get(), "MuonSpectrometer");
518  ATH_MSG_DEBUG( "From Version Tag: " << detectorKey.tag()<< " at Node: " << detectorKey.node() );
519  detTag = detectorKey.tag();
520  detNode = detectorKey.node();
521  }
522  idDictSet = m_rdbAccessSvc->getRecordsetPtr("MuonIdentifier", detTag, detNode);
523  assignTagAndName(idDictSet, m_muonIDFileName, m_muonIdDictTag);
524  }
525 
526  // Get Forward
527  // Attempt to read the embedded disctionary from SQLite
528  embeddedDict = !useGeomDB && getEmbeddedDict("IdDictForwardDetectors",m_forwardIDFileName,m_forwardIdDictTag);
529  if(!embeddedDict) {
530  // Fall back on getting file names from the database
531  if (useGeomDB) {
532  detectorKey = DecodeVersionKey(m_geoDbTagSvc.get(), "ForwardDetectors");
533  ATH_MSG_DEBUG( "From Version Tag: " << detectorKey.tag() << " at Node: " << detectorKey.node() );
534  detTag = detectorKey.tag();
535  detNode = detectorKey.node();
536  }
537  idDictSet = m_rdbAccessSvc->getRecordsetPtr("ForDetIdentifier", detTag, detNode);
538 
539  // For older datasets use ForDetIdentifier-00 as fallback
540  if (idDictSet->size() == 0 && useGeomDB) {
541  idDictSet = m_rdbAccessSvc->getRecordsetPtr("ForDetIdentifier",
542  "ForDetIdentifier-00");
543  ATH_MSG_DEBUG(" explicitly requesting ForDetIdentifier-00 tag for pre-forward "
544  "detector data ");
545  }
546  // Size == 0 if not found
547  assignTagAndName(idDictSet, m_forwardIDFileName, m_forwardIdDictTag);
548  }
549  ATH_MSG_DEBUG("End access to RDB for id dictionary info ");
550  return StatusCode::SUCCESS;
551 }

◆ initialize()

StatusCode IdDictDetDescrCnv::initialize ( )
overridevirtual

Definition at line 36 of file IdDictDetDescrCnv.cxx.

36  {
37  // First call parent init
39  ATH_MSG_INFO("in initialize");
40  // Must set indet tag to EMPTY
41  m_inDetIDTag = "EMPTY";
42 
43  m_detDescrProxy = serviceLocator()->service("DetDescrCnvSvc");
44  ATH_CHECK(m_detDescrProxy.isValid());
45 
46  return StatusCode::SUCCESS;
47 }

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

◆ loadProperty()

template<class dType >
StatusCode IdDictDetDescrCnv::loadProperty ( const std::string &  propertyName,
dType &  pipeTo 
)
private

Loads the property from the DetDecrCnvSvc and pipes its value Returns failure if either the service, the property don't exist or the data type is wrong.

Definition at line 657 of file IdDictDetDescrCnv.cxx.

658  {
659 
660  if (!m_detDescrProxy->hasProperty(propertyName)) {
661  ATH_MSG_FATAL("DetDescrSvc does not have the property "
662  << propertyName);
663  return StatusCode::FAILURE;
664  }
665  const Gaudi::Details::PropertyBase &prop =
666  m_detDescrProxy->getProperty(propertyName);
667  const Gaudi::Property<dType> *propPtr{
668  dynamic_cast<const Gaudi::Property<dType> *>(&prop)};
669  if (!propPtr) {
670  ATH_MSG_ERROR("Property " << propertyName << " is not of type"
671  << typeid(dType).name() << " but of "
672  << typeid(prop).name());
673  return StatusCode::FAILURE;
674  }
675  pipeTo = propPtr->value();
676  ATH_MSG_DEBUG("Flag " << propertyName << " is: " << pipeTo);
677  return StatusCode::SUCCESS;
678 }

◆ loadPropertyWithParse()

template<class dType >
StatusCode IdDictDetDescrCnv::loadPropertyWithParse ( const std::string &  propertyName,
dType &  pipeTo 
)
private

Same as loadProperty but additionally m_doParsing is set to true if the input value does not match the set property value.

Definition at line 683 of file IdDictDetDescrCnv.cxx.

684  {
685  dType cache{};
686  ATH_CHECK(loadProperty(propertyName, cache));
687  m_doParsing |= cache != pipeTo;
688  pipeTo = std::move(cache);
689  return StatusCode::SUCCESS;
690 }

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

◆ parseXMLDescription()

StatusCode IdDictDetDescrCnv::parseXMLDescription ( )
private

Create and (re)initialize the IdDictManager - only create the first time.

Definition at line 110 of file IdDictDetDescrCnv.cxx.

110  {
111  ATH_MSG_DEBUG("in parseXMLDescription()");
112 
113  // Parse the xml files to obtain the iddict dictionaries
114  //
115  // Parsing of the xml files may not be needed. So we check. The
116  // conditions to reparse are:
117  //
118  // - first pass, i.e. creating a new IdDictParser
119  // - a change in an input xml file
120  // - a change in one of the "options" such as doIdChecks,
121  // doInitNeighbors, etc.
122  //
123 
124  m_doParsing = false; // Preset to no parsing
125 
126  if (!m_parser) {
127  // Create parser
128  m_parser = std::make_unique<IdDictParser>();
129  m_doParsing = true;
130  }
131 
132  // We access the properties on each pass
133 
134  // Set flag for doing checks of ids
136 
137  // Set flag for initializing neighbours
138  ATH_CHECK(loadPropertyWithParse("DoInitNeighbours", m_doNeighbours));
139 
140  // Name of IdDict file
142  ATH_MSG_INFO("IdDictName: " << m_idDictName);
143 
144  // Get the file names: two options - either from jobOpt
145  // properties of the DetDescrCnvSvc or from RDB tags
146 
147  // Determine if Dict filename comes from DD database or
148  // if properties from JobOptions should be used.
149  ATH_CHECK(loadProperty("IdDictFromRDB", m_idDictFromRDB));
150 
151  // Determine if the dictionary content comes from DD database or
152  // if properties from JobOptions should be used.
153  ATH_CHECK(loadProperty("useGeomDB_InDet", m_useGeomDB_InDet));
154 
155  if (m_idDictFromRDB)
156  ATH_MSG_DEBUG("Dictonary file name from DD database");
157  else
159  "Dictonary file name from job options or using defaults.");
160 
161  // Get the file name to parse:
162  //
163  // 1) From Relational DB
164  // 2) Via jobOptions
165  // 3) default name in the xml files
166  //
167  // Currently the logic is 1) or 2) and 3) covers the case where
168  // no file name is found.
169  //
170  if (m_idDictFromRDB) {
171  // Get file names from RDB
173  ATH_MSG_DEBUG("Looked for ID file name from RDB ");
174  } else {
175  // Get file names from properties
177  ATH_MSG_DEBUG("Looked for ID file name from properties ");
178  }
179 
180  // Only parse if necessary
181  if (m_doParsing) {
182  // Register the requested files with the xml parser
184  ATH_MSG_DEBUG("Registered file names ");
185 
186  // Check whether a tag is needed for dictionary initialization
187 
188  // NOTE: the internal tag for IdDict is global, but is only
189  // used for InDet and thus is defined by InDet
190  std::string tag{};
191  if (m_inDetIDTag == "EMPTY")
192  ATH_CHECK(loadProperty("IdDictGlobalTag", tag));
193  else
194  tag = m_inDetIDTag;
195 
196  // Parse the dictionaries
197  m_parser->parse(m_idDictName, tag);
198  if (tag.empty())
199  tag = "default";
200  ATH_MSG_DEBUG("Read dict: " << m_idDictName << " with tag " << tag);
201 
202  // Set flag to check ids
203  IdDictMgr &mgr = m_parser->m_idd;
204 
205  mgr.set_do_checks(m_doChecks);
206  ATH_MSG_DEBUG("Set IdDictManager doChecks flag to"
207  << (m_doChecks ? "true" : "false"));
208 
209  // Set flag to initialize neighbours
210  mgr.set_do_neighbours(m_doNeighbours);
211  ATH_MSG_DEBUG("Set IdDictManager doNeighbours flag to "
212  << (m_doNeighbours ? "true" : "false"));
213 
214  // Do some checks
215  const IdDictMgr::dictionary_map &dm = mgr.get_dictionary_map();
216  if (dm.empty()) {
217  ATH_MSG_ERROR("No dictionaries found!");
218  return StatusCode::FAILURE;
219  }
220  ATH_MSG_DEBUG("Found " << dm.size() << " dictionaries.");
221 
222  // Register the requested files and tags with the id dicts
224  ATH_MSG_DEBUG("Registered info with id dicts ");
225  } else {
227  "NOTE: ** parseXMLDescription called, but parsing was deemed "
228  "unnecessary ** ");
229  }
230  ATH_MSG_DEBUG("parseXMLDescription: Finished parsing and setting options ");
231  return StatusCode::SUCCESS;
232 }

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

◆ printDicts()

void IdDictDetDescrCnv::printDicts ( const IdDictManager dictMgr)
private

Print out the contained dictionaries and version.

Definition at line 269 of file IdDictDetDescrCnv.cxx.

269  {
270 
271  ATH_MSG_INFO("Found id dicts:");
272  if (!dictMgr)
273  return;
274 
275  std::string tag = dictMgr->manager()->tag();
276  ATH_MSG_INFO("Using dictionary tag: " << (tag.empty() ? "<no tag>" : tag));
277 
279  dictMgr->manager()->get_dictionary_map();
280  IdDictMgr::dictionary_map::const_iterator it;
281 
282  int n = 0;
283 
284  for (it = dm.begin(); it != dm.end(); ++it, ++n) {
285  const IdDictDictionary &dictionary = *((*it).second);
286  std::string version =
287  ("" != dictionary.m_version) ? dictionary.m_version : "default";
288  msg(MSG::INFO) << "Dictionary " << dictionary.m_name;
289  if (dictionary.m_name.size() < 20) {
290  std::string space(20 - dictionary.m_name.size(), ' ');
291  msg(MSG::INFO) << space;
292  }
293  msg(MSG::INFO) << " version " << version;
294  if (version.size() < 20) {
295  std::string space(20 - version.size(), ' ');
296  msg(MSG::INFO) << space;
297  }
298  if (dictionary.dict_tag().size()) {
299  msg(MSG::INFO) << " DetDescr tag " << dictionary.dict_tag();
300  if (dictionary.dict_tag().size() < 20) {
301  std::string space(25 - dictionary.dict_tag().size(), ' ');
302  msg(MSG::INFO) << space;
303  }
304  } else {
305  msg(MSG::INFO) << " DetDescr tag (using default)";
306  }
307  ATH_MSG_INFO(" file " << dictionary.file_name());
308  }
309 }

◆ registerFilesWithParser()

StatusCode IdDictDetDescrCnv::registerFilesWithParser ( )
private

Register the requested files with the xml parser.

Definition at line 554 of file IdDictDetDescrCnv.cxx.

554  {
555  // If InDetIdDict.xml exists set InDetFileName set to it's name
556  if (m_useGeomDB_InDet) {
557  std::ifstream ifile;
558  ifile.open("InDetIdDict.xml");
559  if (ifile)
560  m_inDetIDFileName = "InDetIdDict.xml";
561  else
562  ATH_MSG_WARNING(" no temp. file InDetIdDict.xml found - using file "
563  << m_inDetIDFileName);
564  }
565 
566  if (!m_atlasIDFileName.empty()) {
567  m_parser->register_external_entity("ATLAS", m_atlasIDFileName);
568  ATH_MSG_INFO("Reading ATLAS IdDict file "
569  << m_atlasIDFileName);
570  }
571  if (!m_inDetIDFileName.empty()) {
572  m_parser->register_external_entity("InnerDetector", m_inDetIDFileName);
573  ATH_MSG_INFO("Reading InnerDetector IdDict file "
574  << m_inDetIDFileName);
575  }
576  if (!m_larIDFileName.empty()) {
577  m_parser->register_external_entity("LArCalorimeter", m_larIDFileName);
578  ATH_MSG_INFO("Reading LArCalorimeter IdDict file "
579  << m_larIDFileName);
580  }
581  if (!m_tileIDFileName.empty()) {
582  m_parser->register_external_entity("TileCalorimeter", m_tileIDFileName);
583  ATH_MSG_INFO("Reading TileCalorimeter IdDict file "
584  << m_tileIDFileName);
585  }
586  if (!m_caloIDFileName.empty()) {
587  m_parser->register_external_entity("Calorimeter", m_caloIDFileName);
588  ATH_MSG_INFO("Reading Calorimeter IdDict file "
589  << m_caloIDFileName);
590  }
591  if (!m_muonIDFileName.empty()) {
592  m_parser->register_external_entity("MuonSpectrometer",
594  ATH_MSG_INFO("Reading MuonSpectrometer IdDict file "
595  << m_muonIDFileName);
596  }
597  if (!m_forwardIDFileName.empty()) {
598  m_parser->register_external_entity("ForwardDetectors",
600  ATH_MSG_INFO("Reading ForwardDetectors IdDict file "
602  }
603  return StatusCode::SUCCESS;
604 }

◆ registerInfoWithDicts()

StatusCode IdDictDetDescrCnv::registerInfoWithDicts ( )
private

Register the requested files and tag with the created id dicts.

Definition at line 607 of file IdDictDetDescrCnv.cxx.

607  {
608  // Save the file name and tag in each of the dictionaries
609  IdDictMgr &mgr = m_parser->m_idd;
610 
611  auto setDictPaths = [this, &mgr](const std::string &dict_name,
612  const std::string &file_name,
613  const std::string &dict_tag) {
614  if (file_name.empty()) {
615  ATH_MSG_DEBUG("No idDict will be loaded for " << dict_name);
616  return StatusCode::SUCCESS;
617  }
618  IdDictDictionary *dict = mgr.find_dictionary(dict_name);
619  if (!dict) {
620  ATH_MSG_ERROR("unable to find idDict for " << dict_name);
621  return StatusCode::FAILURE;
622  }
623  dict->set_file_name(file_name);
624  dict->set_dict_tag(dict_tag);
625  ATH_MSG_DEBUG("For " << dict_name << " idDict, setting file/tag: "
626  << file_name << " " << dict_tag);
627  return StatusCode::SUCCESS;
628  };
629  ATH_CHECK(setDictPaths("ATLAS", m_atlasIDFileName, m_atlasIdDictTag));
630  ATH_CHECK(setDictPaths("InnerDetector", m_inDetIDFileName, m_inDetIdDictTag));
631  ATH_CHECK(setDictPaths("LArCalorimeter", m_larIDFileName, m_larIdDictTag));
632  ATH_CHECK(setDictPaths("TileCalorimeter", m_tileIDFileName, m_tileIdDictTag));
633  ATH_CHECK(setDictPaths("Calorimeter", m_caloIDFileName, m_caloIdDictTag));
634  ATH_CHECK(setDictPaths("MuonSpectrometer", m_muonIDFileName, m_muonIdDictTag));
635  ATH_CHECK(setDictPaths("ForwardDetectors", m_forwardIDFileName, m_forwardIdDictTag));
636 
637  auto addMetaData = [&mgr, this](const std::string &key,
638  const std::string &value) {
639  if (value.empty()) {
640  ATH_MSG_DEBUG("No value given for key " << key);
641  } else {
642  mgr.add_metadata(key, value);
643  ATH_MSG_DEBUG("Added to dict mgr meta data: <" << key << ","
644  << value << ">");
645  }
646  };
647  addMetaData("FULLATLASNEIGHBORS", m_fullAtlasNeighborsName);
648  addMetaData("FCAL2DNEIGHBORS", m_fcal2dNeighborsName);
649  addMetaData("FCAL3DNEIGHBORSNEXT", m_fcal3dNeighborsNextName);
650  addMetaData("FCAL3DNEIGHBORSPREV", m_fcal3dNeighborsPrevName);
651  addMetaData("TILENEIGHBORS", m_tileNeighborsName);
652 
653  return StatusCode::SUCCESS;
654 }

◆ repSvcType()

long int IdDictDetDescrCnv::repSvcType ( ) const
overridevirtual

Definition at line 30 of file IdDictDetDescrCnv.cxx.

30  {
31  return (storageType());
32 }

◆ 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 int IdDictDetDescrCnv::storageType ( )
static

Storage type and class ID (used by CnvFactory)

Definition at line 255 of file IdDictDetDescrCnv.cxx.

255  {
256  return DetDescr_StorageType;
257 }

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

std::string IdDictDetDescrCnv::m_atlasIdDictTag {}
private

Tag of RDB record for Atlas top-level ids.

Definition at line 146 of file IdDictDetDescrCnv.h.

◆ m_atlasIDFileName

std::string IdDictDetDescrCnv::m_atlasIDFileName {}
private

File to be read for top-level subsystem ids values.

Definition at line 118 of file IdDictDetDescrCnv.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_caloIdDictTag

std::string IdDictDetDescrCnv::m_caloIdDictTag {}
private

Tag of RDB record for Calo ids.

Definition at line 158 of file IdDictDetDescrCnv.h.

◆ m_caloIDFileName

std::string IdDictDetDescrCnv::m_caloIDFileName {}
private

File to be read for Calo ids.

Definition at line 130 of file IdDictDetDescrCnv.h.

◆ m_detDescrProxy

SmartIF<IProperty> IdDictDetDescrCnv::m_detDescrProxy
private

Propxy to the DetDescrCnvSvc.

Definition at line 62 of file IdDictDetDescrCnv.h.

◆ m_detStore

ServiceHandle<StoreGateSvc> DetDescrConverter::m_detStore
privateinherited

Definition at line 42 of file DetDescrConverter.h.

◆ m_doChecks

bool IdDictDetDescrCnv::m_doChecks {false}
private

Flag to tell helpers to do Checks.

Definition at line 102 of file IdDictDetDescrCnv.h.

◆ m_doNeighbours

bool IdDictDetDescrCnv::m_doNeighbours {true}
private

Flag to generate neighbor information - for calos.

Definition at line 105 of file IdDictDetDescrCnv.h.

◆ m_doParsing

bool IdDictDetDescrCnv::m_doParsing {true}
private

Flag to which determines whether the xml files are parsed or not.

Definition at line 115 of file IdDictDetDescrCnv.h.

◆ m_fcal2dNeighborsName

std::string IdDictDetDescrCnv::m_fcal2dNeighborsName {}
private

Definition at line 134 of file IdDictDetDescrCnv.h.

◆ m_fcal3dNeighborsNextName

std::string IdDictDetDescrCnv::m_fcal3dNeighborsNextName {}
private

Definition at line 135 of file IdDictDetDescrCnv.h.

◆ m_fcal3dNeighborsPrevName

std::string IdDictDetDescrCnv::m_fcal3dNeighborsPrevName {}
private

Definition at line 136 of file IdDictDetDescrCnv.h.

◆ m_forwardIdDictTag

std::string IdDictDetDescrCnv::m_forwardIdDictTag {}
private

Tag of RDB record for forwards det ids.

Definition at line 164 of file IdDictDetDescrCnv.h.

◆ m_forwardIDFileName

std::string IdDictDetDescrCnv::m_forwardIDFileName {}
private

File to be read for Forward det ids.

Definition at line 143 of file IdDictDetDescrCnv.h.

◆ m_fullAtlasNeighborsName

std::string IdDictDetDescrCnv::m_fullAtlasNeighborsName {}
private

Files for Calo Neighbors.

Definition at line 133 of file IdDictDetDescrCnv.h.

◆ m_geoDbTagSvc

ServiceHandle<IGeoDbTagSvc> IdDictDetDescrCnv::m_geoDbTagSvc {"GeoDbTagSvc/GeoDbTagSvc", "IdDictDetDescrCnv"}
private

Definition at line 58 of file IdDictDetDescrCnv.h.

◆ m_idDictFromRDB

bool IdDictDetDescrCnv::m_idDictFromRDB {false}
private

Flag to get dict parameters from Relational DetDescr DB.

Definition at line 111 of file IdDictDetDescrCnv.h.

◆ m_idDictName

std::string IdDictDetDescrCnv::m_idDictName {}
private

Name of top-level xml dict file.

Definition at line 108 of file IdDictDetDescrCnv.h.

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

◆ m_inDetIdDictTag

std::string IdDictDetDescrCnv::m_inDetIdDictTag {}
private

Tag of RDB record for InDet ids.

Definition at line 149 of file IdDictDetDescrCnv.h.

◆ m_inDetIDFileName

std::string IdDictDetDescrCnv::m_inDetIDFileName {}
private

File to be read for InDet ids.

Definition at line 121 of file IdDictDetDescrCnv.h.

◆ m_inDetIDTag

std::string IdDictDetDescrCnv::m_inDetIDTag {}
private

Internal InDet id tag.

Definition at line 167 of file IdDictDetDescrCnv.h.

◆ m_larIdDictTag

std::string IdDictDetDescrCnv::m_larIdDictTag {}
private

Tag of RDB record for LAr ids.

Definition at line 152 of file IdDictDetDescrCnv.h.

◆ m_larIDFileName

std::string IdDictDetDescrCnv::m_larIDFileName {}
private

File to be read for LAr ids.

Definition at line 124 of file IdDictDetDescrCnv.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_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_muonIdDictTag

std::string IdDictDetDescrCnv::m_muonIdDictTag {}
private

Tag of RDB record for Muon ids.

Definition at line 161 of file IdDictDetDescrCnv.h.

◆ m_muonIDFileName

std::string IdDictDetDescrCnv::m_muonIDFileName {}
private

File to be read for Muon ids.

Definition at line 140 of file IdDictDetDescrCnv.h.

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_parser

std::unique_ptr<IdDictParser> IdDictDetDescrCnv::m_parser {}
private

The xml parser for the dictionary descriptions.

Definition at line 99 of file IdDictDetDescrCnv.h.

◆ m_rdbAccessSvc

ServiceHandle<IRDBAccessSvc> IdDictDetDescrCnv::m_rdbAccessSvc {"RDBAccessSvc/RDBAccessSvc", "IdDictDetDescrCnv"}
private

Definition at line 59 of file IdDictDetDescrCnv.h.

◆ m_tileIdDictTag

std::string IdDictDetDescrCnv::m_tileIdDictTag {}
private

Tag of RDB record for Tile ids.

Definition at line 155 of file IdDictDetDescrCnv.h.

◆ m_tileIDFileName

std::string IdDictDetDescrCnv::m_tileIDFileName {}
private

File to be read for Tile ids.

Definition at line 127 of file IdDictDetDescrCnv.h.

◆ m_tileNeighborsName

std::string IdDictDetDescrCnv::m_tileNeighborsName {}
private

Definition at line 137 of file IdDictDetDescrCnv.h.

◆ m_tracks

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

Definition at line 321 of file Converter.h.

◆ m_useGeomDB_InDet

bool IdDictDetDescrCnv::m_useGeomDB_InDet {false}
private

Definition at line 170 of file IdDictDetDescrCnv.h.


The documentation for this class was generated from the following files:
IdDictDetDescrCnv::m_tileIdDictTag
std::string m_tileIdDictTag
Tag of RDB record for Tile ids.
Definition: IdDictDetDescrCnv.h:155
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
IdDictMgr::dictionary_map
std::map< std::string, IdDictDictionary * > dictionary_map
Definition: IdDictMgr.h:16
IdDictDetDescrCnv::m_idDictName
std::string m_idDictName
Name of top-level xml dict file.
Definition: IdDictDetDescrCnv.h:108
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
ATH_MSG_FATAL
#define ATH_MSG_FATAL(x)
Definition: AthMsgStreamMacros.h:34
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
IdDictDetDescrCnv::loadProperty
StatusCode loadProperty(const std::string &propertyName, dType &pipeTo)
Loads the property from the DetDecrCnvSvc and pipes its value Returns failure if either the service,...
Definition: IdDictDetDescrCnv.cxx:657
Converter::m_beamY
double m_beamY
Definition: Converter.h:320
IdDictDetDescrCnv::m_atlasIDFileName
std::string m_atlasIDFileName
File to be read for top-level subsystem ids values.
Definition: IdDictDetDescrCnv.h:118
IdDictDetDescrCnv::m_fcal3dNeighborsPrevName
std::string m_fcal3dNeighborsPrevName
Definition: IdDictDetDescrCnv.h:136
phi
Scalar phi() const
phi method
Definition: AmgMatrixBasePlugin.h:67
IdDictDetDescrCnv::registerInfoWithDicts
StatusCode registerInfoWithDicts()
Register the requested files and tag with the created id dicts.
Definition: IdDictDetDescrCnv.cxx:607
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
DetDescr_StorageType
const long DetDescr_StorageType
Definition: DetDescrCnvSvc.cxx:20
IdDictDetDescrCnv::m_inDetIDTag
std::string m_inDetIDTag
Internal InDet id tag.
Definition: IdDictDetDescrCnv.h:167
IdDictDetDescrCnv::m_atlasIdDictTag
std::string m_atlasIdDictTag
Tag of RDB record for Atlas top-level ids.
Definition: IdDictDetDescrCnv.h:146
IdDictDetDescrCnv::getFileNamesFromTags
StatusCode getFileNamesFromTags()
Get file names from properties.
Definition: IdDictDetDescrCnv.cxx:341
IdDictDetDescrCnv::m_doNeighbours
bool m_doNeighbours
Flag to generate neighbor information - for calos.
Definition: IdDictDetDescrCnv.h:105
eta
Scalar eta() const
pseudorapidity method
Definition: AmgMatrixBasePlugin.h:83
Trk::ParametersT
Dummy class used to allow special convertors to be called for surfaces owned by a detector element.
Definition: EMErrorDetail.h:25
IdDictDetDescrCnv::m_muonIDFileName
std::string m_muonIDFileName
File to be read for Muon ids.
Definition: IdDictDetDescrCnv.h:140
initialize
void initialize()
Definition: run_EoverP.cxx:894
IRDBRecord::getString
virtual const std::string & getString(const std::string &fieldName) const =0
Get string field value.
InDetAccessor::phi0
@ phi0
Definition: InDetAccessor.h:33
theta
Scalar theta() const
theta method
Definition: AmgMatrixBasePlugin.h:75
IdDictDetDescrCnv::m_fullAtlasNeighborsName
std::string m_fullAtlasNeighborsName
Files for Calo Neighbors.
Definition: IdDictDetDescrCnv.h:133
xAOD::JetInput::Track
@ Track
Definition: JetContainerInfo.h:61
Trk::TrackParticleBase::trackSummary
const TrackSummary * trackSummary() const
accessor function for TrackSummary.
Definition: TrackParticleBase.h:247
skel.it
it
Definition: skel.GENtoEVGEN.py:396
test_pyathena.pt
pt
Definition: test_pyathena.py:11
M_PI
#define M_PI
Definition: ActiveFraction.h:11
IdDictMgr::get_dictionary_map
const dictionary_map & get_dictionary_map() const
Access to all dictionaries.
Definition: IdDictMgr.cxx:111
Trk::z0
@ z0
Definition: ParamDefs.h:64
IdDictDetDescrCnv::m_detDescrProxy
SmartIF< IProperty > m_detDescrProxy
Propxy to the DetDescrCnvSvc.
Definition: IdDictDetDescrCnv.h:62
IdDictDetDescrCnv::m_fcal2dNeighborsName
std::string m_fcal2dNeighborsName
Definition: IdDictDetDescrCnv.h:134
athena.value
value
Definition: athena.py:124
python.SystemOfUnits.TeV
int TeV
Definition: SystemOfUnits.py:158
IdDictDictionary::set_dict_tag
void set_dict_tag(const std::string &tag)
Set the dictionary tag.
Definition: IdDictDictionary.h:276
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
drawFromPickle.cos
cos
Definition: drawFromPickle.py:36
IdDictDetDescrCnv::m_forwardIDFileName
std::string m_forwardIDFileName
File to be read for Forward det ids.
Definition: IdDictDetDescrCnv.h:143
IdDictDetDescrCnv::m_tileIDFileName
std::string m_tileIDFileName
File to be read for Tile ids.
Definition: IdDictDetDescrCnv.h:127
MCP::ScaleSmearParam::r2
@ r2
drawFromPickle.exp
exp
Definition: drawFromPickle.py:36
IdDictDetDescrCnv::parseXMLDescription
StatusCode parseXMLDescription()
Create and (re)initialize the IdDictManager - only create the first time.
Definition: IdDictDetDescrCnv.cxx:110
IdDictDetDescrCnv::m_larIDFileName
std::string m_larIDFileName
File to be read for LAr ids.
Definition: IdDictDetDescrCnv.h:124
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
IdDictDetDescrCnv::m_tileNeighborsName
std::string m_tileNeighborsName
Definition: IdDictDetDescrCnv.h:137
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
IDTPM::nPixelHits
float nPixelHits(const U &p)
Definition: TrackParametersHelper.h:354
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
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
IdDictDetDescrCnv::collectCaloNeighbors
void collectCaloNeighbors(IRDBRecordset_ptr recordset)
A helper function for collecting calo neighbor file names from the database.
Definition: IdDictDetDescrCnv.cxx:236
BchCleanup.mgr
mgr
Definition: BchCleanup.py:294
physics_parameters.file_name
string file_name
Definition: physics_parameters.py:32
DetDescrConverter::m_detStore
ServiceHandle< StoreGateSvc > m_detStore
Definition: DetDescrConverter.h:42
SG::asStorable
DataObject * asStorable(SG::DataObjectSharedPtr< T > pObject)
Definition: DataObjectSharedPtr.h:65
ClassID_traits::ID
static const CLID & ID()
the CLID of T
Definition: Control/AthenaKernel/AthenaKernel/ClassID_traits.h:50
IdDictDetDescrCnv::m_inDetIdDictTag
std::string m_inDetIdDictTag
Tag of RDB record for InDet ids.
Definition: IdDictDetDescrCnv.h:149
IdDictMgr
Definition: IdDictMgr.h:14
FortranAlgorithmOptions.fileName
fileName
Definition: FortranAlgorithmOptions.py:13
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
DetDescrAddress
Definition: DetDescrAddress.h:32
IdDictDetDescrCnv::m_larIdDictTag
std::string m_larIdDictTag
Tag of RDB record for LAr ids.
Definition: IdDictDetDescrCnv.h:152
Converter::m_beamX
double m_beamX
Definition: Converter.h:320
beamspotman.n
n
Definition: beamspotman.py:731
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
DetDescrConverter::DetDescrConverter
DetDescrConverter(const CLID &myCLID, ISvcLocator *svcloc, const char *name=nullptr)
Definition: DetDescrConverter.cxx:34
IdDictDetDescrCnv::m_doChecks
bool m_doChecks
Flag to tell helpers to do Checks.
Definition: IdDictDetDescrCnv.h:102
DecodeVersionKey
This is a helper class to query the version tags from GeoModelSvc and determine the appropriate tag a...
Definition: DecodeVersionKey.h:18
IdDictDictionary::set_file_name
void set_file_name(const std::string &name)
Set file name.
Definition: IdDictDictionary.h:269
ClassID_traits
Default, invalid implementation of ClassID_traits.
Definition: Control/AthenaKernel/AthenaKernel/ClassID_traits.h:40
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:523
TRT::Track::d0
@ d0
Definition: InnerDetector/InDetCalibEvent/TRT_CalibData/TRT_CalibData/TrackInfo.h:62
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
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
IdDictDetDescrCnv::registerFilesWithParser
StatusCode registerFilesWithParser()
Register the requested files with the xml parser.
Definition: IdDictDetDescrCnv.cxx:554
TRT::Track::z0
@ z0
Definition: InnerDetector/InDetCalibEvent/TRT_CalibData/TRT_CalibData/TrackInfo.h:63
IdDictDetDescrCnv::m_inDetIDFileName
std::string m_inDetIDFileName
File to be read for InDet ids.
Definition: IdDictDetDescrCnv.h:121
IdDictDetDescrCnv::m_useGeomDB_InDet
bool m_useGeomDB_InDet
Definition: IdDictDetDescrCnv.h:170
IdDictDetDescrCnv::m_fcal3dNeighborsNextName
std::string m_fcal3dNeighborsNextName
Definition: IdDictDetDescrCnv.h:135
IRDBRecordset_ptr
std::shared_ptr< IRDBRecordset > IRDBRecordset_ptr
Definition: IRDBAccessSvc.h:25
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
Converter::addTrack
void addTrack(TIDA::Track *t)
Definition: Converter.h:45
ReadCellNoiseFromCool.dm
dm
Definition: ReadCellNoiseFromCool.py:235
IdDictDetDescrCnv::m_muonIdDictTag
std::string m_muonIdDictTag
Tag of RDB record for Muon ids.
Definition: IdDictDetDescrCnv.h:161
Trk::numberOfTRTHits
@ numberOfTRTHits
number of TRT outliers
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:79
IdDictDetDescrCnv::m_geoDbTagSvc
ServiceHandle< IGeoDbTagSvc > m_geoDbTagSvc
Definition: IdDictDetDescrCnv.h:58
master.dictionary
dictionary
Definition: master.py:47
Trk::TrackSummary
A summary of the information contained by a track.
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:287
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
Trk::d0
@ d0
Definition: ParamDefs.h:63
IdDictManager
IdDictManager is the interface to identifier dictionaries.
Definition: IdDictManager.h:36
IdDictDetDescrCnv::m_caloIdDictTag
std::string m_caloIdDictTag
Tag of RDB record for Calo ids.
Definition: IdDictDetDescrCnv.h:158
IdDictDetDescrCnv::m_rdbAccessSvc
ServiceHandle< IRDBAccessSvc > m_rdbAccessSvc
Definition: IdDictDetDescrCnv.h:59
IdDictDictionary
Definition: IdDictDictionary.h:30
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
DataVector::end
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
get_generator_info.version
version
Definition: get_generator_info.py:33
Trk::DetectorType
DetectorType
enumerates the various detector types currently accessible from the isHit() method.
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:231
IdDictDetDescrCnv::m_forwardIdDictTag
std::string m_forwardIdDictTag
Tag of RDB record for forwards det ids.
Definition: IdDictDetDescrCnv.h:164
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
IRDBRecord::isFieldNull
virtual bool isFieldNull(const std::string &fieldName) const =0
Check if the field value is NULL.
IdDictDetDescrCnv::m_caloIDFileName
std::string m_caloIDFileName
File to be read for Calo ids.
Definition: IdDictDetDescrCnv.h:130
IRDBRecord
IRDBRecord is one record in the IRDBRecordset object.
Definition: IRDBRecord.h:27
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
IdDictManager::manager
const IdDictMgr * manager(void) const
Definition: IdDictManager.cxx:37
IdDictDetDescrCnv::loadPropertyWithParse
StatusCode loadPropertyWithParse(const std::string &propertyName, dType &pipeTo)
Same as loadProperty but additionally m_doParsing is set to true if the input value does not match th...
Definition: IdDictDetDescrCnv.cxx:683
IdDictDetDescrCnv::m_parser
std::unique_ptr< IdDictParser > m_parser
The xml parser for the dictionary descriptions.
Definition: IdDictDetDescrCnv.h:99
TIDA::Track
Definition: Trigger/TrigAnalysis/TrigInDetAnalysis/TrigInDetAnalysis/Track.h:26
IdDictDetDescrCnv::printDicts
void printDicts(const IdDictManager *dictMgr)
Print out the contained dictionaries and version.
Definition: IdDictDetDescrCnv.cxx:269
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
LArCellNtuple.ifile
string ifile
Definition: LArCellNtuple.py:133
CaloCondBlobAlgs_fillNoiseFromASCII.tag
string tag
Definition: CaloCondBlobAlgs_fillNoiseFromASCII.py:24
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx:39
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
IdDictDetDescrCnv::getFileNamesFromProperties
StatusCode getFileNamesFromProperties()
Get file names from properties.
Definition: IdDictDetDescrCnv.cxx:312
MCP::ScaleSmearParam::r1
@ r1
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
pow
constexpr int pow(int base, int exp) noexcept
Definition: ap_fixedTest.cxx:15
IdDictMgr::tag
const std::string & tag() const
Version tag.
Definition: IdDictMgr.cxx:57
Converter::m_tracks
std::vector< TIDA::Track * > m_tracks
Definition: Converter.h:321
IdDictDetDescrCnv::m_idDictFromRDB
bool m_idDictFromRDB
Flag to get dict parameters from Relational DetDescr DB.
Definition: IdDictDetDescrCnv.h:111
IdDictDetDescrCnv::m_doParsing
bool m_doParsing
Flag to which determines whether the xml files are parsed or not.
Definition: IdDictDetDescrCnv.h:115
Trk::phi0
@ phi0
Definition: ParamDefs.h:65
IdDictDetDescrCnv::storageType
static long int storageType()
Storage type and class ID (used by CnvFactory)
Definition: IdDictDetDescrCnv.cxx:255
IDTPM::nSiHits
float nSiHits(const U &p)
Definition: TrackParametersHelper.h:427
python.trfValidateRootFile.rc
rc
Definition: trfValidateRootFile.py:355
DataVector::begin
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37
SCT_Monitoring::summary
@ summary
Definition: SCT_MonitoringNumbers.h:65