ATLAS Offline Software
Loading...
Searching...
No Matches
CaloIDHelper Class Referenceabstract

Base class to factor out code common among Calo ID helpers. More...

#include <CaloIDHelper.h>

Inheritance diagram for CaloIDHelper:
Collaboration diagram for CaloIDHelper:

Classes

class  HashGroup
 Manage a list of identifiers. More...

Public Types

enum  { NOT_VALID =999999 }
typedef Identifier::size_type size_type
using id_iterator = std::vector<Identifier>::const_iterator
 Type for iterators over identifiers.
using id_range = std::ranges::subrange<id_iterator>
 Type for range over identifiers.
enum class  HelperType {
  Unimplemented = -1 , Silicon = 0 , Pixel , PLR ,
  SCT , TRT , LArEM , LArFCal ,
  LArFCalSuperCell , LArHEC , LArHEC_SuperCell , LARMiniFCal ,
  Tile , TileSuperCell , LArOnline , LArOnlineSuperCell ,
  LArElectrode , LArHVLine , TileHardware , TileTestbeam ,
  CaloCell , CaloSuperCell , CaloDM , CaloLvl1 ,
  GTower , JTower , Muon , LUCID ,
  LUCID_Hardware , Zdc , ZdcHardware , TT
}
 enum class for eventual final derived types of this class More...

Public Member Functions

 CaloIDHelper (const std::string &name, const std::string &group)
 Constructor.
const HashGroupchannels () const
 Return the HashGroup for channels (cells).
const HashGroupregions () const
 Return the HashGroup for regions.
Identifier channel_id (IdentifierHash hashId) const
 Return the channel (cell) Identifier for a given hash code (no checking).
Identifier region_id (IdentifierHash hashId) const
 Return the region Identifier for a given hash code (no checking).
IdentifierHash channel_hash (Identifier channelId) const
 Convert a connected channel (cell) Identifier to a hash code.
IdentifierHash region_hash (Identifier regionId) const
 Convert a connected region Identifier to a hash code.
virtual int get_id (const IdentifierHash &hash_id, Identifier &id, const IdContext *context=0) const
 Convert a hash code to an Identifier for either channels or regions, depending on the context.
virtual int get_hash (const Identifier &id, IdentifierHash &hash_id, const IdContext *context=0) const
 Convert an Identifier to a hash code for either channels or regions, depending on the context.
size_type channel_hash_max () const
 One more than the largest channel (cell) hash code.
size_type region_hash_max () const
 One more than the largest region hash code.
IdContext channel_context () const
 Return the context for channels (cells).
IdContext region_context () const
 Return the context for regions.
const std::vector< const IdDictRegion * > & dictRegions () const
 Return the vector of IdDictRegion, accessed via region hash.
float etaGranularity (const IdentifierHash regHash) const
 Return the eta granularity of a region, or NOT_VALID.
float phiGranularity (const IdentifierHash regHash) const
 Return the phi granularity of a region, or NOT_VALID.
float eta0 (const IdentifierHash regHash) const
 Return the minimum eta of region, or NOT_VALID.
float phi0 (const IdentifierHash regHash) const
 Return the minimum phi of region, or NOT_VALID.
const std::string & name () const
 Return the name for this helper.
bool msgLvl (const MSG::Level lvl) const
 Test the output level.
MsgStream & msg () const
 The standard message stream.
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream.
void setLevel (MSG::Level lvl)
 Change the current logging level.
'structors
virtual HelperType helper () const
 Type of helper, defaulted to 'Unimplemented'.
const std::string & group () const
 Group name for this helper.
Detector system ids
Identifier indet (void) const
 Detector systems:
Identifier lar (void) const
Identifier tile (void) const
Identifier muon (void) const
Identifier calo (void) const
Inner Detector subsystem ids
Identifier pixel (void) const
Identifier sct (void) const
Identifier trt (void) const
Identifier hgtd (void) const
Identifier lumi (void) const
LAr subsystem ids
Identifier lar_em (void) const
Identifier lar_hec (void) const
Identifier lar_fcal (void) const
Muon subsystem ids
Identifier mdt (void) const
Identifier csc (void) const
Identifier rpc (void) const
Identifier tgc (void) const
Identifier stgc (void) const
Identifier mm (void) const
level 1 and dead material ids
Identifier lar_lvl1 (void) const
Identifier lar_dm (void) const
Identifier tile_dm (void) const
Contexts to provide id length - e.g. for use in generic decoding
IdContext detsystem_context (void) const
 IdContext (indicates id length) for detector systems.
IdContext subdet_context (void) const
 IdContext (indicates id length) for sub-detector.
Initialization and version name
virtual int initialize_from_dictionary (const IdDictMgr &dict_mgr) override
 Initialization from the identifier dictionary.
virtual std::string dictionaryVersion (void) const override
Generic printing of identifiers
void show (Identifier id, const IdContext *context=0, char sep='.') const
 Short print out of any identifier (optionally provide separation character - default is '.
std::string show_to_string (Identifier id, const IdContext *context=0, char sep='.') const
 or provide the printout in string form
void print (Identifier id, const IdContext *context=0) const
 Expanded print out of any identifier.
std::string print_to_string (Identifier id, const IdContext *context=0) const
 or provide the printout in string form
Test of an Identifier to see if it belongs to a particular detector (sub)system:
bool is_indet (Identifier id) const
bool is_lar (Identifier id) const
bool is_tile (Identifier id) const
bool is_muon (Identifier id) const
bool is_calo (Identifier id) const
bool is_lvl1_trig_towers (Identifier id) const
bool is_lvl1_online (Identifier id) const
bool is_pixel (Identifier id) const
bool is_sct (Identifier id) const
bool is_trt (Identifier id) const
bool is_hgtd (Identifier id) const
bool is_lumi (Identifier id) const
bool is_plr (Identifier id) const
bool is_lar_em (Identifier id) const
bool is_lar_hec (Identifier id) const
bool is_lar_fcal (Identifier id) const
bool is_lar_minifcal (Identifier id) const
bool is_lar_dm (Identifier id) const
 LAr/Tile dead material:
bool is_tile_dm (Identifier id) const
bool is_mdt (Identifier id) const
bool is_csc (Identifier id) const
bool is_tgc (Identifier id) const
bool is_rpc (Identifier id) const
bool is_stgc (Identifier id) const
bool is_mm (Identifier id) const
bool is_forward (Identifier id) const
bool is_alfa (Identifier id) const
bool is_bcm (Identifier id) const
bool is_lucid (Identifier id) const
bool is_zdc (Identifier id) const
Test of an Identifier to see if it belongs to a particular detector (sub)system (using expanded ids):
bool is_indet (const ExpandedIdentifier &id) const
bool is_lar (const ExpandedIdentifier &id) const
bool is_tile (const ExpandedIdentifier &id) const
bool is_muon (const ExpandedIdentifier &id) const
bool is_calo (const ExpandedIdentifier &id) const
bool is_pixel (const ExpandedIdentifier &id) const
bool is_sct (const ExpandedIdentifier &id) const
bool is_trt (const ExpandedIdentifier &id) const
bool is_hgtd (const ExpandedIdentifier &id) const
bool is_lumi (const ExpandedIdentifier &id) const
bool is_plr (const ExpandedIdentifier &id) const
bool is_lar_em (const ExpandedIdentifier &id) const
bool is_lar_hec (const ExpandedIdentifier &id) const
bool is_lar_fcal (const ExpandedIdentifier &id) const
bool is_lar_minifcal (const ExpandedIdentifier &id) const
bool is_mdt (const ExpandedIdentifier &id) const
bool is_csc (const ExpandedIdentifier &id) const
bool is_tgc (const ExpandedIdentifier &id) const
bool is_rpc (const ExpandedIdentifier &id) const
bool is_stgc (const ExpandedIdentifier &id) const
bool is_mm (const ExpandedIdentifier &id) const
Dictionary versioning: provide access to dictionary names and versions. Note that a helper may correspond to one or more id dictionary
const std::vector< std::string > & dict_names (void) const
 Dictionary names.
const std::vector< std::string > & file_names (void) const
 File names for subdet dictionaries.
const std::vector< std::string > & dict_tags (void) const
 Version tags for subdet dictionaries.
Checks are performed by default in debug compilation and NOT in optimized compilation. One can switch or query this mode for any idHelper with the following methods:
virtual bool do_checks (void) const override
 Checks are performed by default in debug compilation and NOT in optimized compilation.
virtual void set_do_checks (bool do_checks) override

Static Public Attributes

static constexpr int invalidIndex {999}
static constexpr int invalidId {-1}

Protected Member Functions

int fill_vec_of_dict_regions (const std::string &group_name="")
 Do basic initialization of the helper.
virtual int get_expanded_id (const Identifier &id, ExpandedIdentifier &exp_id, const IdContext *context) const =0
 Create an expanded Identifier from an Identifier.

Private Member Functions

*Group of channel (cell) Identifiers. HashGroup m_channels
void initMessaging () const
 Initialize our message level and MessageSvc.

Private Attributes

*Name of this helper std::string m_name
*Group of region Identifiers HashGroup m_regions
*The dictionary for this helper const IdDictDictionarym_dict
*List of c IdDictRegion objects std::vector< const IdDictRegion * > m_vecOfDictRegions
std::string m_nm
 Message source name.
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels).
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer.
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level.
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging).

neighbours are initialized by default. One can switch or query this mode with the following methods:

std::string m_dict_version
const IdDictDictionarym_atlas_dict {}
const IdDictDictionarym_indet_dict {}
const IdDictDictionarym_lar_dict {}
const IdDictDictionarym_tile_dict {}
const IdDictDictionarym_muon_dict {}
const IdDictDictionarym_calo_dict {}
const IdDictDictionarym_fwd_dict {}
size_type m_DET_INDEX {999}
size_type m_SUBDET_INDEX {999}
size_type m_MUON_SUBDET_INDEX {999}
int m_INDET_ID {2}
int m_LAR_ID {4}
int m_TILE_ID {5}
int m_MUON_ID {7}
int m_CALO_ID {10}
int m_PIXEL_ID {1}
int m_SCT_ID {2}
int m_TRT_ID {3}
int m_HGTD_ID {4}
int m_LUMI_ID {3}
int m_LUMI_PLR_ID {1}
int m_LAR_EM_ID {1}
int m_LAR_HEC_ID {2}
int m_LAR_FCAL_ID {3}
int m_LAR_FCAL_MODULE_INDEX {999}
int m_MDT_ID {0}
int m_CSC_ID {1}
int m_RPC_ID {2}
int m_TGC_ID {3}
int m_STGC_ID {4}
int m_MM_ID {5}
int m_FWD_ID {13}
int m_ALFA_ID {1}
int m_BCM_ID {3}
int m_LUCID_ID {5}
int m_ZDC_ID {7}
IdDictFieldImplementation m_det_impl
IdDictFieldImplementation m_indet_part_impl
IdDictFieldImplementation m_calo_side_impl
IdDictFieldImplementation m_lar_part_impl
IdDictFieldImplementation m_lar_fcal_module_impl
IdDictFieldImplementation m_muon_station_name_impl
IdDictFieldImplementation m_muon_mdt_impl
IdDictFieldImplementation m_muon_rpc_impl
IdDictFieldImplementation m_fwd_part_impl
Range::field m_lvl1_field
Range::field m_lvl1_onl_field
Range::field m_lar_dm_field
Range::field m_tile_dm_field
std::unique_ptr< AtlasDetectorIDHelperm_helper {}
std::vector< unsigned int > m_muon_tech_bits
bool m_is_initialized_from_dict {}
bool m_isHighLuminosityLHC {}
virtual bool do_neighbours (void) const override
 Neighbour initialization is performed by default One can switch or query this mode for any idHelper with the following method:
virtual void set_do_neighbours (bool do_neighbours) override
virtual void setDictVersion (const IdDictMgr &dict_mgr, const std::string &name) override
std::string to_range (const ExpandedIdentifier &id) const
std::string fix_barrel_ec (const std::string &barrel_ec) const
ExpandedIdentifier indet_exp (void) const
 Detector systems:
ExpandedIdentifier lar_exp (void) const
ExpandedIdentifier tile_exp (void) const
ExpandedIdentifier muon_exp (void) const
ExpandedIdentifier calo_exp (void) const
ExpandedIdentifier fwd_exp (void) const
ExpandedIdentifier pixel_exp (void) const
 Inner Detector:
ExpandedIdentifier sct_exp (void) const
ExpandedIdentifier trt_exp (void) const
ExpandedIdentifier hgtd_exp (void) const
ExpandedIdentifier lumi_exp (void) const
ExpandedIdentifier lar_em_exp (void) const
 LAr.
ExpandedIdentifier lar_hec_exp (void) const
ExpandedIdentifier lar_fcal_exp (void) const
ExpandedIdentifier alfa_exp (void) const
 Forward.
ExpandedIdentifier bcm_exp (void) const
ExpandedIdentifier lucid_exp (void) const
ExpandedIdentifier zdc_exp (void) const
int indet_field_value () const
 Provide efficient access to individual field values, for subclass idhelpers.
int lar_field_value () const
int tile_field_value () const
int muon_field_value () const
int calo_field_value () const
int pixel_field_value () const
int sct_field_value () const
int trt_field_value () const
int hgtd_field_value () const
int lumi_field_value () const
int plr_field_value () const
int lar_em_field_value () const
int lar_hec_field_value () const
int lar_fcal_field_value () const
int mdt_field_value () const
int csc_field_value () const
int rpc_field_value () const
int tgc_field_value () const
int stgc_field_value () const
int mm_field_value () const
int forward_field_value () const
int alfa_field_value () const
int bcm_field_value () const
int lucid_field_value () const
int zdc_field_value () const
int register_dict_tag (const IdDictMgr &dict_mgr, const std::string &dict_name)
 Register the file and tag names for a particular IdDict dictionary.
bool reinitialize (const IdDictMgr &dict_mgr)
 Test whether an idhelper should be reinitialized based on the change of tags.
const IdDictDictionarydictionary (const Identifier &id) const
int initLevelsFromDict (const IdDictMgr &dict_mgr)
enum  ID { ATLAS_ID = static_cast<Identifier::value_type>(0) , MAX_BIT = Identifier::MAX_BIT , PIXEL_MASK = static_cast<Identifier::value_type>(0xFF) , ALL_BITS = Identifier::ALL_BITS }
std::string m_group
 Group name.
std::vector< std::string > m_dict_names
 List of dictionary names used by this helper.
std::vector< std::string > m_file_names
 List of dictionary file names used by this helper.
std::vector< std::string > m_dict_tags
 List of dictionary versions used by this helper.
bool m_do_checks {}
 Flag for subclasses to know whether or not to perform checks.
bool m_do_neighbours {true}
 Flag for subclasses to know whether or not to perform neighbour initialization.

Detailed Description

Base class to factor out code common among Calo ID helpers.

Definition at line 32 of file CaloIDHelper.h.

Member Typedef Documentation

◆ id_iterator

Type for iterators over identifiers.

Definition at line 42 of file CaloIDHelper.h.

◆ id_range

using CaloIDHelper::id_range = std::ranges::subrange<id_iterator>

Type for range over identifiers.

Definition at line 44 of file CaloIDHelper.h.

◆ size_type

typedef Identifier::size_type CaloIDHelper::size_type

Definition at line 39 of file CaloIDHelper.h.

Member Enumeration Documentation

◆ anonymous enum

anonymous enum
Enumerator
NOT_VALID 

Definition at line 36 of file CaloIDHelper.h.

36{ NOT_VALID=999999 };

◆ HelperType

enum class AtlasDetectorID::HelperType
stronginherited

enum class for eventual final derived types of this class

Enumerator
Unimplemented 
Silicon 
Pixel 
PLR 
SCT 
TRT 
LArEM 
LArFCal 
LArFCalSuperCell 
LArHEC 
LArHEC_SuperCell 
LARMiniFCal 
Tile 
TileSuperCell 
LArOnline 
LArOnlineSuperCell 
LArElectrode 
LArHVLine 
TileHardware 
TileTestbeam 
CaloCell 
CaloSuperCell 
CaloDM 
CaloLvl1 
GTower 
JTower 
Muon 
LUCID 
LUCID_Hardware 
Zdc 
ZdcHardware 
TT 

Definition at line 56 of file AtlasDetectorID.h.

56 {
57 Unimplemented = -1,
58 Silicon = 0,
59 Pixel, PLR, SCT, TRT,
60 //inherits from CaloIDHelper
61 LArEM, LArFCal, LArFCalSuperCell,
62 LArHEC, LArHEC_SuperCell, LARMiniFCal,
63 Tile, TileSuperCell,
64 //
65 //inherit from LArOnlineId
66 LArOnline, LArOnlineSuperCell,
67 //
68 LArElectrode, LArHVLine,
69 TileHardware, TileTestbeam,
70 CaloCell, CaloSuperCell,
71 CaloDM, CaloLvl1,
72 //inherit from JGTowerBase
73 GTower, JTower,
74 //
75 Muon,
76 LUCID, LUCID_Hardware,
77 Zdc,ZdcHardware,
78 TT
79 };
@ TRT
Definition RegSelEnums.h:26
@ SCT
Definition RegSelEnums.h:25
@ Pixel
Definition DetType.h:13
constexpr std::initializer_list< int > Tile
Definition HIEventDefs.h:70
Muon_v1 Muon
Reference the current persistent version:

◆ ID

enum AtlasDetectorID::ID
privateinherited
Enumerator
ATLAS_ID 
MAX_BIT 
PIXEL_MASK 
ALL_BITS 

Definition at line 377 of file AtlasDetectorID.h.

377 {
378 ATLAS_ID = static_cast<Identifier::value_type>(0),
379 MAX_BIT = Identifier::MAX_BIT,
380 // mask to distinguish a pixel id from lvl1 id (bit 1 set)
381 PIXEL_MASK = static_cast<Identifier::value_type>(0xFF),
383 };

Constructor & Destructor Documentation

◆ CaloIDHelper()

CaloIDHelper::CaloIDHelper ( const std::string & name,
const std::string & group )

Constructor.

Makes an uninitialized helper. To initialize, call initialize_base_from_dictionary, followed by init_channels and init_regions, and optionally fill_vec_of_dict_regions.

Parameters
nameName of this helper (for error reporting).

Makes an uninitialized helper. To initialize, call initialize_base_from_dictionary, followed by init_channels and init_regions.

Parameters
nameName of this helper (for error reporting).

Definition at line 96 of file CaloIDHelper.cxx.

99 m_name (name),
100 m_dict(nullptr)
101{
102}
const std::string & group() const
Group name for this helper.
AtlasDetectorID(const std::string &name, const std::string &group)
const std::string & name() const
Return the name for this helper.
*Name of this helper std::string m_name
*The dictionary for this helper const IdDictDictionary * m_dict

Member Function Documentation

◆ alfa_exp()

ExpandedIdentifier AtlasDetectorID::alfa_exp ( void ) const
protectedinherited

Forward.

Definition at line 1053 of file AtlasDetectorID.cxx.

1054{
1055 ExpandedIdentifier result(fwd_exp());
1056 return (result << m_ALFA_ID);
1057}
ExpandedIdentifier fwd_exp(void) const

◆ alfa_field_value()

int AtlasDetectorID::alfa_field_value ( ) const
inlineprotectedinherited

Definition at line 516 of file AtlasDetectorID.h.

516{return (m_ALFA_ID);}

◆ bcm_exp()

ExpandedIdentifier AtlasDetectorID::bcm_exp ( void ) const
protectedinherited

Definition at line 1060 of file AtlasDetectorID.cxx.

1061{
1062 ExpandedIdentifier result(fwd_exp());
1063 return (result << m_BCM_ID);
1064}

◆ bcm_field_value()

int AtlasDetectorID::bcm_field_value ( ) const
inlineprotectedinherited

Definition at line 518 of file AtlasDetectorID.h.

518{return (m_BCM_ID);}

◆ calo()

Identifier AtlasDetectorID::calo ( void ) const
inherited

Definition at line 78 of file AtlasDetectorID.cxx.

78 {
79 return m_det_impl.new_pack(calo_field_value());
80}
IdDictFieldImplementation m_det_impl
int calo_field_value() const

◆ calo_exp()

ExpandedIdentifier AtlasDetectorID::calo_exp ( void ) const
protectedinherited

Definition at line 983 of file AtlasDetectorID.cxx.

984{
985 ExpandedIdentifier result;
986 return (result << m_CALO_ID);
987}

◆ calo_field_value()

int AtlasDetectorID::calo_field_value ( ) const
inlineprotectedinherited

Definition at line 466 of file AtlasDetectorID.h.

466{return (m_CALO_ID);}

◆ channel()

*Group of CaloIDHelper::channel ( cell )
private

◆ channel_context()

IdContext CaloIDHelper::channel_context ( ) const

Return the context for channels (cells).

◆ channel_hash()

IdentifierHash CaloIDHelper::channel_hash ( Identifier channelId) const

Convert a connected channel (cell) Identifier to a hash code.

Some subdetector helpers may override this with a faster version.

◆ channel_hash_max()

size_type CaloIDHelper::channel_hash_max ( ) const

One more than the largest channel (cell) hash code.

◆ channel_id()

Identifier CaloIDHelper::channel_id ( IdentifierHash hashId) const

Return the channel (cell) Identifier for a given hash code (no checking).

◆ channels()

const HashGroup & CaloIDHelper::channels ( ) const

Return the HashGroup for channels (cells).

◆ csc()

Identifier AtlasDetectorID::csc ( void ) const
inherited

Definition at line 47 of file AtlasDetectorID.cxx.

47 {
48 return Identifier{};
49}

◆ csc_field_value()

int AtlasDetectorID::csc_field_value ( ) const
inlineprotectedinherited

Definition at line 499 of file AtlasDetectorID.h.

499{return (m_CSC_ID);}

◆ detsystem_context()

IdContext AtlasDetectorID::detsystem_context ( void ) const
inherited

IdContext (indicates id length) for detector systems.

Definition at line 127 of file AtlasDetectorID.cxx.

127 {
128 ExpandedIdentifier id{};
129 return IdContext{id, 0, m_DET_INDEX};
130}

◆ dict_names()

const std::vector< std::string > & AtlasDetectorID::dict_names ( void ) const
inherited

Dictionary names.

Definition at line 382 of file AtlasDetectorID.cxx.

382 {
383 return m_dict_names;
384}
std::vector< std::string > m_dict_names
List of dictionary names used by this helper.

◆ dict_tags()

const std::vector< std::string > & AtlasDetectorID::dict_tags ( void ) const
inherited

Version tags for subdet dictionaries.

Definition at line 388 of file AtlasDetectorID.cxx.

388 {
389 return m_dict_tags;
390}
std::vector< std::string > m_dict_tags
List of dictionary versions used by this helper.

◆ dictionary()

const IdDictDictionary * AtlasDetectorID::dictionary ( const Identifier & id) const
privateinherited

Definition at line 1080 of file AtlasDetectorID.cxx.

1080 {
1081 if (is_indet(id)) {
1082 return m_indet_dict;
1083 }
1084 if (is_lar(id)) {
1085 return m_lar_dict;
1086 }
1087 if (is_tile(id)) {
1088 return m_tile_dict;
1089 }
1090 if (is_muon(id)) {
1091 return m_muon_dict;
1092 }
1093 if (is_lvl1_trig_towers(id) || is_lvl1_online(id) || is_lar_dm(id) || is_tile_dm(id)) {
1094 return m_calo_dict;
1095 }
1096 if (is_forward(id)) {
1097 return m_fwd_dict;
1098 }
1099 return nullptr;
1100}
const IdDictDictionary * m_calo_dict
const IdDictDictionary * m_muon_dict
bool is_indet(Identifier id) const
bool is_lar(Identifier id) const
bool is_lar_dm(Identifier id) const
LAr/Tile dead material:
bool is_lvl1_online(Identifier id) const
const IdDictDictionary * m_tile_dict
const IdDictDictionary * m_fwd_dict
bool is_muon(Identifier id) const
bool is_tile_dm(Identifier id) const
bool is_tile(Identifier id) const
const IdDictDictionary * m_indet_dict
bool is_forward(Identifier id) const
const IdDictDictionary * m_lar_dict
bool is_lvl1_trig_towers(Identifier id) const

◆ dictionaryVersion()

std::string AtlasDetectorID::dictionaryVersion ( void ) const
overridevirtualinherited

Implements IdHelper.

Definition at line 227 of file AtlasDetectorID.cxx.

227 {
228 return m_dict_version;
229}
std::string m_dict_version

◆ dictRegions()

const std::vector< const IdDictRegion * > & CaloIDHelper::dictRegions ( ) const

Return the vector of IdDictRegion, accessed via region hash.

◆ do_checks()

bool AtlasDetectorID::do_checks ( void ) const
overridevirtualinherited

Checks are performed by default in debug compilation and NOT in optimized compilation.

One can switch or query this mode for any idHelper with the following methods:

Implements IdHelper.

Definition at line 391 of file AtlasDetectorID.cxx.

391 {
392 return m_do_checks;
393}
bool m_do_checks
Flag for subclasses to know whether or not to perform checks.

◆ do_neighbours()

bool AtlasDetectorID::do_neighbours ( void ) const
overridevirtualinherited

Neighbour initialization is performed by default One can switch or query this mode for any idHelper with the following method:

Implements IdHelper.

Definition at line 398 of file AtlasDetectorID.cxx.

398 {
399 return m_do_neighbours;
400}
bool m_do_neighbours
Flag for subclasses to know whether or not to perform neighbour initialization.

◆ eta0()

float CaloIDHelper::eta0 ( const IdentifierHash regHash) const

Return the minimum eta of region, or NOT_VALID.

Parameters
regHashREGION hash code.

Definition at line 206 of file CaloIDHelper.cxx.

207{
208 if (regHash >= m_vecOfDictRegions.size()) return NOT_VALID;
209 return (m_vecOfDictRegions.at(regHash)->eta0());
210}
*List of c IdDictRegion objects std::vector< const IdDictRegion * > m_vecOfDictRegions

◆ etaGranularity()

float CaloIDHelper::etaGranularity ( const IdentifierHash regHash) const

Return the eta granularity of a region, or NOT_VALID.

Parameters
regHashREGION hash code.

Definition at line 184 of file CaloIDHelper.cxx.

185{
186 if (regHash >= m_vecOfDictRegions.size()) return NOT_VALID;
187 return m_vecOfDictRegions.at(regHash)->deta();
188}

◆ file_names()

const std::vector< std::string > & AtlasDetectorID::file_names ( void ) const
inherited

File names for subdet dictionaries.

Definition at line 385 of file AtlasDetectorID.cxx.

385 {
386 return m_file_names;
387}
std::vector< std::string > m_file_names
List of dictionary file names used by this helper.

◆ fill_vec_of_dict_regions()

int CaloIDHelper::fill_vec_of_dict_regions ( const std::string & group_name = "")
protected

Do basic initialization of the helper.

Parameters
dict_mgrThe dictionary manager returned from the parser.
dict_nameThe dictionary name (eg, `LArCalorimeter').
Returns
0 on success, non-zero on failure. */ int initialize_base_from_dictionary (const IdDictMgr& dict_mgr, const std::string& dict_name);

Return the HashGroup for channels (cells). non-const. HashGroup& channels(); Return the HashGroup for regions. non-const. HashGroup& regions();

Return the dictionary for this subdetector. const IdDictDictionary* dict() const;

/**

Initialize the list of detector regions. init_regions should have been called first.

Parameters
group_nameThe group for this helper.
Returns
0 on success; non-zero on failure.
Parameters
dict_mgrThe dictionary manager returned from the parser.
dict_nameThe dictionary name (eg, `LArCalorimeter').
Returns
0 on success, non-zero on failure. */ int CaloIDHelper::initialize_base_from_dictionary (const IdDictMgr& dict_mgr, const std::string& dict_name) { init base object if(AtlasDetectorID::initialize_from_dictionary(dict_mgr)) return (1);

Register version of dictionary if (register_dict_tag(dict_mgr, dict_name)) return(1);

m_dict = dict_mgr.find_dictionary (dict_name); if(!m_dict) { ATH_MSG_ERROR("cannot access " << dict_name << "dictionary"); return 1; } return 0; }

/**

Initialize the list of detector regions. init_regions should have been called first.

Parameters
group_nameThe group for this helper.
Returns
0 on success; non-zero on failure.

Definition at line 256 of file CaloIDHelper.cxx.

257{
258 m_vecOfDictRegions.clear();
259 m_vecOfDictRegions.reserve (regions().hash_max());
260 IdContext region_cntxt = region_context();
261 ExpandedIdentifier expRegId;
262 for (Identifier id : regions().range()) {
263 if(!get_expanded_id(id, expRegId, &region_cntxt)) {
264 m_vecOfDictRegions.push_back (m_dict->find_region(expRegId,group_name));
265 }
266 }
267 // cppcheck-suppress assertWithSideEffect
268 assert (m_vecOfDictRegions.size() == regions().hash_max());
269 return 0;
270}
static const std::vector< std::string > regions
const HashGroup & regions() const
Return the HashGroup for regions.
virtual int get_expanded_id(const Identifier &id, ExpandedIdentifier &exp_id, const IdContext *context) const =0
Create an expanded Identifier from an Identifier.
IdContext region_context() const
Return the context for regions.

◆ fix_barrel_ec()

std::string AtlasDetectorID::fix_barrel_ec ( const std::string & barrel_ec) const
protectedinherited

◆ forward_field_value()

int AtlasDetectorID::forward_field_value ( ) const
inlineprotectedinherited

Definition at line 514 of file AtlasDetectorID.h.

514{return (m_FWD_ID);}

◆ fwd_exp()

ExpandedIdentifier AtlasDetectorID::fwd_exp ( void ) const
protectedinherited

Definition at line 990 of file AtlasDetectorID.cxx.

991{
992 ExpandedIdentifier result;
993 return (result << m_FWD_ID);
994}

◆ get_expanded_id()

virtual int CaloIDHelper::get_expanded_id ( const Identifier & id,
ExpandedIdentifier & exp_id,
const IdContext * context ) const
protectedpure virtual

Create an expanded Identifier from an Identifier.

Returns
0 on success; non-zero on failure.
Parameters
idIdentifier to convert.
[out]exp_idThe expanded Identifier.
contextThe context in which to do the conversion (specifies whether we want channels or regions).

Implemented in LArEM_Base_ID, LArFCAL_Base_ID, LArHEC_Base_ID, LArMiniFCAL_ID, and Tile_Base_ID.

◆ get_hash()

int CaloIDHelper::get_hash ( const Identifier & id,
IdentifierHash & hash_id,
const IdContext * context = 0 ) const
virtual

Convert an Identifier to a hash code for either channels or regions, depending on the context.

Uses binary search. Some of the subdetector-specific helpers define faster versions of channel_hash and region_hash (that, however, do less checking).

Parameters
idThe identifier to convert.
[out]hash_idThe resulting hash code. Will be invalid if there was an error.
contextThe context in which to do the conversion (specifies whether we want channels or regions).
Returns
0 for success, non-zero for failure (unrecognized context or Identifier.

Reimplemented from AtlasDetectorID.

Reimplemented in Tile_Base_ID.

Definition at line 160 of file CaloIDHelper.cxx.

161{
162 hash_id = IdentifierHash();
163
164 size_t begin = (context) ? context->begin_index(): 0;
165 size_t end = (context) ? context->end_index() : 0;
166
167 if (0 == begin) {
168 const HashGroup* hg = nullptr;
169 if (m_channels.end_index() == end) hg = &m_channels;
170 else if (m_regions.end_index() == end) hg = &m_regions;
171
172 if (hg)
173 return hg->get_hash (id, hash_id);
174 }
175
176 return 1;
177}
Manage a list of identifiers.
*Group of region Identifiers HashGroup m_regions

◆ get_id()

int CaloIDHelper::get_id ( const IdentifierHash & hash_id,
Identifier & id,
const IdContext * context = 0 ) const
virtual

Convert a hash code to an Identifier for either channels or regions, depending on the context.

If you know the context at compile-time, channel_id and region_id will be faster (but they don't do range checking).

Parameters
hash_idThe hash code to convert.
[out]idThe resulting Identifier. Will be invalid if there was an error.
contextThe context in which to do the conversion (specifies whether we want channels or regions).
Returns
0 for success, non-zero for failure (unrecognized context, or hash code out of range).

Reimplemented from AtlasDetectorID.

Reimplemented in Tile_Base_ID.

Definition at line 118 of file CaloIDHelper.cxx.

121{
122 int result = 1;
123 id.clear();
124
125 size_t begin = (context) ? context->begin_index(): 0;
126 size_t end = (context) ? context->end_index() : 0;
127
128 if (0 == begin) {
129 const HashGroup* hg = nullptr;
130 if (m_channels.end_index() == end) hg = &m_channels;
131 else if (m_regions.end_index() == end) hg = &m_regions;
132
133 if (hg) {
134 if (hash_id < hg->hash_max()) {
135 id = hg->id (hash_id);
136 result = 0;
137 }
138 }
139 }
140
141 return(result);
142}

◆ group()

const std::string & AtlasDetectorID::group ( ) const
inherited

Group name for this helper.

Definition at line 39 of file AtlasDetectorID.cxx.

40{
41 return m_group;
42}
std::string m_group
Group name.

◆ helper()

virtual HelperType AtlasDetectorID::helper ( ) const
inlinevirtualinherited

Type of helper, defaulted to 'Unimplemented'.

Reimplemented in PixelID, PLR_ID, and SCT_ID.

Definition at line 92 of file AtlasDetectorID.h.

◆ hgtd()

Identifier AtlasDetectorID::hgtd ( void ) const
inherited

Definition at line 94 of file AtlasDetectorID.cxx.

94 {
96}
IdDictFieldImplementation m_indet_part_impl
int indet_field_value() const
Provide efficient access to individual field values, for subclass idhelpers.

◆ hgtd_exp()

ExpandedIdentifier AtlasDetectorID::hgtd_exp ( void ) const
protectedinherited

Definition at line 1018 of file AtlasDetectorID.cxx.

1019{
1020 ExpandedIdentifier result(indet_exp());
1021 return (result << m_HGTD_ID);
1022}
ExpandedIdentifier indet_exp(void) const
Detector systems:

◆ hgtd_field_value()

int AtlasDetectorID::hgtd_field_value ( ) const
inlineprotectedinherited

Definition at line 478 of file AtlasDetectorID.h.

478{return (m_HGTD_ID);}

◆ indet()

Identifier AtlasDetectorID::indet ( void ) const
inherited

Detector systems:

Definition at line 62 of file AtlasDetectorID.cxx.

62 {
63 return m_det_impl.new_pack(indet_field_value());
64}

◆ indet_exp()

ExpandedIdentifier AtlasDetectorID::indet_exp ( void ) const
protectedinherited

Detector systems:

Definition at line 955 of file AtlasDetectorID.cxx.

956{
957 ExpandedIdentifier result;
958 return (result << m_INDET_ID);
959}

◆ indet_field_value()

int AtlasDetectorID::indet_field_value ( ) const
inlineprotectedinherited

Provide efficient access to individual field values, for subclass idhelpers.

Definition at line 454 of file AtlasDetectorID.h.

454{return (m_INDET_ID);}

◆ initialize_from_dictionary()

int AtlasDetectorID::initialize_from_dictionary ( const IdDictMgr & dict_mgr)
overridevirtualinherited

Initialization from the identifier dictionary.

Implements IdHelper.

Reimplemented in CaloCell_Base_ID, CaloCell_ID, CaloDM_ID, CaloLVL1_ID, CscIdHelper, GTower_ID, HGTD_ID, JTower_ID, LArElectrodeID, LArEM_ID, LArEM_SuperCell_ID, LArFCAL_ID, LArFCAL_SuperCell_ID, LArHEC_ID, LArHEC_SuperCell_ID, LArHVLineID, LArMiniFCAL_ID, LArOnline_SuperCellID, LArOnlineID, LArOnlineID_Base, MdtIdHelper, MmIdHelper, MuonIdHelper, PixelID, PLR_ID, RpcIdHelper, SCT_ID, SiliconID, sTgcIdHelper, TgcIdHelper, Tile_SuperCell_ID, TileHWID, TileID, TileTBID, TRT_ID, TTOnlineID, and ZdcID.

Definition at line 201 of file AtlasDetectorID.cxx.

201 {
202
203 // Register version of ATLAS dictionary
204 if (register_dict_tag(dict_mgr, "ATLAS")){
205 ATH_MSG_ERROR(__func__<<":"<<__LINE__<<" - Failed to register dict tag");
206 return 1;
207 }
208 // Initialize helper, needed for init of AtlasDetectorID
209 if (!m_helper) {
210 m_helper = std::make_unique<AtlasDetectorIDHelper>();
211 }
212
213 if (m_helper->initialize_from_dictionary(dict_mgr)){
214 ATH_MSG_ERROR(__func__<<":"<<__LINE__<<" - Initialization from dictionary failed.");
215 return 1;
216 }
217 // Initialize level indices and id values from dicts
218 if (initLevelsFromDict(dict_mgr)) {
219 ATH_MSG_ERROR(__func__<<":"<<__LINE__<<" - Level initialization from dictionary failed.");
220 return 1;
221 }
223 ATH_MSG_DEBUG("initialize_from_dictionary - OK");
224 return 0;
225}
#define ATH_MSG_ERROR(x)
#define ATH_MSG_DEBUG(x)
int register_dict_tag(const IdDictMgr &dict_mgr, const std::string &dict_name)
Register the file and tag names for a particular IdDict dictionary.
int initLevelsFromDict(const IdDictMgr &dict_mgr)
std::unique_ptr< AtlasDetectorIDHelper > m_helper

◆ initLevelsFromDict()

int AtlasDetectorID::initLevelsFromDict ( const IdDictMgr & dict_mgr)
privateinherited

Definition at line 425 of file AtlasDetectorID.cxx.

425 {
426
427 // Set do_checks flag
428 if (dict_mgr.do_checks())
429 m_do_checks = true;
430 // Set do_neighbours flag
431 if (!dict_mgr.do_neighbours())
432 m_do_neighbours = false;
433
434
435 const IdDictField *field{nullptr};
436
437 // Find out from the dictionary the detector and subdetector
438 // levels and id values
465
466 // Save generic dict for top levels
467 const IdDictDictionary *top_dict {nullptr};
468
469 auto assignSystemId = [this, &field](const std::string& systemName,
470 int& idToAssign,
471 bool mandatory = true) ->bool {
472 const IdDictLabel *label = field->find_label(systemName);
473 if (label && label->valued()){
474 idToAssign = label->value();
475 ATH_MSG_VERBOSE("Assign system "<<systemName<<" to "<<idToAssign<<".");
476 return true;
477 } else if (label) {
478 ATH_MSG_ERROR("initLevelsFromDict - label "<<systemName<<" does NOT have a value ");
479 return false;
480 }
481 if (mandatory) {
482 ATH_MSG_ERROR("initLevelsFromDict - unable to find '"<<systemName<<"' label");
483 return false;
484 }
485 ATH_MSG_DEBUG("initLevelsFromDict - unable to find '"<<systemName<<"' label");
486 return true;
487 };
488 // Get det ids
489
490 // Initialize ids for InDet subdet
491 m_indet_dict = dict_mgr.find_dictionary("InnerDetector");
492 if (!m_indet_dict) {
493 ATH_MSG_WARNING("initLevelsFromDict - cannot access InnerDetector dictionary");
494 } else {
495 // Found InDet dict
496 top_dict = m_indet_dict; // save as top_dict
497 // Check if this is High Luminosity LHC layout
498 // should just use std::string::contains once that is available... (C++23)
499 std::string versionString = m_indet_dict->version();
500 m_isHighLuminosityLHC = (versionString.find("ITk") != std::string::npos || versionString.find("P2-RUN4") != std::string::npos);
501
502 // Get InDet subdets
503 field = m_indet_dict->find_field("part");
504 if (!field) {
505 ATH_MSG_ERROR("initLevelsFromDict - unable to find 'part' field for InnerDetector dictionary");
506 return 1;
507 }
508
509 if (!assignSystemId("Pixel", m_PIXEL_ID)) {
510 return 1;
511 }
512 if (!assignSystemId("SCT", m_SCT_ID)) {
513 return 1;
514 }
515 if (!assignSystemId("TRT", m_TRT_ID, !m_isHighLuminosityLHC)) {
516 return 1;
517 }
519 if (!assignSystemId("LuminosityDetectors", m_LUMI_ID, versionString.find("PLR") != std::string::npos ||
520 versionString.find("P2-RUN4") != std::string::npos)) {
521 return 1;
522 }
523 if (!assignSystemId("HGTD", m_HGTD_ID)){
524 return 1;
525 }
526 }
527 }
528 // Initialize ids for Forward dets
529 m_fwd_dict = dict_mgr.find_dictionary("ForwardDetectors");
530 if (!m_fwd_dict) {
531 ATH_MSG_WARNING("initLevelsFromDict - cannot access ForwardDetectors dictionary");
532 } else {
533
534 // Found ForwardDetectors dict
535
536 if (!top_dict){
537 top_dict = m_fwd_dict; // save as top_dict
538 }
539 // Get Forward subdets
540
541 field = m_fwd_dict->find_field("part");
542 if (!field) {
543 ATH_MSG_ERROR("initLevelsFromDict - unable to find 'part' field for ForwardDetectors dictionary");
544 return 1;
545 }
546 if (!assignSystemId("ALFA", m_ALFA_ID)) {
547 return 1;
548 }
549 if (!assignSystemId("BCM", m_BCM_ID)) {
550 return 1;
551 }
552 if (!assignSystemId("LUCID", m_LUCID_ID)) {
553 return 1;
554 }
555 if (!assignSystemId("ZDC", m_ZDC_ID)) {
556 return 1;
557 }
558 }
559
560 // Initialize ids for LAr detectors
561 m_lar_dict = dict_mgr.find_dictionary("LArCalorimeter");
562 if (!m_lar_dict) {
563 ATH_MSG_WARNING("initLevelsFromDict - cannot access LArCalorimeter dictionary");
564 } else {
565 // Found LAr dict
566
567 if (!top_dict) {
568 top_dict = m_lar_dict; // save as top_dict
569 }
570 field = m_lar_dict->find_field("part");
571 if (!field) {
572 ATH_MSG_ERROR("initLevelsFromDict - unable to find 'part' field for LArCalorimeter dictionary");
573 return 1;
574 }
575 if (!assignSystemId("LArEM", m_LAR_EM_ID)) {
576 return 1;
577 }
578 if (!assignSystemId("LArHEC", m_LAR_HEC_ID)) {
579 return 1;
580 }
581 if (!assignSystemId("LArFCAL", m_LAR_FCAL_ID)) {
582 return 1;
583 }
584 field = m_lar_dict->find_field("module");
585 if (field) {
587 } else {
588 ATH_MSG_DEBUG("initLevelsFromDict - unable to find 'module' field for miniFCAL");
589 }
590 }
591
592 // Initialize ids for Tile calo
593 m_tile_dict = dict_mgr.find_dictionary("TileCalorimeter");
594 if (!m_tile_dict) {
595 ATH_MSG_WARNING("initLevelsFromDict - cannot access TileCalorimeter dictionary");
596 } else {
597 // File Tile
598 if (!top_dict)
599 top_dict = m_tile_dict; // save as top_dict
600 }
601
602 // Initialize ids for Muon detectors
603 m_muon_dict = dict_mgr.find_dictionary("MuonSpectrometer");
604 if (!m_muon_dict) {
605 ATH_MSG_WARNING("initLevelsFromDict - cannot access MuonSpectrometer dictionary");
606 } else {
607 // Found muon dict
608 if (!top_dict){
609 top_dict = m_muon_dict; // save as top_dict
610 }
611 /*
612 During initialisation from the dictionary we parse the
613 information which muon stationName belongs to which muon
614 subsystem. This information is not entirely encoded in the
615 identifiers however it is frequently tested during
616 reconstruction. In order to speed up these checks this info
617 is now stored locally into m_muon_tech_bits.
618 P.Fleischmann 04.04.2013
619 */
620 if (m_muon_tech_bits.empty()) {
621 // we only need to load this once
622 field = m_muon_dict->find_field("stationName");
623 if (!field) {
624 ATH_MSG_ERROR("initLevelsFromDict - unable to find 'stationName' field for MuonSpectrometer dictionary");
625 return 1;
626 }
627
628 size_type nStationNames = field->get_label_number();
629 std::string stationNameString{};
630
631 // first check for the maximum value assigned to any stationName
632 int stationNameIndex{};
633 int maxStationNameIndex{-1};
634 for (size_type i = 0; i < nStationNames; ++i) {
635 // in case no individual values are given,
636 // the order inside the dictionary is used
637 const IdDictLabel& label = field->label(i);
638 stationNameIndex = label.valued() ? label.value() : i;
639
640 maxStationNameIndex = std::max(maxStationNameIndex, stationNameIndex);
641 }
642
643 // the vector may contain gaps (value=0) in case of jumps
644 // in the values
645 m_muon_tech_bits.resize(maxStationNameIndex + 1);
646
647 // loop over all stationNames and search for associations
648 // to technology
649 for (size_type i = 0; i < nStationNames; ++i) {
650 const IdDictLabel& label = field->label(i);
651 stationNameString = label.name();
652 // in case no individual values are given,
653 // the order inside the dictionary is used
654 stationNameIndex = label.valued() ? label.value() : i;
655 // next loop over all regions to look for
656 // stationName <-> technology associations
657 bool found{false}, stationNameFound{false}, technologyFound{false};
658 std::string techLabel{};
659 size_t nregions = m_muon_dict->n_regions();
660 for (size_type j = 0; j < nregions; ++j) {
661 const IdDictRegion& region = m_muon_dict->region(j);
662 // loop over all entries of a region to look for
663 // stationName and technology information
664 stationNameFound = technologyFound = false;
665 size_t nentries = region.n_entries();
666 for (size_type k = 0; k < nentries; ++k) {
667 const IdDictRange *range =
668 dynamic_cast<const IdDictRange *>(&region.entry(k));
669 if (!range) {
670 continue;
671 }
672
673 if (range->field_name() == "stationName") {
674
675 if (range->label() == stationNameString) {
676 // we found a region containing the current stationName
677 stationNameFound = true;
678 continue;
679 } else {
680 // we found a region containing a different stationName,
681 // let's skip
682 break;
683 }
684 } else if (range->field_name() == "technology") {
685 technologyFound = true;
686 techLabel = range->label();
687 }
688
689 if (!stationNameFound || !technologyFound) {
690 continue;
691 }
692
693 // we found a stationName <-> technology association
694 if (techLabel == "MDT") {
695 m_muon_tech_bits[stationNameIndex] = AtlasDetDescr::fAtlasMDT;
696 } else if (techLabel == "RPC") {
697 m_muon_tech_bits[stationNameIndex] = AtlasDetDescr::fAtlasRPC;
698 } else if (techLabel == "CSC") {
699 m_muon_tech_bits[stationNameIndex] = AtlasDetDescr::fAtlasCSC;
700 } else if (techLabel == "TGC"){
701 m_muon_tech_bits[stationNameIndex] = AtlasDetDescr::fAtlasTGC;
702 } else if (techLabel == "MM") {
703 m_muon_tech_bits[stationNameIndex] = AtlasDetDescr::fAtlasMM;
704 } else if (techLabel == "STGC") {
706 } else {
708 }
709 found = true;
710 break;
711 } // end of loop overregion entries
712
713 if (found) {
714 // no need to continue to look for this stationName,
715 // since each stationName must be uniquely associated
716 // to a technology, except for MDT/PRC
717 break;
718 }
719
720 } // end of loop over regions
721
722 } // end of loop over stationNames
723 }
724 // end of filling stationName <-> technology associations
725
726 field = m_muon_dict->find_field("technology");
727 if (field) {
728 m_MUON_SUBDET_INDEX = field->index();
729 }
730 else {
731 ATH_MSG_ERROR("initLevelsFromDict - unable to find 'technology' field for MuonSpectrometer dictionary");
732 return 1;
733 }
734
735 if (!assignSystemId("MDT", m_MDT_ID)) {
736 return 1;
737 }
738 if (!assignSystemId("RPC", m_RPC_ID)) {
739 return 1;
740 }
741 if (!assignSystemId("TGC", m_TGC_ID)) {
742 return 1;
743 }
744 if (!assignSystemId("STGC", m_STGC_ID, false)) {
745 return 1;
746 }
747 if (!assignSystemId("MM", m_MM_ID, false)) {
748 return 1;
749 }
750 if (!assignSystemId("CSC", m_CSC_ID, false)) {
751 return 1;
752 }
753 }
754
755 // Initialize id for Calo and fields for lvl1 and dead material
756 m_calo_dict = dict_mgr.find_dictionary("Calorimeter");
757 if (!m_calo_dict) {
758 ATH_MSG_WARNING("initLevelsFromDict - Warning cannot access Calorimeter dictionary");
759 } else {
760 // Found calo dict
761 if (!top_dict) {
762 top_dict = m_calo_dict; // save as top_dict
763 }
764 // Set lvl1 field for is_lvl1_trig_towers
765 int value{0};
766 m_lvl1_field.clear();
767 // negative half
768 if (m_calo_dict->get_label_value("DetZside", "negative_lvl1_side", value)) {
769 ATH_MSG_ERROR("initLevelsFromDict - Could not get value for label 'negative_lvl1_side' of field 'DetZside' in dictionary " << m_calo_dict->name());
770 return 1;
771 }
772 m_lvl1_field.add_value(value);
773 // positive half
774 if (m_calo_dict->get_label_value("DetZside", "positive_lvl1_side", value)) {
775 ATH_MSG_ERROR("initLevelsFromDict - Could not get value for label 'positive_lvl1_side' of field 'DetZside' in dictionary " << m_calo_dict->name());
776 return 1;
777 }
778 m_lvl1_field.add_value(value);
779 // Set lar dead material field for is_lar_dm
780 m_lar_dm_field.clear();
781 // negative half
782 if (m_calo_dict->get_label_value("DetZside", "negative_DMLar_side", value)) {
783 ATH_MSG_ERROR("initLevelsFromDict - Could not get value for label 'negative_DMLar_side' of field 'DetZside' in dictionary " << m_calo_dict->name());
784 return 1;
785 }
786 m_lar_dm_field.add_value(value);
787 // positive half
788 if (m_calo_dict->get_label_value("DetZside", "positive_DMLar_side", value)) {
789 ATH_MSG_ERROR("initLevelsFromDict - Could not get value for label 'positive_DMLar_side' of field 'DetZside' in dictionary " << m_calo_dict->name());
790 return 1;
791 }
792 m_lar_dm_field.add_value(value);
793
794 // Set tile dead material field for is_tile_dm
795 m_tile_dm_field.clear();
796 // negative half
797 if (m_calo_dict->get_label_value("DetZside", "negative_DMTile_side", value)) {
798 ATH_MSG_ERROR("initLevelsFromDict - Could not get value for label 'negative_DMTile_side' of field 'DetZside' in dictionary " << m_calo_dict->name());
799 return 1;
800 }
801 m_tile_dm_field.add_value(value);
802 // positive half
803 if (m_calo_dict->get_label_value("DetZside", "positive_DMTile_side", value)) {
804 ATH_MSG_ERROR("initLevelsFromDict - Could not get value for label 'positive_DMTile_side' of field 'DetZside' in dictionary " << m_calo_dict->name());
805 return 1;
806 }
807 m_tile_dm_field.add_value(value);
808
809 // Set lvl1 field for is_lvl1_online
810 m_lvl1_onl_field.clear();
811 if (m_calo_dict->get_label_value("DetZside", "no_side", value)) {
812 ATH_MSG_DEBUG("initLevelsFromDict - Could not get value for label 'no_side' of field 'DetZside' in dictionary " << m_calo_dict->name());
813 } else {
814 m_lvl1_onl_field.add_value(value);
815 }
816 }
817
818 // set det/subdet indices
819 if (top_dict){
820
821 field = top_dict->find_field("subdet");
822 if (field) {
823 m_DET_INDEX = field->index();
824 } else {
825 ATH_MSG_ERROR("initLevelsFromDict - - unable to find 'subdet' field from dict "
826 << top_dict->name());
827 return 1;
828 }
829
830 if (!assignSystemId("InnerDetector", m_INDET_ID)) {
831 return 1;
832 }
833 if (!assignSystemId("ForwardDetectors", m_FWD_ID)) {
834 return 1;
835 }
836 if (!assignSystemId("LArCalorimeter", m_LAR_ID)) {
837 return 1;
838 }
839 if (!assignSystemId("TileCalorimeter", m_TILE_ID)) {
840 return 1;
841 }
842
843 if (!assignSystemId("MuonSpectrometer", m_MUON_ID)) {
844 return 1;
845 }
846 if (!assignSystemId("Calorimeter", m_CALO_ID)) {
847 return 1;
848 }
849 // Get name of next level
850 std::string name{};
851 if (top_dict->name() == "InnerDetector") {
852 name = "part";
853 } else if (top_dict->name() == "Calorimeter") {
854 name = "DetZside";
855 } else if (top_dict->name() == "LArCalorimeter") {
856 name = "part";
857 } else if (top_dict->name() == "MuonSpectrometer") {
858 name = "stationName";
859 } else if (top_dict->name() == "TileCalorimeter") {
860 name = "section";
861 } else if (top_dict->name() == "ForwardDetectors") {
862 name = "part";
863 }
864 // While we're here, save the index to the sub-detector level
865 // ("part" for InDet)
866 field = top_dict->find_field(name);
867 if (field) {
868 m_SUBDET_INDEX = field->index();
869 }
870 else {
871 ATH_MSG_ERROR("initLevelsFromDict - unable to find field " << name << " from dict "<< top_dict->name());
872 return 1;
873 }
874 } else {
875 ATH_MSG_ERROR("initLevelsFromDict - no top dictionary defined");
876 return 1;
877 }
878
879 // Set the field implementations
880
881 size_type region_index = m_helper->pixel_region_index();
882 if (m_indet_dict && AtlasDetectorIDHelper::UNDEFINED != region_index) {
883
884 const IdDictRegion& region = m_indet_dict->region(region_index);
885
886 // Detector
888
889 // Add on extra values to assure that one has a value per
890 // bit. This is needed to avoid an overflow decoding error
891 // when a pixel channel id is decoded
892 if (not m_det_impl.ored_field().isEnumerated()) {
893 ATH_MSG_ERROR("initLevelsFromDict - ERROR det implementation is not enumerated: "
894 << m_det_impl);
895 return 1;
896 }
897
898 size_type bits = m_det_impl.bits();
899 size_type nvalues = static_cast<size_type>(1) << bits;
900 Range::field det = m_det_impl.ored_field();
901 size_type max = det.get_maximum();
902 for (size_type i = det.get_values().size(); i < nvalues; ++i) {
903 ++max;
904 det.add_value(max);
905 }
906 // Replace ored field with modified one
907 m_det_impl.set_ored_field(det);
908 ATH_MSG_VERBOSE("set extra bits "<< m_det_impl);
909
910 // InDet part
912 }
913
914 // Calo side: LVL1, LAr & Tile DeadMat
915 region_index = m_helper->lvl1_region_index();
916 if (m_calo_dict && AtlasDetectorIDHelper::UNDEFINED != region_index) {
917 const IdDictRegion& region = m_calo_dict->region(region_index);
919 }
920
921 // LAr part
922 region_index = m_helper->lar_em_region_index();
923 if (m_lar_dict && AtlasDetectorIDHelper::UNDEFINED != region_index) {
924 const IdDictRegion& region = m_lar_dict->region(region_index);
926 }
927
928 // LAr part
929 region_index = m_helper->lar_fcal_region_index();
930 if (m_lar_dict && AtlasDetectorIDHelper::UNDEFINED != region_index &&
932 const IdDictRegion& region = m_lar_dict->region(region_index);
934 }
935
936 // Muon station name
937 region_index = m_helper->mdt_region_index();
938 if (m_muon_dict && AtlasDetectorIDHelper::UNDEFINED != region_index) {
939 const IdDictRegion& region = m_muon_dict->region(region_index);
941 // Muon MDT
943 // Muon RPC
944 region_index = m_helper->rpc_region_index();
945 if (AtlasDetectorIDHelper::UNDEFINED != region_index) {
946 const IdDictRegion& rpc_region = m_muon_dict->region(region_index);
948 }
949 }
950 return 0;
951}
#define ATH_MSG_VERBOSE(x)
#define ATH_MSG_WARNING(x)
#define max(a, b)
Definition cfImp.cxx:41
Range::field m_lvl1_field
Range::field m_lar_dm_field
size_type m_SUBDET_INDEX
IdDictFieldImplementation m_calo_side_impl
Identifier::size_type size_type
static constexpr int invalidId
IdDictFieldImplementation m_lar_part_impl
Range::field m_lvl1_onl_field
IdDictFieldImplementation m_lar_fcal_module_impl
IdDictFieldImplementation m_muon_mdt_impl
static constexpr int invalidIndex
IdDictFieldImplementation m_muon_rpc_impl
size_type m_MUON_SUBDET_INDEX
std::vector< unsigned int > m_muon_tech_bits
Range::field m_tile_dm_field
IdDictFieldImplementation m_muon_station_name_impl
const std::string & name() const
Dictionary name.
const IdDictField * find_field(const std::string &name) const
bool do_checks() const
Check whether or not to do checks for ids.
Definition IdDictMgr.cxx:62
bool do_neighbours() const
Check whether or not to init neighbours.
Definition IdDictMgr.cxx:74
const IdDictDictionary * find_dictionary(const std::string &name) const
Access dictionary by name.
const IdDictRegionEntry & entry(size_t i) const
size_t n_entries() const
const IdDictFieldImplementation & implementation(size_t i) const
std::string label(const std::string &format, int i)
Definition label.h:19
float j(const xAOD::IParticle &, const xAOD::TrackMeasurementValidation &hit, const Eigen::Matrix3d &jab_inv)

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 39 of file AthMessaging.cxx.

40{
42 // If user did not set an explicit level, set a default
43 if (m_lvl == MSG::NIL) {
44 m_lvl = m_imsg ?
45 static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
46 MSG::INFO;
47 }
48}
std::string m_nm
Message source name.
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
Current logging level.
IMessageSvc * getMessageSvc(bool quiet=false)

◆ is_alfa()

bool AtlasDetectorID::is_alfa ( Identifier id) const
inlineinherited

Definition at line 784 of file AtlasDetectorID.h.

785{
786 bool result = false;
787 if(is_forward(id)) {
788 result = (std::abs(m_lar_part_impl.unpack(id)) == m_ALFA_ID);
789 }
790 return result;
791}

◆ is_bcm()

bool AtlasDetectorID::is_bcm ( Identifier id) const
inlineinherited

Definition at line 794 of file AtlasDetectorID.h.

795{
796 bool result = false;
797 if(is_forward(id)) {
798 result = (std::abs(m_lar_part_impl.unpack(id)) == m_BCM_ID);
799 }
800 return result;
801}

◆ is_calo() [1/2]

bool AtlasDetectorID::is_calo ( const ExpandedIdentifier & id) const
inherited

Definition at line 242 of file AtlasDetectorID.cxx.

242 {
243 return id.fields() > 0 && id[0] == m_CALO_ID;
244}

◆ is_calo() [2/2]

bool AtlasDetectorID::is_calo ( Identifier id) const
inlineinherited

Definition at line 550 of file AtlasDetectorID.h.

551{
552 return (m_det_impl.unpack(id) == m_CALO_ID);
553}

◆ is_csc() [1/2]

bool AtlasDetectorID::is_csc ( const ExpandedIdentifier & id) const
inherited

Definition at line 284 of file AtlasDetectorID.cxx.

284 {
285 return id.fields() > 4 && id[0] == m_MUON_ID && id[4] == m_CSC_ID;
286}

◆ is_csc() [2/2]

bool AtlasDetectorID::is_csc ( Identifier id) const
inlineinherited

Definition at line 734 of file AtlasDetectorID.h.

735{
736 bool result = false;
737 if (!is_muon(id)) return false;
738 unsigned int stationNameIndex = m_muon_station_name_impl.unpack(id);
739 unsigned int techBit = m_muon_tech_bits[stationNameIndex];
740 result = (is_muon(id) && (techBit == AtlasDetDescr::fAtlasCSC));
741 return result;
742}

◆ is_forward()

bool AtlasDetectorID::is_forward ( Identifier id) const
inlineinherited

Definition at line 778 of file AtlasDetectorID.h.

779{
780 return (m_det_impl.unpack(id) == m_FWD_ID);
781}

◆ is_hgtd() [1/2]

bool AtlasDetectorID::is_hgtd ( const ExpandedIdentifier & id) const
inherited

Definition at line 255 of file AtlasDetectorID.cxx.

255 {
256 return is_indet(id) && id.fields() > 1 && id[1] == m_HGTD_ID;
257}

◆ is_hgtd() [2/2]

bool AtlasDetectorID::is_hgtd ( Identifier id) const
inlineinherited

Definition at line 637 of file AtlasDetectorID.h.

638{
639 bool result = false;
640 // Must check is_pixel to allow for special bits
641 // (don't need this check for 64-bit identifier, but leave it in for now)
642 if(is_indet(id) && !is_pixel(id)) {
643 result = (m_indet_part_impl.unpack(id) == m_HGTD_ID);
644 }
645 return result;
646}
bool is_pixel(Identifier id) const

◆ is_indet() [1/2]

bool AtlasDetectorID::is_indet ( const ExpandedIdentifier & id) const
inherited

Definition at line 230 of file AtlasDetectorID.cxx.

230 {
231 return id.fields() > 0 && id[0] == m_INDET_ID;
232}

◆ is_indet() [2/2]

bool AtlasDetectorID::is_indet ( Identifier id) const
inlineinherited

Definition at line 526 of file AtlasDetectorID.h.

527{
528 return (m_det_impl.unpack(id) == m_INDET_ID);
529}

◆ is_lar() [1/2]

bool AtlasDetectorID::is_lar ( const ExpandedIdentifier & id) const
inherited

Definition at line 233 of file AtlasDetectorID.cxx.

233 {
234 return id.fields() > 0 && id[0] == m_LAR_ID;
235}

◆ is_lar() [2/2]

bool AtlasDetectorID::is_lar ( Identifier id) const
inlineinherited

Definition at line 532 of file AtlasDetectorID.h.

533{
534 return (m_det_impl.unpack(id) == m_LAR_ID);
535}

◆ is_lar_dm()

bool AtlasDetectorID::is_lar_dm ( Identifier id) const
inlineinherited

LAr/Tile dead material:

Definition at line 579 of file AtlasDetectorID.h.

580{
581 bool result = false;
582 if (is_calo(id)) {
583 int temp = m_calo_side_impl.unpack(id);
584 result = (m_lar_dm_field.match(temp));
585 }
586 return result;
587}
bool is_calo(Identifier id) const

◆ is_lar_em() [1/2]

bool AtlasDetectorID::is_lar_em ( const ExpandedIdentifier & id) const
inherited

Definition at line 265 of file AtlasDetectorID.cxx.

265 {
266 return is_lar(id) && id.fields() > 1 && std::abs(id[1]) == m_LAR_EM_ID;
267}

◆ is_lar_em() [2/2]

bool AtlasDetectorID::is_lar_em ( Identifier id) const
inlineinherited

Definition at line 661 of file AtlasDetectorID.h.

662{
663 bool result = false;
664 if(is_lar(id)) {
665 result = (std::abs(m_lar_part_impl.unpack(id)) == m_LAR_EM_ID);
666 }
667 return result;
668}

◆ is_lar_fcal() [1/2]

bool AtlasDetectorID::is_lar_fcal ( const ExpandedIdentifier & id) const
inherited

Definition at line 272 of file AtlasDetectorID.cxx.

272 {
273 return is_lar(id) && id.fields() > 1 && std::abs(id[1]) == m_LAR_FCAL_ID;
274}

◆ is_lar_fcal() [2/2]

bool AtlasDetectorID::is_lar_fcal ( Identifier id) const
inlineinherited

Definition at line 682 of file AtlasDetectorID.h.

683{
684 bool result = false;
685 if(is_lar(id)) {
686 result = (std::abs(m_lar_part_impl.unpack(id)) == m_LAR_FCAL_ID);
687 }
688 return result;
689}

◆ is_lar_hec() [1/2]

bool AtlasDetectorID::is_lar_hec ( const ExpandedIdentifier & id) const
inherited

Definition at line 268 of file AtlasDetectorID.cxx.

268 {
269 return is_lar(id) && id.fields() > 1 && std::abs(id[1]) == m_LAR_HEC_ID;
270}

◆ is_lar_hec() [2/2]

bool AtlasDetectorID::is_lar_hec ( Identifier id) const
inlineinherited

Definition at line 672 of file AtlasDetectorID.h.

673{
674 bool result = false;
675 if(is_lar(id)) {
676 result = (std::abs(m_lar_part_impl.unpack(id)) == m_LAR_HEC_ID);
677 }
678 return result;
679}

◆ is_lar_minifcal() [1/2]

bool AtlasDetectorID::is_lar_minifcal ( const ExpandedIdentifier & id) const
inherited

Definition at line 276 of file AtlasDetectorID.cxx.

276 {
277 return is_lar_fcal(id) && id.fields() > 3 &&std::abs(id[3]) == 0;
278}
bool is_lar_fcal(Identifier id) const

◆ is_lar_minifcal() [2/2]

bool AtlasDetectorID::is_lar_minifcal ( Identifier id) const
inlineinherited

Definition at line 692 of file AtlasDetectorID.h.

693{
694 bool result = false;
695 if(is_lar_fcal(id)) {
696 result = (m_lar_fcal_module_impl.unpack(id) == 0);
697 }
698 return result;
699}

◆ is_lucid()

bool AtlasDetectorID::is_lucid ( Identifier id) const
inlineinherited

Definition at line 804 of file AtlasDetectorID.h.

805{
806 bool result = false;
807 if(is_forward(id)) {
808 result = (std::abs(m_lar_part_impl.unpack(id)) == m_LUCID_ID);
809 }
810 return result;
811}

◆ is_lumi() [1/2]

bool AtlasDetectorID::is_lumi ( const ExpandedIdentifier & id) const
inherited

Definition at line 258 of file AtlasDetectorID.cxx.

258 {
259 return is_indet(id) && id.fields() > 1 && id[1] == m_LUMI_ID;
260}

◆ is_lumi() [2/2]

bool AtlasDetectorID::is_lumi ( Identifier id) const
inlineinherited

Definition at line 649 of file AtlasDetectorID.h.

650{
651 bool result = false;
652 // Must check is_pixel to allow for special bits
653 // (don't need this check for 64-bit identifier, but leave it in for now)
654 if(is_indet(id) && !is_pixel(id)) {
655 result = (m_indet_part_impl.unpack(id) == m_LUMI_ID);
656 }
657 return result;
658}

◆ is_lvl1_online()

bool AtlasDetectorID::is_lvl1_online ( Identifier id) const
inlineinherited

Definition at line 567 of file AtlasDetectorID.h.

568{
569 bool result = false;
570 if (is_calo(id)) {
571 int temp = m_calo_side_impl.unpack(id);
572 result = (m_lvl1_onl_field.match(temp));
573 }
574 return result;
575}

◆ is_lvl1_trig_towers()

bool AtlasDetectorID::is_lvl1_trig_towers ( Identifier id) const
inlineinherited

Definition at line 556 of file AtlasDetectorID.h.

557{
558 bool result = false;
559 if (is_calo(id)) {
560 int temp = m_calo_side_impl.unpack(id);
561 result = (m_lvl1_field.match(temp));
562 }
563 return result;
564}

◆ is_mdt() [1/2]

bool AtlasDetectorID::is_mdt ( const ExpandedIdentifier & id) const
inherited

Definition at line 280 of file AtlasDetectorID.cxx.

280 {
281 return id.fields() > 4 && id[0] == m_MUON_ID && id[4] == m_MDT_ID;
282}

◆ is_mdt() [2/2]

bool AtlasDetectorID::is_mdt ( Identifier id) const
inlineinherited

Definition at line 702 of file AtlasDetectorID.h.

703{
704 bool result = false;
705 if (!is_muon(id)) return false;
706 unsigned int stationNameIndex = m_muon_station_name_impl.unpack(id);
707 unsigned int techBit = m_muon_tech_bits[stationNameIndex];
708 // MDT and RPC can only be destinguished by the additional bit in the ID
709 // since the station names are ambiguous
710 if (is_muon(id) && ((techBit == AtlasDetDescr::fAtlasMDT)
711 || (techBit == AtlasDetDescr::fAtlasRPC))) {
712 result = (m_muon_mdt_impl.unpack(id) == m_MDT_ID);
713 }
714 return result;
715}

◆ is_mm() [1/2]

bool AtlasDetectorID::is_mm ( const ExpandedIdentifier & id) const
inherited

Definition at line 300 of file AtlasDetectorID.cxx.

300 {
301 return id.fields() > 4 && id[0] == m_MUON_ID && id[4] == m_MM_ID;
302}

◆ is_mm() [2/2]

bool AtlasDetectorID::is_mm ( Identifier id) const
inlineinherited

Definition at line 756 of file AtlasDetectorID.h.

757{
758 bool result = false;
759 if (!is_muon(id)) return false;
760 unsigned int stationNameIndex = m_muon_station_name_impl.unpack(id);
761 unsigned int techBit = m_muon_tech_bits[stationNameIndex];
762 result = (is_muon(id) && (techBit == AtlasDetDescr::fAtlasMM));
763 return result;
764}

◆ is_muon() [1/2]

bool AtlasDetectorID::is_muon ( const ExpandedIdentifier & id) const
inherited

Definition at line 239 of file AtlasDetectorID.cxx.

239 {
240 return id.fields() > 0 && id[0] == m_MUON_ID;
241}

◆ is_muon() [2/2]

bool AtlasDetectorID::is_muon ( Identifier id) const
inlineinherited

Definition at line 544 of file AtlasDetectorID.h.

545{
546 return (m_det_impl.unpack(id) == m_MUON_ID);
547}

◆ is_pixel() [1/2]

bool AtlasDetectorID::is_pixel ( const ExpandedIdentifier & id) const
inherited

Definition at line 245 of file AtlasDetectorID.cxx.

245 {
246 return is_indet(id) && id.fields() > 1 && id[1] == m_PIXEL_ID;
247}

◆ is_pixel() [2/2]

bool AtlasDetectorID::is_pixel ( Identifier id) const
inlineinherited

Definition at line 603 of file AtlasDetectorID.h.

604{
605 bool result = false;
606 if(is_indet(id)) {
607 result = (m_indet_part_impl.unpack(id) == m_PIXEL_ID);
608 }
609 return result;
610}

◆ is_plr() [1/2]

bool AtlasDetectorID::is_plr ( const ExpandedIdentifier & id) const
inherited

Definition at line 261 of file AtlasDetectorID.cxx.

261 {
262 return is_lumi(id) && id.fields() > 2 && id[2] == m_LUMI_PLR_ID;
263}
bool is_lumi(Identifier id) const

◆ is_plr() [2/2]

bool AtlasDetectorID::is_plr ( Identifier id) const
inherited

◆ is_rpc() [1/2]

bool AtlasDetectorID::is_rpc ( const ExpandedIdentifier & id) const
inherited

Definition at line 288 of file AtlasDetectorID.cxx.

288 {
289 return id.fields() > 4 && id[0] == m_MUON_ID && id[4] == m_RPC_ID;
290}

◆ is_rpc() [2/2]

bool AtlasDetectorID::is_rpc ( Identifier id) const
inlineinherited

Definition at line 718 of file AtlasDetectorID.h.

719{
720 bool result = false;
721 if (!is_muon(id)) return false;
722 unsigned int stationNameIndex = m_muon_station_name_impl.unpack(id);
723 unsigned int techBit = m_muon_tech_bits[stationNameIndex];
724 // MDT and RPC can only be destinguished by the additional bit in the ID
725 // since the station names are ambiguous
726 if (is_muon(id) && ((techBit == AtlasDetDescr::fAtlasMDT)
727 || (techBit == AtlasDetDescr::fAtlasRPC))) {
728 result = (m_muon_rpc_impl.unpack(id) == m_RPC_ID);
729 }
730 return result;
731}

◆ is_sct() [1/2]

bool AtlasDetectorID::is_sct ( const ExpandedIdentifier & id) const
inherited

Definition at line 249 of file AtlasDetectorID.cxx.

249 {
250 return is_indet(id) && id.fields() > 1 && id[1] == m_SCT_ID;
251}

◆ is_sct() [2/2]

bool AtlasDetectorID::is_sct ( Identifier id) const
inlineinherited

Definition at line 613 of file AtlasDetectorID.h.

614{
615 bool result = false;
616 // Must check is_pixel to allow for special bits
617 // (don't need this check for 64-bit identifier, but leave it in for now)
618 if(is_indet(id) && !is_pixel(id)) {
619 result = (m_indet_part_impl.unpack(id) == m_SCT_ID);
620 }
621 return result;
622}

◆ is_stgc() [1/2]

bool AtlasDetectorID::is_stgc ( const ExpandedIdentifier & id) const
inherited

Definition at line 296 of file AtlasDetectorID.cxx.

296 {
297 return id.fields() > 4 && id[0] == m_MUON_ID && id[4] == m_STGC_ID;
298}

◆ is_stgc() [2/2]

bool AtlasDetectorID::is_stgc ( Identifier id) const
inlineinherited

Definition at line 767 of file AtlasDetectorID.h.

768{
769 bool result = false;
770 if (!is_muon(id)) return false;
771 unsigned int stationNameIndex = m_muon_station_name_impl.unpack(id);
772 unsigned int techBit = m_muon_tech_bits[stationNameIndex];
773 result = (is_muon(id) && (techBit == AtlasDetDescr::fAtlasSTGC));
774 return result;
775}

◆ is_tgc() [1/2]

bool AtlasDetectorID::is_tgc ( const ExpandedIdentifier & id) const
inherited

Definition at line 292 of file AtlasDetectorID.cxx.

292 {
293 return id.fields() > 4 && id[0] == m_MUON_ID && id[4] == m_TGC_ID;
294}

◆ is_tgc() [2/2]

bool AtlasDetectorID::is_tgc ( Identifier id) const
inlineinherited

Definition at line 745 of file AtlasDetectorID.h.

746{
747 bool result = false;
748 if (!is_muon(id)) return false;
749 unsigned int stationNameIndex = m_muon_station_name_impl.unpack(id);
750 unsigned int techBit = m_muon_tech_bits[stationNameIndex];
751 result = (is_muon(id) && (techBit == AtlasDetDescr::fAtlasTGC));
752 return result;
753}

◆ is_tile() [1/2]

bool AtlasDetectorID::is_tile ( const ExpandedIdentifier & id) const
inherited

Definition at line 236 of file AtlasDetectorID.cxx.

236 {
237 return id.fields() > 0 && id[0] == m_TILE_ID;
238}

◆ is_tile() [2/2]

bool AtlasDetectorID::is_tile ( Identifier id) const
inlineinherited

Definition at line 538 of file AtlasDetectorID.h.

539{
540 return (m_det_impl.unpack(id) == m_TILE_ID);
541}

◆ is_tile_dm()

bool AtlasDetectorID::is_tile_dm ( Identifier id) const
inlineinherited

Definition at line 591 of file AtlasDetectorID.h.

592{
593 bool result = false;
594 if (is_calo(id)) {
595 int temp = m_calo_side_impl.unpack(id);
596 result = (m_tile_dm_field.match(temp));
597 }
598 return result;
599}

◆ is_trt() [1/2]

bool AtlasDetectorID::is_trt ( const ExpandedIdentifier & id) const
inherited

Definition at line 252 of file AtlasDetectorID.cxx.

252 {
253 return is_indet(id) && id.fields() > 1;
254}

◆ is_trt() [2/2]

bool AtlasDetectorID::is_trt ( Identifier id) const
inlineinherited

Definition at line 625 of file AtlasDetectorID.h.

626{
627 bool result = false;
628 // Must check is_pixel to allow for special bits
629 // (don't need this check for 64-bit identifier, but leave it in for now)
630 if(is_indet(id) && !is_pixel(id)) {
631 result = (m_indet_part_impl.unpack(id) == m_TRT_ID);
632 }
633 return result;
634}

◆ is_zdc()

bool AtlasDetectorID::is_zdc ( Identifier id) const
inlineinherited

Definition at line 814 of file AtlasDetectorID.h.

815{
816 bool result = false;
817 if(is_forward(id)) {
818 result = (std::abs(m_lar_part_impl.unpack(id)) == m_ZDC_ID);
819 }
820 return result;
821}

◆ lar()

Identifier AtlasDetectorID::lar ( void ) const
inherited

Definition at line 66 of file AtlasDetectorID.cxx.

66 {
67 return m_det_impl.new_pack(lar_field_value());
68}
int lar_field_value() const

◆ lar_dm()

Identifier AtlasDetectorID::lar_dm ( void ) const
inherited

Definition at line 118 of file AtlasDetectorID.cxx.

118 {
119 return makeId(m_det_impl, m_calo_side_impl, calo_field_value(), -4);
120}

◆ lar_em()

Identifier AtlasDetectorID::lar_em ( void ) const
inherited

Definition at line 102 of file AtlasDetectorID.cxx.

102 {
104}

◆ lar_em_exp()

ExpandedIdentifier AtlasDetectorID::lar_em_exp ( void ) const
protectedinherited

LAr.

Definition at line 1032 of file AtlasDetectorID.cxx.

1033{
1034 ExpandedIdentifier result(lar_exp());
1035 return (result << m_LAR_EM_ID);
1036}
ExpandedIdentifier lar_exp(void) const

◆ lar_em_field_value()

int AtlasDetectorID::lar_em_field_value ( ) const
inlineprotectedinherited

Definition at line 487 of file AtlasDetectorID.h.

487{return (m_LAR_EM_ID);}

◆ lar_exp()

ExpandedIdentifier AtlasDetectorID::lar_exp ( void ) const
protectedinherited

Definition at line 962 of file AtlasDetectorID.cxx.

963{
964 ExpandedIdentifier result;
965 return (result << m_LAR_ID);
966}

◆ lar_fcal()

Identifier AtlasDetectorID::lar_fcal ( void ) const
inherited

Definition at line 110 of file AtlasDetectorID.cxx.

110 {
112}

◆ lar_fcal_exp()

ExpandedIdentifier AtlasDetectorID::lar_fcal_exp ( void ) const
protectedinherited

Definition at line 1046 of file AtlasDetectorID.cxx.

1047{
1048 ExpandedIdentifier result(lar_exp());
1049 return (result << m_LAR_FCAL_ID);
1050}

◆ lar_fcal_field_value()

int AtlasDetectorID::lar_fcal_field_value ( ) const
inlineprotectedinherited

Definition at line 493 of file AtlasDetectorID.h.

493{return (m_LAR_FCAL_ID);}

◆ lar_field_value()

int AtlasDetectorID::lar_field_value ( ) const
inlineprotectedinherited

Definition at line 457 of file AtlasDetectorID.h.

457{return (m_LAR_ID);}

◆ lar_hec()

Identifier AtlasDetectorID::lar_hec ( void ) const
inherited

Definition at line 106 of file AtlasDetectorID.cxx.

106 {
108}

◆ lar_hec_exp()

ExpandedIdentifier AtlasDetectorID::lar_hec_exp ( void ) const
protectedinherited

Definition at line 1039 of file AtlasDetectorID.cxx.

1040{
1041 ExpandedIdentifier result(lar_exp());
1042 return (result << m_LAR_HEC_ID);
1043}

◆ lar_hec_field_value()

int AtlasDetectorID::lar_hec_field_value ( ) const
inlineprotectedinherited

Definition at line 490 of file AtlasDetectorID.h.

490{return (m_LAR_HEC_ID);}

◆ lar_lvl1()

Identifier AtlasDetectorID::lar_lvl1 ( void ) const
inherited

Definition at line 114 of file AtlasDetectorID.cxx.

114 {
115 return makeId(m_det_impl, m_calo_side_impl, calo_field_value(), -1);
116}

◆ lucid_exp()

ExpandedIdentifier AtlasDetectorID::lucid_exp ( void ) const
protectedinherited

Definition at line 1067 of file AtlasDetectorID.cxx.

1068{
1069 ExpandedIdentifier result(fwd_exp());
1070 return (result << m_LUCID_ID);
1071}

◆ lucid_field_value()

int AtlasDetectorID::lucid_field_value ( ) const
inlineprotectedinherited

Definition at line 520 of file AtlasDetectorID.h.

520{return (m_LUCID_ID);}

◆ lumi()

Identifier AtlasDetectorID::lumi ( void ) const
inherited

Definition at line 98 of file AtlasDetectorID.cxx.

98 {
100}

◆ lumi_exp()

ExpandedIdentifier AtlasDetectorID::lumi_exp ( void ) const
protectedinherited

Definition at line 1025 of file AtlasDetectorID.cxx.

1026{
1027 ExpandedIdentifier result(indet_exp());
1028 return (result << m_LUMI_ID);
1029}

◆ lumi_field_value()

int AtlasDetectorID::lumi_field_value ( ) const
inlineprotectedinherited

Definition at line 481 of file AtlasDetectorID.h.

481{return (m_LUMI_ID);}

◆ mdt()

Identifier AtlasDetectorID::mdt ( void ) const
inherited

Definition at line 44 of file AtlasDetectorID.cxx.

44 {
45 return Identifier{};
46}

◆ mdt_field_value()

int AtlasDetectorID::mdt_field_value ( ) const
inlineprotectedinherited

Definition at line 496 of file AtlasDetectorID.h.

496{return (m_MDT_ID);}

◆ mm()

Identifier AtlasDetectorID::mm ( void ) const
inherited

Definition at line 59 of file AtlasDetectorID.cxx.

59 {
60 return Identifier{};
61}

◆ mm_field_value()

int AtlasDetectorID::mm_field_value ( ) const
inlineprotectedinherited

Definition at line 511 of file AtlasDetectorID.h.

511{return (m_MM_ID);}

◆ msg() [1/2]

MsgStream & AthMessaging::msg ( ) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 167 of file AthMessaging.h.

168{
169 MsgStream* ms = m_msg_tls.get();
170 if (!ms) {
171 if (!m_initialized.test_and_set()) initMessaging();
172 ms = new MsgStream(m_imsg,m_nm);
173 m_msg_tls.reset( ms );
174 }
175
176 ms->setLevel (m_lvl);
177 return *ms;
178}
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels).
void initMessaging() const
Initialize our message level and MessageSvc.

◆ msg() [2/2]

MsgStream & AthMessaging::msg ( const MSG::Level lvl) const
inlineinherited

The standard message stream.

Returns a reference to the default message stream May not be invoked before sysInitialize() has been invoked.

Definition at line 182 of file AthMessaging.h.

183{ return msg() << lvl; }
MsgStream & msg() const
The standard message stream.

◆ msgLvl()

bool AthMessaging::msgLvl ( const MSG::Level lvl) const
inlineinherited

Test the output level.

Parameters
lvlThe message level to test against
Returns
boolean Indicating if messages at given level will be printed
Return values
trueMessages at level "lvl" will be printed

Definition at line 151 of file AthMessaging.h.

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

◆ muon()

Identifier AtlasDetectorID::muon ( void ) const
inherited

Definition at line 74 of file AtlasDetectorID.cxx.

74 {
75 return m_det_impl.new_pack(muon_field_value());
76}
int muon_field_value() const

◆ muon_exp()

ExpandedIdentifier AtlasDetectorID::muon_exp ( void ) const
protectedinherited

Definition at line 976 of file AtlasDetectorID.cxx.

977{
978 ExpandedIdentifier result;
979 return (result << m_MUON_ID);
980}

◆ muon_field_value()

int AtlasDetectorID::muon_field_value ( ) const
inlineprotectedinherited

Definition at line 463 of file AtlasDetectorID.h.

463{return (m_MUON_ID);}

◆ name()

const std::string & CaloIDHelper::name ( ) const

Return the name for this helper.

◆ phi0()

float CaloIDHelper::phi0 ( const IdentifierHash regHash) const

Return the minimum phi of region, or NOT_VALID.

Parameters
regHashREGION hash code.

Definition at line 217 of file CaloIDHelper.cxx.

218{
219 if (regHash >= m_vecOfDictRegions.size()) return NOT_VALID;
220 return (m_vecOfDictRegions.at(regHash)->phi0());
221}

◆ phiGranularity()

float CaloIDHelper::phiGranularity ( const IdentifierHash regHash) const

Return the phi granularity of a region, or NOT_VALID.

Parameters
regHashREGION hash code.

Definition at line 195 of file CaloIDHelper.cxx.

196{
197 if (regHash >= m_vecOfDictRegions.size()) return NOT_VALID;
198 return 2. * M_PI / m_vecOfDictRegions.at(regHash)->dphi();
199}
#define M_PI

◆ pixel()

Identifier AtlasDetectorID::pixel ( void ) const
inherited

Definition at line 82 of file AtlasDetectorID.cxx.

82 {
84}

◆ pixel_exp()

ExpandedIdentifier AtlasDetectorID::pixel_exp ( void ) const
protectedinherited

Inner Detector:

Definition at line 997 of file AtlasDetectorID.cxx.

998{
999 ExpandedIdentifier result(indet_exp());
1000 return (result << m_PIXEL_ID);
1001}

◆ pixel_field_value()

int AtlasDetectorID::pixel_field_value ( ) const
inlineprotectedinherited

Definition at line 469 of file AtlasDetectorID.h.

469{return (m_PIXEL_ID);}

◆ plr_field_value()

int AtlasDetectorID::plr_field_value ( ) const
inlineprotectedinherited

Definition at line 484 of file AtlasDetectorID.h.

484{return (m_LUMI_PLR_ID);}

◆ print()

void AtlasDetectorID::print ( Identifier id,
const IdContext * context = 0 ) const
inherited

Expanded print out of any identifier.

Definition at line 354 of file AtlasDetectorID.cxx.

354 {
355 ATH_MSG_INFO(print_to_string(id, context));
356}
#define ATH_MSG_INFO(x)
std::string print_to_string(Identifier id, const IdContext *context=0) const
or provide the printout in string form

◆ print_to_string()

std::string AtlasDetectorID::print_to_string ( Identifier id,
const IdContext * context = 0 ) const
inherited

or provide the printout in string form

Definition at line 358 of file AtlasDetectorID.cxx.

359 {
360 // Print out for any Atlas identifier
361 std::string result;
363
364 // Do a generic printout of identifier from dictionary
365 unsigned int max_index = (context) ? context->end_index() : 999;
366
367 // Find the dictionary to use:
368 const IdDictDictionary *dict = dictionary(id);
369 ExpandedIdentifier expId;
370 ExpandedIdentifier prefix; // default is null prefix
371 Identifier compact = id;
372 if (!dict) {
373 ATH_MSG_WARNING(__func__<<":"<<__LINE__<<" No dictionary could be associated to "<<id);
374 return result;
375 }
376 if (dict->unpack(m_group, compact, prefix, max_index," ", result)) {
377 return result;
378 }
379 }
380 return result;
381}
const IdDictDictionary * dictionary(const Identifier &id) const
int unpack(const std::string &group, const Identifier &id, const ExpandedIdentifier &prefix, size_t index2, ExpandedIdentifier &unpackedId) const
Unpack the value_type id to an expanded Identifier for a given group, considering the provided prefix...

◆ region_context()

IdContext CaloIDHelper::region_context ( ) const

Return the context for regions.

◆ region_hash()

IdentifierHash CaloIDHelper::region_hash ( Identifier regionId) const

Convert a connected region Identifier to a hash code.

Some subdetector helpers may override this with a faster version.

◆ region_hash_max()

size_type CaloIDHelper::region_hash_max ( ) const

One more than the largest region hash code.

◆ region_id()

Identifier CaloIDHelper::region_id ( IdentifierHash hashId) const

Return the region Identifier for a given hash code (no checking).

◆ regions()

const HashGroup & CaloIDHelper::regions ( ) const

Return the HashGroup for regions.

◆ register_dict_tag()

int AtlasDetectorID::register_dict_tag ( const IdDictMgr & dict_mgr,
const std::string & dict_name )
protectedinherited

Register the file and tag names for a particular IdDict dictionary.

Definition at line 150 of file AtlasDetectorID.cxx.

151 {
152 // Register version of dictionary dict_name
153
154 // Access dictionary by name
155 const IdDictDictionary *dict = dict_mgr.find_dictionary(dict_name);
156 if (!dict) {
157 ATH_MSG_ERROR(__func__<<":"<<__LINE__<<" No dictionary found");
158 return 1;
159
160 }
161 // Add in dict name, file name and version
162 m_dict_names.push_back(dict_name);
163 m_file_names.push_back(dict->file_name());
164 m_dict_tags.push_back(dict->dict_tag());
165 return 0;
166}
const std::string & dict_tag() const
Access to the dictionary tag.
const std::string & file_name() const
Access to file name.

◆ reinitialize()

bool AtlasDetectorID::reinitialize ( const IdDictMgr & dict_mgr)
protectedinherited

Test whether an idhelper should be reinitialized based on the change of tags.

Definition at line 170 of file AtlasDetectorID.cxx.

170 {
171 // If no tag has been registered, then reinitialize
172 if (m_dict_tags.empty() || m_dict_names.empty() ){
173 return true;
174 }
175
176 // Loop over dict names and check version tags
177 if (m_dict_names.size() != m_dict_tags.size()) [[unlikely]]{
178 ATH_MSG_ERROR("reinitialize: dict names and tags vectors not the same length ");
179 ATH_MSG_ERROR("names: " << m_dict_names.size() << " tags: " << m_dict_tags.size());
180 }
181 for (unsigned int i = 0; i < m_dict_names.size(); ++i) {
182 // Access dictionary by name
183 const IdDictDictionary *dict = dict_mgr.find_dictionary(m_dict_names[i]);
184 if (!dict)[[unlikely]] {
185 ATH_MSG_ERROR("reinitialize: could not find dict - " << m_dict_names[i]);
186 return false;
187 }
188 if (m_dict_tags[i] != dict->dict_tag()) {
189 // Remove all memory of versions
190 m_dict_names.clear();
191 m_dict_tags.clear();
192 m_file_names.clear();
193 return true;
194 }
195 }
196
197 // Tags match - don't reinitialize
198 return false;
199}
#define unlikely(x)

◆ rpc()

Identifier AtlasDetectorID::rpc ( void ) const
inherited

Definition at line 50 of file AtlasDetectorID.cxx.

50 {
51 return Identifier{};
52}

◆ rpc_field_value()

int AtlasDetectorID::rpc_field_value ( ) const
inlineprotectedinherited

Definition at line 502 of file AtlasDetectorID.h.

502{return (m_RPC_ID);}

◆ sct()

Identifier AtlasDetectorID::sct ( void ) const
inherited

Definition at line 86 of file AtlasDetectorID.cxx.

86 {
88}

◆ sct_exp()

ExpandedIdentifier AtlasDetectorID::sct_exp ( void ) const
protectedinherited

Definition at line 1004 of file AtlasDetectorID.cxx.

1005{
1006 ExpandedIdentifier result(indet_exp());
1007 return (result << m_SCT_ID);
1008}

◆ sct_field_value()

int AtlasDetectorID::sct_field_value ( ) const
inlineprotectedinherited

Definition at line 472 of file AtlasDetectorID.h.

472{return (m_SCT_ID);}

◆ set_do_checks()

void AtlasDetectorID::set_do_checks ( bool do_checks)
overridevirtualinherited

Implements IdHelper.

Definition at line 394 of file AtlasDetectorID.cxx.

394 {
396}
virtual bool do_checks(void) const override
Checks are performed by default in debug compilation and NOT in optimized compilation.

◆ set_do_neighbours()

void AtlasDetectorID::set_do_neighbours ( bool do_neighbours)
overridevirtualinherited

Implements IdHelper.

Definition at line 402 of file AtlasDetectorID.cxx.

402 {
404}
virtual bool do_neighbours(void) const override
Neighbour initialization is performed by default One can switch or query this mode for any idHelper w...

◆ setDictVersion()

void AtlasDetectorID::setDictVersion ( const IdDictMgr & dict_mgr,
const std::string & name )
overrideprotectedvirtualinherited

Implements IdHelper.

Definition at line 406 of file AtlasDetectorID.cxx.

406 {
407 const IdDictDictionary *dict = dict_mgr.find_dictionary(name);
408 m_dict_version = dict->version();
409}
const std::string & version() const
Dictionary version.

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

◆ show()

void AtlasDetectorID::show ( Identifier id,
const IdContext * context = 0,
char sep = '.' ) const
inherited

Short print out of any identifier (optionally provide separation character - default is '.

'):

Definition at line 305 of file AtlasDetectorID.cxx.

305 {
306 ATH_MSG_INFO(show_to_string(id, context, sep));
307}
std::string show_to_string(Identifier id, const IdContext *context=0, char sep='.') const
or provide the printout in string form

◆ show_to_string()

std::string AtlasDetectorID::show_to_string ( Identifier id,
const IdContext * context = 0,
char sep = '.' ) const
inherited

or provide the printout in string form

Definition at line 311 of file AtlasDetectorID.cxx.

311 {
312 // Do a generic printout of identifier
313
314 std::string result("Unable to decode id");
315 unsigned int max_index = (context) ? context->end_index() : 999;
316
317 if (!id.is_valid()) {
318 return "[INVALID]";
319 }
320
322 return result;
323
324 // Find the dictionary to use:
325 const IdDictDictionary * dict = dictionary(id);
326 ExpandedIdentifier expId{};
327 ExpandedIdentifier prefix{}; // default is null prefix
328 Identifier compact = id;
329
330 if (!dict) {
331 ATH_MSG_WARNING(__func__<<" No detector type associated to id "<<id);
332 return result;
333 }
334 if (dict->unpack(m_group, compact, prefix, max_index, expId)) {
335 return result;
336 }
337
338 bool first = true;
339 result = "";
340 if ('.' == sep)
341 result = '[';
342 for (unsigned int i = 0; i < expId.fields(); ++i) {
343 if (first)
344 first = false;
345 else
346 result += sep;
347 result += std::to_string(expId[i]);
348 }
349 if ('.' == sep)
350 result += ']';
351 return result;
352}
size_type fields() const
bool first
Definition DeMoScan.py:534

◆ stgc()

Identifier AtlasDetectorID::stgc ( void ) const
inherited

Definition at line 56 of file AtlasDetectorID.cxx.

56 {
57 return Identifier{};
58}

◆ stgc_field_value()

int AtlasDetectorID::stgc_field_value ( ) const
inlineprotectedinherited

Definition at line 508 of file AtlasDetectorID.h.

508{return (m_STGC_ID);}

◆ subdet_context()

IdContext AtlasDetectorID::subdet_context ( void ) const
inherited

IdContext (indicates id length) for sub-detector.

Definition at line 133 of file AtlasDetectorID.cxx.

133 {
134 ExpandedIdentifier id{};
135 return IdContext{id, 0, m_SUBDET_INDEX};
136}

◆ tgc()

Identifier AtlasDetectorID::tgc ( void ) const
inherited

Definition at line 53 of file AtlasDetectorID.cxx.

53 {
54 return Identifier{};
55}

◆ tgc_field_value()

int AtlasDetectorID::tgc_field_value ( ) const
inlineprotectedinherited

Definition at line 505 of file AtlasDetectorID.h.

505{return (m_TGC_ID);}

◆ tile()

Identifier AtlasDetectorID::tile ( void ) const
inherited

Definition at line 70 of file AtlasDetectorID.cxx.

70 {
71 return m_det_impl.new_pack(tile_field_value());
72}
int tile_field_value() const

◆ tile_dm()

Identifier AtlasDetectorID::tile_dm ( void ) const
inherited

Definition at line 122 of file AtlasDetectorID.cxx.

122 {
123 return makeId(m_det_impl, m_calo_side_impl, calo_field_value(), -5);
124}

◆ tile_exp()

ExpandedIdentifier AtlasDetectorID::tile_exp ( void ) const
protectedinherited

Definition at line 969 of file AtlasDetectorID.cxx.

970{
971 ExpandedIdentifier result;
972 return (result << m_TILE_ID);
973}

◆ tile_field_value()

int AtlasDetectorID::tile_field_value ( ) const
inlineprotectedinherited

Definition at line 460 of file AtlasDetectorID.h.

460{return (m_TILE_ID);}

◆ to_range()

std::string AtlasDetectorID::to_range ( const ExpandedIdentifier & id) const
protectedinherited

Definition at line 411 of file AtlasDetectorID.cxx.

411 {
412
413 // Build a string from the contents of an identifier
414 int fields = id.fields();
415 std::string result;
416 for (int i = 0; i < fields; ++i) {
417 if (i > 0) {
418 result += '/'; // add '/' only if NOT first one
419 }
420 result += std::to_string(id[i]);
421 }
422 return result;
423}

◆ trt()

Identifier AtlasDetectorID::trt ( void ) const
inherited

Definition at line 90 of file AtlasDetectorID.cxx.

90 {
92}

◆ trt_exp()

ExpandedIdentifier AtlasDetectorID::trt_exp ( void ) const
protectedinherited

Definition at line 1011 of file AtlasDetectorID.cxx.

1012{
1013 ExpandedIdentifier result(indet_exp());
1014 return (result << m_TRT_ID);
1015}

◆ trt_field_value()

int AtlasDetectorID::trt_field_value ( ) const
inlineprotectedinherited

Definition at line 475 of file AtlasDetectorID.h.

475{return (m_TRT_ID);}

◆ zdc_exp()

ExpandedIdentifier AtlasDetectorID::zdc_exp ( void ) const
protectedinherited

Definition at line 1074 of file AtlasDetectorID.cxx.

1075{
1076 ExpandedIdentifier result(fwd_exp());
1077 return (result << m_ZDC_ID);
1078}

◆ zdc_field_value()

int AtlasDetectorID::zdc_field_value ( ) const
inlineprotectedinherited

Definition at line 522 of file AtlasDetectorID.h.

522{return (m_ZDC_ID);}

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.

◆ invalidId

int AtlasDetectorID::invalidId {-1}
staticconstexprinherited

Definition at line 81 of file AtlasDetectorID.h.

81{-1};

◆ invalidIndex

int AtlasDetectorID::invalidIndex {999}
staticconstexprinherited

Definition at line 80 of file AtlasDetectorID.h.

80{999};

◆ m_ALFA_ID

int AtlasDetectorID::m_ALFA_ID {1}
privateinherited

Definition at line 411 of file AtlasDetectorID.h.

411{1};

◆ m_atlas_dict

const IdDictDictionary* AtlasDetectorID::m_atlas_dict {}
privateinherited

Definition at line 368 of file AtlasDetectorID.h.

368{};

◆ m_BCM_ID

int AtlasDetectorID::m_BCM_ID {3}
privateinherited

Definition at line 412 of file AtlasDetectorID.h.

412{3};

◆ m_calo_dict

const IdDictDictionary* AtlasDetectorID::m_calo_dict {}
privateinherited

Definition at line 373 of file AtlasDetectorID.h.

373{};

◆ m_CALO_ID

int AtlasDetectorID::m_CALO_ID {10}
privateinherited

Definition at line 393 of file AtlasDetectorID.h.

393{10};

◆ m_calo_side_impl

IdDictFieldImplementation AtlasDetectorID::m_calo_side_impl
privateinherited

Definition at line 419 of file AtlasDetectorID.h.

◆ m_CSC_ID

int AtlasDetectorID::m_CSC_ID {1}
privateinherited

Definition at line 405 of file AtlasDetectorID.h.

405{1};

◆ m_det_impl

IdDictFieldImplementation AtlasDetectorID::m_det_impl
privateinherited

Definition at line 417 of file AtlasDetectorID.h.

◆ m_DET_INDEX

size_type AtlasDetectorID::m_DET_INDEX {999}
privateinherited

Definition at line 386 of file AtlasDetectorID.h.

386{999};

◆ m_dict

* The dictionary for this helper const IdDictDictionary* CaloIDHelper::m_dict
private

Definition at line 332 of file CaloIDHelper.h.

◆ m_dict_names

std::vector<std::string> AtlasDetectorID::m_dict_names
protectedinherited

List of dictionary names used by this helper.

Definition at line 355 of file AtlasDetectorID.h.

◆ m_dict_tags

std::vector<std::string> AtlasDetectorID::m_dict_tags
protectedinherited

List of dictionary versions used by this helper.

Definition at line 361 of file AtlasDetectorID.h.

◆ m_dict_version

std::string AtlasDetectorID::m_dict_version
privateinherited

Definition at line 366 of file AtlasDetectorID.h.

◆ m_do_checks

bool AtlasDetectorID::m_do_checks {}
protectedinherited

Flag for subclasses to know whether or not to perform checks.

In general, this is set to false in optimized mode.

Definition at line 440 of file AtlasDetectorID.h.

440{};

◆ m_do_neighbours

bool AtlasDetectorID::m_do_neighbours {true}
protectedinherited

Flag for subclasses to know whether or not to perform neighbour initialization.

Definition at line 443 of file AtlasDetectorID.h.

443{true};

◆ m_file_names

std::vector<std::string> AtlasDetectorID::m_file_names
protectedinherited

List of dictionary file names used by this helper.

Definition at line 358 of file AtlasDetectorID.h.

◆ m_fwd_dict

const IdDictDictionary* AtlasDetectorID::m_fwd_dict {}
privateinherited

Definition at line 374 of file AtlasDetectorID.h.

374{};

◆ m_FWD_ID

int AtlasDetectorID::m_FWD_ID {13}
privateinherited

Definition at line 410 of file AtlasDetectorID.h.

410{13};

◆ m_fwd_part_impl

IdDictFieldImplementation AtlasDetectorID::m_fwd_part_impl
privateinherited

Definition at line 425 of file AtlasDetectorID.h.

◆ m_group

std::string AtlasDetectorID::m_group
protectedinherited

Group name.

Definition at line 352 of file AtlasDetectorID.h.

◆ m_helper

std::unique_ptr<AtlasDetectorIDHelper> AtlasDetectorID::m_helper {}
privateinherited

Definition at line 430 of file AtlasDetectorID.h.

430{};

◆ m_HGTD_ID

int AtlasDetectorID::m_HGTD_ID {4}
privateinherited

Definition at line 397 of file AtlasDetectorID.h.

397{4};

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_indet_dict

const IdDictDictionary* AtlasDetectorID::m_indet_dict {}
privateinherited

Definition at line 369 of file AtlasDetectorID.h.

369{};

◆ m_INDET_ID

int AtlasDetectorID::m_INDET_ID {2}
privateinherited

Definition at line 389 of file AtlasDetectorID.h.

389{2};

◆ m_indet_part_impl

IdDictFieldImplementation AtlasDetectorID::m_indet_part_impl
privateinherited

Definition at line 418 of file AtlasDetectorID.h.

◆ m_is_initialized_from_dict

bool AtlasDetectorID::m_is_initialized_from_dict {}
privateinherited

Definition at line 435 of file AtlasDetectorID.h.

435{};

◆ m_isHighLuminosityLHC

bool AtlasDetectorID::m_isHighLuminosityLHC {}
privateinherited

Definition at line 436 of file AtlasDetectorID.h.

436{};

◆ m_lar_dict

const IdDictDictionary* AtlasDetectorID::m_lar_dict {}
privateinherited

Definition at line 370 of file AtlasDetectorID.h.

370{};

◆ m_lar_dm_field

Range::field AtlasDetectorID::m_lar_dm_field
privateinherited

Definition at line 428 of file AtlasDetectorID.h.

◆ m_LAR_EM_ID

int AtlasDetectorID::m_LAR_EM_ID {1}
privateinherited

Definition at line 400 of file AtlasDetectorID.h.

400{1};

◆ m_LAR_FCAL_ID

int AtlasDetectorID::m_LAR_FCAL_ID {3}
privateinherited

Definition at line 402 of file AtlasDetectorID.h.

402{3};

◆ m_lar_fcal_module_impl

IdDictFieldImplementation AtlasDetectorID::m_lar_fcal_module_impl
privateinherited

Definition at line 421 of file AtlasDetectorID.h.

◆ m_LAR_FCAL_MODULE_INDEX

int AtlasDetectorID::m_LAR_FCAL_MODULE_INDEX {999}
privateinherited

Definition at line 403 of file AtlasDetectorID.h.

403{999};

◆ m_LAR_HEC_ID

int AtlasDetectorID::m_LAR_HEC_ID {2}
privateinherited

Definition at line 401 of file AtlasDetectorID.h.

401{2};

◆ m_LAR_ID

int AtlasDetectorID::m_LAR_ID {4}
privateinherited

Definition at line 390 of file AtlasDetectorID.h.

390{4};

◆ m_lar_part_impl

IdDictFieldImplementation AtlasDetectorID::m_lar_part_impl
privateinherited

Definition at line 420 of file AtlasDetectorID.h.

◆ m_LUCID_ID

int AtlasDetectorID::m_LUCID_ID {5}
privateinherited

Definition at line 413 of file AtlasDetectorID.h.

413{5};

◆ m_LUMI_ID

int AtlasDetectorID::m_LUMI_ID {3}
privateinherited

Definition at line 398 of file AtlasDetectorID.h.

398{3};

◆ m_LUMI_PLR_ID

int AtlasDetectorID::m_LUMI_PLR_ID {1}
privateinherited

Definition at line 399 of file AtlasDetectorID.h.

399{1};

◆ m_lvl

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

Current logging level.

Definition at line 138 of file AthMessaging.h.

138{ MSG::NIL };

◆ m_lvl1_field

Range::field AtlasDetectorID::m_lvl1_field
privateinherited

Definition at line 426 of file AtlasDetectorID.h.

◆ m_lvl1_onl_field

Range::field AtlasDetectorID::m_lvl1_onl_field
privateinherited

Definition at line 427 of file AtlasDetectorID.h.

◆ m_MDT_ID

int AtlasDetectorID::m_MDT_ID {0}
privateinherited

Definition at line 404 of file AtlasDetectorID.h.

404{0};

◆ m_MM_ID

int AtlasDetectorID::m_MM_ID {5}
privateinherited

Definition at line 409 of file AtlasDetectorID.h.

409{5};

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

const IdDictDictionary* AtlasDetectorID::m_muon_dict {}
privateinherited

Definition at line 372 of file AtlasDetectorID.h.

372{};

◆ m_MUON_ID

int AtlasDetectorID::m_MUON_ID {7}
privateinherited

Definition at line 392 of file AtlasDetectorID.h.

392{7};

◆ m_muon_mdt_impl

IdDictFieldImplementation AtlasDetectorID::m_muon_mdt_impl
privateinherited

Definition at line 423 of file AtlasDetectorID.h.

◆ m_muon_rpc_impl

IdDictFieldImplementation AtlasDetectorID::m_muon_rpc_impl
privateinherited

Definition at line 424 of file AtlasDetectorID.h.

◆ m_muon_station_name_impl

IdDictFieldImplementation AtlasDetectorID::m_muon_station_name_impl
privateinherited

Definition at line 422 of file AtlasDetectorID.h.

◆ m_MUON_SUBDET_INDEX

size_type AtlasDetectorID::m_MUON_SUBDET_INDEX {999}
privateinherited

Definition at line 388 of file AtlasDetectorID.h.

388{999};

◆ m_muon_tech_bits

std::vector<unsigned int> AtlasDetectorID::m_muon_tech_bits
privateinherited

Definition at line 433 of file AtlasDetectorID.h.

◆ m_name

* Name of this helper std::string CaloIDHelper::m_name
private

Definition at line 323 of file CaloIDHelper.h.

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_PIXEL_ID

int AtlasDetectorID::m_PIXEL_ID {1}
privateinherited

Definition at line 394 of file AtlasDetectorID.h.

394{1};

◆ m_regions

* Group of region Identifiers HashGroup CaloIDHelper::m_regions
private

Definition at line 329 of file CaloIDHelper.h.

◆ m_RPC_ID

int AtlasDetectorID::m_RPC_ID {2}
privateinherited

Definition at line 406 of file AtlasDetectorID.h.

406{2};

◆ m_SCT_ID

int AtlasDetectorID::m_SCT_ID {2}
privateinherited

Definition at line 395 of file AtlasDetectorID.h.

395{2};

◆ m_STGC_ID

int AtlasDetectorID::m_STGC_ID {4}
privateinherited

Definition at line 408 of file AtlasDetectorID.h.

408{4};

◆ m_SUBDET_INDEX

size_type AtlasDetectorID::m_SUBDET_INDEX {999}
privateinherited

Definition at line 387 of file AtlasDetectorID.h.

387{999};

◆ m_TGC_ID

int AtlasDetectorID::m_TGC_ID {3}
privateinherited

Definition at line 407 of file AtlasDetectorID.h.

407{3};

◆ m_tile_dict

const IdDictDictionary* AtlasDetectorID::m_tile_dict {}
privateinherited

Definition at line 371 of file AtlasDetectorID.h.

371{};

◆ m_tile_dm_field

Range::field AtlasDetectorID::m_tile_dm_field
privateinherited

Definition at line 429 of file AtlasDetectorID.h.

◆ m_TILE_ID

int AtlasDetectorID::m_TILE_ID {5}
privateinherited

Definition at line 391 of file AtlasDetectorID.h.

391{5};

◆ m_TRT_ID

int AtlasDetectorID::m_TRT_ID {3}
privateinherited

Definition at line 396 of file AtlasDetectorID.h.

396{3};

◆ m_vecOfDictRegions

* List of c IdDictRegion objects std::vector<const IdDictRegion*> CaloIDHelper::m_vecOfDictRegions
private

Definition at line 335 of file CaloIDHelper.h.

◆ m_ZDC_ID

int AtlasDetectorID::m_ZDC_ID {7}
privateinherited

Definition at line 414 of file AtlasDetectorID.h.

414{7};

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