ATLAS Offline Software
Public Member Functions | Static Public Member Functions | Protected Types | Protected Member Functions | Protected Attributes | Private Member Functions | Private Attributes | List of all members
T_AthenaPoolCnvBase< T > Class Template Reference

This templated class provides the converter to translate an object to/from its persistent POOL representation. More...

#include <T_AthenaPoolCnvBase.h>

Inheritance diagram for T_AthenaPoolCnvBase< T >:
Collaboration diagram for T_AthenaPoolCnvBase< T >:

Public Member Functions

 T_AthenaPoolCnvBase (ISvcLocator *svcloc, const char *name=nullptr)
 Constructor. More...
 
virtual StatusCode finalize () override
 
virtual long repSvcType () const override
 
virtual StatusCode createObj (IOpaqueAddress *pAddr, DataObject *&pObj) override
 Create a transient object from a POOL persistent representation. More...
 
virtual StatusCode createRep (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Create a POOL persistent representation for a transient object. More...
 
virtual StatusCode fillRepRefs (IOpaqueAddress *pAddr, DataObject *pObj) override
 Create a POOL persistent representation for a transient object. More...
 
virtual StatusCode cleanUp (const std::string &output) override
 Implement cleanUp for AthenaPoolConverter to do nothing. More...
 
void addTrack (TIDA::Track *t)
 
const std::vector< TIDA::Track * > & tracks () const
 
void clear ()
 
void selectTracks (const TrigInDetTrackCollection *trigtracks)
 
void selectTracks (const Rec::TrackParticleContainer *trigtracks)
 
void selectTracks (const Analysis::MuonContainer *muontracks)
 
bool msgLvl (const MSG::Level lvl) const
 Test the output level. More...
 
MsgStream & msg () const
 The standard message stream. More...
 
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream. More...
 
void setLevel (MSG::Level lvl)
 Change the current logging level. More...
 

Static Public Member Functions

static const CLIDclassID ()
 
static long storageType ()
 

Protected Types

typedef std::map< std::string, RootTypeClassMap
 
typedef ClassMap::const_iterator ClassMapIt
 
typedef std::mutex CallMutex
 

Protected Member Functions

virtual StatusCode initialize ()
 Gaudi Service Interface method implementations: More...
 
virtual StatusCode DataObjectToPers (DataObject *pObj, IOpaqueAddress *&pAddr)
 Convert an object into Persistent. More...
 
virtual StatusCode DataObjectToPool (IOpaqueAddress *pAddr, DataObject *pObj)
 Write an object into POOL. More...
 
virtual StatusCode PoolToDataObject (DataObject *&pObj, const Token *token, const std::string &key)
 Read an object from POOL. More...
 
virtual Placement setPlacement (const std::string &key, const std::string &output)
 Set POOL placement. More...
 
virtual Placement setPlacementWithType (const std::string &tname, const std::string &key, const std::string &output)
 Set POOL placement hint for a given type. More...
 
virtual const DataObject * getDataObject () const
 
bool compareClassGuid (const Guid &guid) const
 
double phiCorr (double phi)
 
void ipCorr (double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
 

Protected Attributes

ServiceHandle< IAthenaPoolCnvSvcm_athenaPoolCnvSvc
 
RootType m_classDesc
 
std::string m_className
 
ClassMap m_classDescs
 
std::string m_containerPrefix
 
std::string m_containerNameHint
 
std::string m_branchNameHint
 
const DataObject * m_dataObject
 
const Tokenm_i_poolToken
 
CallMutex m_conv_mut
 
double m_beamX
 
double m_beamY
 
double m_beamZ
 
std::vector< TIDA::Track * > m_tracks
 

Private Member Functions

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

Private Attributes

std::string m_nm
 Message source name. More...
 
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels) More...
 
std::atomic< IMessageSvc * > m_imsg { nullptr }
 MessageSvc pointer. More...
 
std::atomic< MSG::Level > m_lvl { MSG::NIL }
 Current logging level. More...
 
std::atomic_flag m_initialized ATLAS_THREAD_SAFE = ATOMIC_FLAG_INIT
 Messaging initialized (initMessaging) More...
 

Detailed Description

template<class T>
class T_AthenaPoolCnvBase< T >

This templated class provides the converter to translate an object to/from its persistent POOL representation.

Definition at line 24 of file T_AthenaPoolCnvBase.h.

Member Typedef Documentation

◆ CallMutex

typedef std::mutex AthenaPoolConverter::CallMutex
protectedinherited

Definition at line 126 of file AthenaPoolConverter.h.

◆ ClassMap

typedef std::map<std::string, RootType> AthenaPoolConverter::ClassMap
protectedinherited

Definition at line 114 of file AthenaPoolConverter.h.

◆ ClassMapIt

typedef ClassMap::const_iterator AthenaPoolConverter::ClassMapIt
protectedinherited

Definition at line 115 of file AthenaPoolConverter.h.

Constructor & Destructor Documentation

◆ T_AthenaPoolCnvBase()

template<class T >
T_AthenaPoolCnvBase< T >::T_AthenaPoolCnvBase ( ISvcLocator *  svcloc,
const char *  name = nullptr 
)

Constructor.

Member Function Documentation

◆ addTrack()

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

Definition at line 45 of file Converter.h.

45  {
46  m_tracks.push_back(t);
47  }

◆ classID()

template<class T >
static const CLID& T_AthenaPoolCnvBase< T >::classID ( )
static
Returns
class ID.

◆ cleanUp()

StatusCode AthenaPoolConverter::cleanUp ( const std::string &  output)
overridevirtualinherited

Implement cleanUp for AthenaPoolConverter to do nothing.

Implements IAthenaPoolCleanUp.

Reimplemented in T_AthenaPoolCustomCnvWithKey< TRANS, PERS >, T_AthenaPoolCustomCnvWithKey< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustomCnvWithKey< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustomCnvWithKey< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustomCnvWithKey< XAOD, XAOD >, T_AthenaPoolCustomCnvWithKey< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustomCnvWithKey< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustomCnvWithKey< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustomCnvWithKey< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustomCnvWithKey< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustomCnvWithKey< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustomCnvWithKey< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustomCnvWithKey< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustomCnvWithKey< RingerRings, RingerRings_PERS >, T_AthenaPoolCustomCnvWithKey< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustomCnvWithKey< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TRANS, TPCNV_CUR::Pers_t >, T_AthenaPoolCustomCnvWithKey< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustomCnvWithKey< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< MissingET, MissingET_PERS >, T_AthenaPoolCustomCnvWithKey< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustomCnvWithKey< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustomCnvWithKey< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustomCnvWithKey< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AUXSTORE, AUXSTORE >, T_AthenaPoolCustomCnvWithKey< T, P >, T_AthenaPoolCustomCnvWithKey< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTau, TrigTau_PERS >, T_AthenaPoolCustomCnvWithKey< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustomCnvWithKey< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustomCnvWithKey< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustomCnvWithKey< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustomCnvWithKey< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustomCnvWithKey< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustomCnvWithKey< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustomCnvWithKey< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, and T_AthenaPoolCustomCnvWithKey< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >.

Definition at line 277 of file AthenaPoolConverter.cxx.

277  {
278  ATH_MSG_DEBUG("AthenaPoolConverter cleanUp called for base class.");
279  return(StatusCode::SUCCESS);
280 }

◆ clear()

void Converter::clear ( )
inlineinherited

Definition at line 53 of file Converter.h.

53 {m_tracks.clear();}

◆ compareClassGuid()

bool AthenaPoolConverter::compareClassGuid ( const Guid guid) const
protectedinherited

Definition at line 273 of file AthenaPoolConverter.cxx.

273  {
274  return(m_i_poolToken ? (guid == m_i_poolToken->classID()) : false);
275 }

◆ createObj()

StatusCode AthenaPoolConverter::createObj ( IOpaqueAddress *  pAddr,
DataObject *&  pObj 
)
overridevirtualinherited

Create a transient object from a POOL persistent representation.

Parameters
pAddr[IN] IOpaqueAddress of POOL persistent representation.
pObj[OUT] pointer to the transient object.

Reimplemented in T_AthenaPoolCoolMultChanCnv< COLL_T, ELEM_T, ELEM_P >, T_AthenaPoolCoolMultChanCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 64 of file AthenaPoolConverter.cxx.

64  {
65  TokenAddress* tokAddr = dynamic_cast<TokenAddress*>(pAddr);
66 
67  bool ownTokAddr = false;
68  if (tokAddr == nullptr || tokAddr->getToken() == nullptr) {
69  ownTokAddr = true;
70  Token* token = new Token;
71  token->fromString(*(pAddr->par()));
72  GenericAddress* genAddr = dynamic_cast<GenericAddress*>(pAddr);
73  if (not genAddr){
74  ATH_MSG_ERROR("Dynamic cast failed in AthenaPoolConverter::createObj");
75  //clean up
76  delete token;
77  return StatusCode::FAILURE;
78  }
79  tokAddr = new TokenAddress(*genAddr, token);
80  }
81  if( tokAddr->ipar()[0] > 0 and tokAddr->getToken()->auxString().empty() ) {
82  char text[32];
83  ::sprintf(text, "[CTXT=%08X]", static_cast<int>(*(pAddr->ipar())));
84  tokAddr->getToken()->setAuxString(text);
85  }
86  ATH_MSG_VERBOSE("createObj: " << tokAddr->getToken()->toString() << ", CTX=" << tokAddr->ipar()[0]
87  << ", auxStr=" << tokAddr->getToken()->auxString() );
88  std::lock_guard<CallMutex> lock(m_conv_mut);
89  m_i_poolToken = tokAddr->getToken();
90  try {
91  std::string key = pAddr->par()[1];
92  if (!PoolToDataObject(pObj, tokAddr->getToken(), key).isSuccess()) {
93  ATH_MSG_ERROR("createObj PoolToDataObject() failed, Token = " << (tokAddr->getToken() ? tokAddr->getToken()->toString() : "NULL"));
94  pObj = nullptr;
95  }
96  } catch (std::exception& e) {
97  ATH_MSG_ERROR("createObj - caught exception: " << e.what());
98  pObj = nullptr;
99  }
100  if (pObj == nullptr) {
101  ATH_MSG_ERROR("createObj failed to get DataObject, Token = " << (tokAddr->getToken() ? tokAddr->getToken()->toString() : "NULL"));
102  }
103  if (ownTokAddr) {
104  delete tokAddr; tokAddr = nullptr;
105  }
106  m_i_poolToken = nullptr;
107  if (pObj == nullptr) {
108  return(StatusCode::FAILURE);
109  }
110  return(StatusCode::SUCCESS);
111 }

◆ createRep()

StatusCode AthenaPoolConverter::createRep ( DataObject *  pObj,
IOpaqueAddress *&  pAddr 
)
overridevirtualinherited

Create a POOL persistent representation for a transient object.

Parameters
pObj[IN] pointer to the transient object.
pAddr[OUT] IOpaqueAddress of POOL persistent representation.

Reimplemented in T_AthenaPoolCoolMultChanCnv< COLL_T, ELEM_T, ELEM_P >, T_AthenaPoolCoolMultChanCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 113 of file AthenaPoolConverter.cxx.

113  {
114  const SG::DataProxy* proxy = dynamic_cast<SG::DataProxy*>(pObj->registry());
115  if (proxy == nullptr) {
116  ATH_MSG_ERROR("AthenaPoolConverter CreateRep failed to cast DataProxy, key = " << pObj->name());
117  return(StatusCode::FAILURE);
118  }
119  try {
120  std::lock_guard<CallMutex> lock(m_conv_mut);
121  if (!DataObjectToPers(pObj, pAddr).isSuccess()) {
122  ATH_MSG_ERROR("CreateRep failed, key = " << pObj->name());
123  return(StatusCode::FAILURE);
124  }
125  } catch (std::exception& e) {
126  ATH_MSG_ERROR("createRep - caught exception: " << e.what());
127  return(StatusCode::FAILURE);
128  }
129  const CLID clid = proxy->clID();
130  if (pAddr == nullptr) {
131  // Create a IOpaqueAddress for this object.
132  pAddr = new TokenAddress(this->storageType(), clid, "", "", 0, 0);
133  } else {
134  GenericAddress* gAddr = dynamic_cast<GenericAddress*>(pAddr);
135  if (gAddr != nullptr) {
136  gAddr->setSvcType(this->storageType());
137  }
138  }
139  return(StatusCode::SUCCESS);
140 }

◆ DataObjectToPers()

template<class T >
virtual StatusCode T_AthenaPoolCnvBase< T >::DataObjectToPers ( DataObject *  pObj,
IOpaqueAddress *&  pAddr 
)
protectedvirtual

Convert an object into Persistent.

Parameters
pObj[IN] pointer to the transient object.

Implements AthenaPoolConverter.

Reimplemented in T_AthenaPoolCustomCnvWithKey< TRANS, PERS >, T_AthenaPoolCustomCnvWithKey< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustomCnvWithKey< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustomCnvWithKey< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustomCnvWithKey< XAOD, XAOD >, T_AthenaPoolCustomCnvWithKey< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustomCnvWithKey< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustomCnvWithKey< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustomCnvWithKey< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustomCnvWithKey< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustomCnvWithKey< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustomCnvWithKey< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustomCnvWithKey< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustomCnvWithKey< RingerRings, RingerRings_PERS >, T_AthenaPoolCustomCnvWithKey< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustomCnvWithKey< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TRANS, TPCNV_CUR::Pers_t >, T_AthenaPoolCustomCnvWithKey< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustomCnvWithKey< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< MissingET, MissingET_PERS >, T_AthenaPoolCustomCnvWithKey< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustomCnvWithKey< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustomCnvWithKey< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustomCnvWithKey< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AUXSTORE, AUXSTORE >, T_AthenaPoolCustomCnvWithKey< T, P >, T_AthenaPoolCustomCnvWithKey< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTau, TrigTau_PERS >, T_AthenaPoolCustomCnvWithKey< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustomCnvWithKey< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustomCnvWithKey< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustomCnvWithKey< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustomCnvWithKey< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustomCnvWithKey< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustomCnvWithKey< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustomCnvWithKey< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >, T_AthenaPoolCustCnv< TRANS, PERS >, T_AthenaPoolCustCnv< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustCnv< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustCnv< TransientClass, LArConditionsSubset< LArSingleFloatP > >, T_AthenaPoolCustCnv< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustCnv< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustCnv< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustCnv< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustCnv< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustCnv< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustCnv< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustCnv< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustCnv< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustCnv< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustCnv< XAOD, XAOD >, T_AthenaPoolCustCnv< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustCnv< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustCnv< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustCnv< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustCnv< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustCnv< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustCnv< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustCnv< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustCnv< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustCnv< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustCnv< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustCnv< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustCnv< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustCnv< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustCnv< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustCnv< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustCnv< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustCnv< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustCnv< T, T::PERSIST >, T_AthenaPoolCustCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP > >, T_AthenaPoolCustCnv< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustCnv< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolCustCnv< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustCnv< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustCnv< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustCnv< RingerRings, RingerRings_PERS >, T_AthenaPoolCustCnv< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustCnv< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustCnv< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustCnv< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustCnv< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustCnv< TRANS, TPCNV_CUR::Pers_t >, T_AthenaPoolCustCnv< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustCnv< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustCnv< COLL_T, ELEM_T >, T_AthenaPoolCustCnv< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustCnv< MissingET, MissingET_PERS >, T_AthenaPoolCustCnv< T, DataVector< T::IDENTIFIABLE > >, T_AthenaPoolCustCnv< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustCnv< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustCnv< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustCnv< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustCnv< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustCnv< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustCnv< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustCnv< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustCnv< AUXSTORE, AUXSTORE >, T_AthenaPoolCustCnv< T, P >, T_AthenaPoolCustCnv< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustCnv< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustCnv< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustCnv< TrigTau, TrigTau_PERS >, T_AthenaPoolCustCnv< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustCnv< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustCnv< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustCnv< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustCnv< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustCnv< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustCnv< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustCnv< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustCnv< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustCnv< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustCnv< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustCnv< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustCnv< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustCnv< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustCnv< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustCnv< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, and T_AthenaPoolCustCnv< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >.

◆ DataObjectToPool()

template<class T >
virtual StatusCode T_AthenaPoolCnvBase< T >::DataObjectToPool ( IOpaqueAddress *  pAddr,
DataObject *  pObj 
)
protectedvirtual

Write an object into POOL.

Parameters
pObj[IN] pointer to the transient object.

Implements AthenaPoolConverter.

Reimplemented in T_AthenaPoolLegacyCnv< TRANS, PERS, LEGACY >, T_AthenaPoolCustomCnvWithKey< TRANS, PERS >, T_AthenaPoolCustomCnvWithKey< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustomCnvWithKey< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustomCnvWithKey< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustomCnvWithKey< XAOD, XAOD >, T_AthenaPoolCustomCnvWithKey< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustomCnvWithKey< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustomCnvWithKey< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustomCnvWithKey< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustomCnvWithKey< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustomCnvWithKey< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustomCnvWithKey< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustomCnvWithKey< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustomCnvWithKey< RingerRings, RingerRings_PERS >, T_AthenaPoolCustomCnvWithKey< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustomCnvWithKey< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TRANS, TPCNV_CUR::Pers_t >, T_AthenaPoolCustomCnvWithKey< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustomCnvWithKey< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< MissingET, MissingET_PERS >, T_AthenaPoolCustomCnvWithKey< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustomCnvWithKey< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustomCnvWithKey< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustomCnvWithKey< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AUXSTORE, AUXSTORE >, T_AthenaPoolCustomCnvWithKey< T, P >, T_AthenaPoolCustomCnvWithKey< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTau, TrigTau_PERS >, T_AthenaPoolCustomCnvWithKey< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustomCnvWithKey< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustomCnvWithKey< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustomCnvWithKey< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustomCnvWithKey< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustomCnvWithKey< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustomCnvWithKey< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustomCnvWithKey< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >, DataHeaderCnv, T_LArCondAthenaPoolCnv< T >, T_AthenaPoolCustCnv< TRANS, PERS >, T_AthenaPoolCustCnv< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustCnv< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustCnv< TransientClass, LArConditionsSubset< LArSingleFloatP > >, T_AthenaPoolCustCnv< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustCnv< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustCnv< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustCnv< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustCnv< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustCnv< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustCnv< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustCnv< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustCnv< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustCnv< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustCnv< XAOD, XAOD >, T_AthenaPoolCustCnv< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustCnv< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustCnv< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustCnv< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustCnv< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustCnv< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustCnv< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustCnv< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustCnv< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustCnv< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustCnv< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustCnv< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustCnv< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustCnv< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustCnv< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustCnv< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustCnv< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustCnv< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustCnv< T, T::PERSIST >, T_AthenaPoolCustCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP > >, T_AthenaPoolCustCnv< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustCnv< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolCustCnv< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustCnv< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustCnv< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustCnv< RingerRings, RingerRings_PERS >, T_AthenaPoolCustCnv< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustCnv< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustCnv< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustCnv< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustCnv< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustCnv< TRANS, TPCNV_CUR::Pers_t >, T_AthenaPoolCustCnv< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustCnv< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustCnv< COLL_T, ELEM_T >, T_AthenaPoolCustCnv< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustCnv< MissingET, MissingET_PERS >, T_AthenaPoolCustCnv< T, DataVector< T::IDENTIFIABLE > >, T_AthenaPoolCustCnv< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustCnv< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustCnv< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustCnv< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustCnv< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustCnv< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustCnv< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustCnv< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustCnv< AUXSTORE, AUXSTORE >, T_AthenaPoolCustCnv< T, P >, T_AthenaPoolCustCnv< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustCnv< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustCnv< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustCnv< TrigTau, TrigTau_PERS >, T_AthenaPoolCustCnv< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustCnv< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustCnv< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustCnv< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustCnv< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustCnv< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustCnv< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustCnv< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustCnv< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustCnv< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustCnv< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustCnv< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustCnv< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustCnv< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustCnv< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustCnv< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, and T_AthenaPoolCustCnv< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >.

◆ fillRepRefs()

StatusCode AthenaPoolConverter::fillRepRefs ( IOpaqueAddress *  pAddr,
DataObject *  pObj 
)
overridevirtualinherited

Create a POOL persistent representation for a transient object.

Parameters
pAddr[IN] IOpaqueAddress of POOL persistent representation.
pObj[IN] pointer to the transient object.

Reimplemented in T_AthenaPoolCoolMultChanCnv< COLL_T, ELEM_T, ELEM_P >, T_AthenaPoolCoolMultChanCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >, and T_AthenaPoolCoolMultChanCnv< TransientClass, LArConditionsSubset< LArSingleFloatP >, LArSingleFloatSubset_p1 >.

Definition at line 142 of file AthenaPoolConverter.cxx.

142  {
143  std::lock_guard<CallMutex> lock(m_conv_mut);
144  try {
145  if (!DataObjectToPool(pAddr, pObj).isSuccess()) {
146  ATH_MSG_ERROR("FillRepRefs failed, key = " << pObj->name());
147  return(StatusCode::FAILURE);
148  }
149  } catch (std::exception& e) {
150  ATH_MSG_ERROR("fillRepRefs - caught exception: " << e.what());
151  return(StatusCode::FAILURE);
152  }
153  return(StatusCode::SUCCESS);
154 }

◆ finalize()

StatusCode AthenaPoolConverter::finalize ( )
overridevirtualinherited

Definition at line 52 of file AthenaPoolConverter.cxx.

52  {
53  // Release AthenaPoolCnvSvc
54  if (!m_athenaPoolCnvSvc.release().isSuccess()) {
55  ATH_MSG_WARNING("Cannot release AthenaPoolCnvSvc.");
56  }
57  return(::Converter::finalize());
58 }

◆ getDataObject()

const DataObject * AthenaPoolConverter::getDataObject ( ) const
protectedvirtualinherited
Returns
data object from the converter.

Definition at line 269 of file AthenaPoolConverter.cxx.

269  {
270  return(m_dataObject);
271 }

◆ initialize()

template<class T >
virtual StatusCode T_AthenaPoolCnvBase< T >::initialize ( )
protectedvirtual

Gaudi Service Interface method implementations:

Reimplemented from AthenaPoolConverter.

Reimplemented in JetCollectionCnv, T_AthenaPoolViewVectorCnv< DV >, xAODTrackParticleAuxContainerCnv, TrackCollectionCnv, V0ContainerCnv, TrackParticleContainerCnv, VxContainerCnv, DataHeaderCnv, LayerMaterialMapCnv, TileCellContainerCnv, xAODSpacePointAuxContainerCnv, xAODTrackStateAuxContainerCnv, LArLATOMEHeaderContainerCnv, MuonContainerCnv, TRT_RDO_ContainerCnv, PixelClusterContainerCnv, SCT_ClusterContainerCnv, SCT_RDO_ContainerCnv, PixelRDO_ContainerCnv, TrigInDetTrackTruthMapCnv, T_AthenaPoolCustCnv< TRANS, PERS >, TRT_DriftCircleContainerCnv, T_AthenaPoolCustCnv< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustCnv< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustCnv< TransientClass, LArConditionsSubset< LArSingleFloatP > >, T_AthenaPoolCustCnv< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustCnv< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustCnv< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustCnv< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustCnv< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustCnv< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustCnv< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustCnv< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustCnv< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustCnv< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustCnv< XAOD, XAOD >, T_AthenaPoolCustCnv< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustCnv< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustCnv< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustCnv< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustCnv< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustCnv< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustCnv< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustCnv< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustCnv< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustCnv< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustCnv< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustCnv< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustCnv< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustCnv< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustCnv< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustCnv< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustCnv< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustCnv< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustCnv< T, T::PERSIST >, T_AthenaPoolCustCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP > >, T_AthenaPoolCustCnv< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustCnv< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolCustCnv< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustCnv< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustCnv< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustCnv< RingerRings, RingerRings_PERS >, T_AthenaPoolCustCnv< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustCnv< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustCnv< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustCnv< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustCnv< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustCnv< TRANS, TPCNV_CUR::Pers_t >, T_AthenaPoolCustCnv< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustCnv< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustCnv< COLL_T, ELEM_T >, T_AthenaPoolCustCnv< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustCnv< MissingET, MissingET_PERS >, T_AthenaPoolCustCnv< T, DataVector< T::IDENTIFIABLE > >, T_AthenaPoolCustCnv< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustCnv< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustCnv< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustCnv< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustCnv< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustCnv< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustCnv< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustCnv< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustCnv< AUXSTORE, AUXSTORE >, T_AthenaPoolCustCnv< T, P >, T_AthenaPoolCustCnv< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustCnv< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustCnv< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustCnv< TrigTau, TrigTau_PERS >, T_AthenaPoolCustCnv< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustCnv< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustCnv< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustCnv< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustCnv< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustCnv< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustCnv< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustCnv< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustCnv< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustCnv< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustCnv< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustCnv< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustCnv< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustCnv< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustCnv< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustCnv< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, T_AthenaPoolCustCnv< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >, TgcCoinDataContainerCnv, TgcPrepDataContainerCnv, CscPrepDataContainerCnv, MdtPrepDataContainerCnv, RpcPrepDataContainerCnv, MMPrepDataContainerCnv, CscStripPrepDataContainerCnv, sTgcPrepDataContainerCnv, TrigSpacePointCountsCnv, MuonRdoContainerTPCnv< T, P, CONV >, CscRawDataContainerCnv, RpcCoinDataContainerCnv, MuonRdoContainerCnv< T >, CaloTTOnAttrIdMapCnv, CaloTTOnOffIdMapCnv, CaloTTPpmRxIdMapCnv, MM_RawDataContainerCnv, STGC_RawDataContainerCnv, AlignableTransformContainerCnv, LArTTCellMapCnv, and LArDigitContainerCnv.

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 39 of file AthMessaging.cxx.

40 {
42  m_lvl = m_imsg ?
43  static_cast<MSG::Level>( m_imsg.load()->outputLevel(m_nm) ) :
44  MSG::INFO;
45 }

◆ ipCorr()

void Converter::ipCorr ( double  d0,
double  z0,
double &  d0c,
double &  z0c,
double  phi0,
double  eta,
double  pt 
)
inlineprotectedinherited

Definition at line 257 of file Converter.h.

257  {
258 
259  double sn = sin(phi0);
260  double cs = cos(phi0);
261  double sd0 = (d0 != 0 ? d0/fabs(d0) : 1);
262  double spt = (pt != 0 ? pt/fabs(pt) : 1);
263 
264  if (fabs(pt) >= 1*CLHEP::TeV) {
265 
266  d0c = d0 + m_beamX*sn - m_beamY*cs;
267 
268  } else {
269 
270  double rc = fabs(pt)*15.0/(9.0*1.042);
271 
272  double xc = (fabs(d0)-spt*sd0*rc)*cos(phi0+M_PI/2*sd0) - m_beamX;
273  double yc = (fabs(d0)-spt*sd0*rc)*sin(phi0+M_PI/2*sd0) - m_beamY;
274 
275  double newphi;
276  double xd01,yd01,xd02,yd02;
277 
278  if (xc == 0) {
279  xd01 = 0; yd01 = rc+yc;
280  xd02 = 0; yd02 = -rc+yc;
281  } else {
282  xd01 = xc+yc/xc*yc+sqrt(pow((xc+yc/xc*yc),2)-xc*xc-yc*yc+rc*rc); yd01 = yc/xc*xd01;
283  xd02 = xc+yc/xc*yc-sqrt(pow((xc+yc/xc*yc),2)-xc*xc-yc*yc+rc*rc); yd02 = yc/xc*xd02;
284  }
285 
286  double r1 = sqrt(xd01*xd01+yd01*yd01);
287  double r2 = sqrt(xd02*xd02+yd02*yd02);
288 
289  double phiV;
290 
291  if (r1 < r2)
292  phiV = atan2(yd01,xd01);
293  else
294  phiV = atan2(yd02,xd02);
295 
296  double phi1 = phiCorr(phiV+M_PI/2);
297  double phi2 = phiCorr(phiV-M_PI/2);
298 
299  if (fabs(phiCorr(phi1-phi0))<=fabs(phiCorr(phi2-phi0)))
300  newphi = phi1;
301  else
302  newphi = phi2;
303 
304  d0c = fabs(sqrt(xc*xc+yc*yc)-rc)*sin(phiV-newphi);
305 
306  double theta=2*atan2(exp(-eta),1);
307  double theta_save=theta;
308  theta = theta - (1+spt)/2*M_PI;
309  if (theta>0) theta = theta_save;
310 
311  double deltaz0= -spt*rc/tan(theta)*phiCorr(phiCorr(newphi)-phiCorr(phi0));
312  z0c = z0 + deltaz0;
313 
314  }
315  }

◆ msg() [1/2]

MsgStream & AthMessaging::msg ( ) const
inlineinherited

The standard message stream.

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

Definition at line 164 of file AthMessaging.h.

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

◆ msg() [2/2]

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

The standard message stream.

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

Definition at line 179 of file AthMessaging.h.

180 { return msg() << lvl; }

◆ msgLvl()

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

Test the output level.

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

Definition at line 151 of file AthMessaging.h.

152 {
153  if (!m_initialized.test_and_set()) initMessaging();
154  if (m_lvl <= lvl) {
155  msg() << lvl;
156  return true;
157  } else {
158  return false;
159  }
160 }

◆ phiCorr()

double Converter::phiCorr ( double  phi)
inlineprotectedinherited

Definition at line 248 of file Converter.h.

248  {
249 
250  if (phi < -TMath::Pi()) phi += 2*TMath::Pi();
251  if (phi > TMath::Pi()) phi -= 2*TMath::Pi();
252 
253  return phi;
254  }

◆ PoolToDataObject()

template<class T >
virtual StatusCode T_AthenaPoolCnvBase< T >::PoolToDataObject ( DataObject *&  pObj,
const Token token,
const std::string &  key 
)
protectedvirtual

Read an object from POOL.

Parameters
pObj[OUT] pointer to the transient object.
token[IN] POOL token of the persistent representation.
key[IN] SG key of the object being read.

Implements AthenaPoolConverter.

Reimplemented in T_AthenaPoolCustomCnvWithKey< TRANS, PERS >, T_AthenaPoolCustomCnvWithKey< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustomCnvWithKey< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustomCnvWithKey< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustomCnvWithKey< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustomCnvWithKey< XAOD, XAOD >, T_AthenaPoolCustomCnvWithKey< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustomCnvWithKey< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustomCnvWithKey< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustomCnvWithKey< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustomCnvWithKey< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustomCnvWithKey< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustomCnvWithKey< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustomCnvWithKey< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustomCnvWithKey< RingerRings, RingerRings_PERS >, T_AthenaPoolCustomCnvWithKey< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustomCnvWithKey< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TRANS, TPCNV_CUR::Pers_t >, T_AthenaPoolCustomCnvWithKey< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustomCnvWithKey< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< MissingET, MissingET_PERS >, T_AthenaPoolCustomCnvWithKey< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustomCnvWithKey< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustomCnvWithKey< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustomCnvWithKey< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< AUXSTORE, AUXSTORE >, T_AthenaPoolCustomCnvWithKey< T, P >, T_AthenaPoolCustomCnvWithKey< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTau, TrigTau_PERS >, T_AthenaPoolCustomCnvWithKey< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustomCnvWithKey< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustomCnvWithKey< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustomCnvWithKey< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustomCnvWithKey< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustomCnvWithKey< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustomCnvWithKey< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustomCnvWithKey< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustomCnvWithKey< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustomCnvWithKey< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustomCnvWithKey< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustomCnvWithKey< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustomCnvWithKey< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustomCnvWithKey< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustomCnvWithKey< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, T_AthenaPoolCustomCnvWithKey< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >, T_AthenaPoolCustCnv< TRANS, PERS >, T_AthenaPoolCustCnv< Analysis::MuonContainer, MuonContainer_PERS >, T_AthenaPoolCustCnv< ElectronContainer, ElectronContainer_PERS >, T_AthenaPoolCustCnv< TransientClass, LArConditionsSubset< LArSingleFloatP > >, T_AthenaPoolCustCnv< ALFA_LocRecCorrODEvCollection, ALFA_LocRecCorrODEvCollection_PERS >, T_AthenaPoolCustCnv< TileCosmicMuonContainer, TileCosmicMuonContainer_PERS >, T_AthenaPoolCustCnv< TrigEMCluster, TrigEMCluster_PERS >, T_AthenaPoolCustCnv< TrigMonConfigCollection, TrigMonConfigCollection_PERS >, T_AthenaPoolCustCnv< TileL2Container, TileL2Container_PERS >, T_AthenaPoolCustCnv< TileBeamElemContainer, TileBeamElemContainer_PERS >, T_AthenaPoolCustCnv< TileMuContainer, TileMuContainer_PERS >, T_AthenaPoolCustCnv< PhotonContainer, PhotonContainer_PERS >, T_AthenaPoolCustCnv< Analysis ::TauDetailsContainer, TauDetailsContainer_PERS >, T_AthenaPoolCustCnv< TrigMonEvent, TrigMonEvent_PERS >, T_AthenaPoolCustCnv< XAOD, XAOD >, T_AthenaPoolCustCnv< AthExDecay, AthExDecay_PERS >, T_AthenaPoolCustCnv< ALFA_ODDigitCollection, ALFA_ODDigitCollection_PERS >, T_AthenaPoolCustCnv< TruthParticleContainer, TruthParticleContainer_PERS >, T_AthenaPoolCustCnv< TrigMonConfig, TrigMonConfig_PERS >, T_AthenaPoolCustCnv< TileHitContainer, TileHitContainer_PERS >, T_AthenaPoolCustCnv< IParticleLinkContainer, IParticleLinkContainer_PERS >, T_AthenaPoolCustCnv< AthExElephantino, AthExElephantino_PERS >, T_AthenaPoolCustCnv< AthExFatObject, AthExFatObject_PERS >, T_AthenaPoolCustCnv< AFP_SiDigiCollection, AFP_SiDigiCollection_PERS >, T_AthenaPoolCustCnv< AFP_SIDLocRecoEvCollection, AFP_SIDLocRecoEvCollection_PERS >, T_AthenaPoolCustCnv< AFP_TDSimHitCollection, AFP_TDSimHitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecEvCollection, ALFA_LocRecEvCollection_PERS >, T_AthenaPoolCustCnv< McEventCollection, McEventCollection_PERS >, T_AthenaPoolCustCnv< ALFA_ODHitCollection, ALFA_ODHitCollection_PERS >, T_AthenaPoolCustCnv< TileHitVector, TileHitVector_PERS >, T_AthenaPoolCustCnv< RecoTimingObj, RecoTimingObj_PERS >, T_AthenaPoolCustCnv< Rec::MuonSpShowerContainer, MuonSpShowerContainer_PERS >, T_AthenaPoolCustCnv< BCM_RDO_Container, BCM_RDO_Container_p0 >, T_AthenaPoolCustCnv< ALFA_DigitCollection, ALFA_DigitCollection_PERS >, T_AthenaPoolCustCnv< T, T::PERSIST >, T_AthenaPoolCustCnv< LArHVScaleCorrComplete, LArConditionsSubset< LArSingleFloatP > >, T_AthenaPoolCustCnv< TileTTL1Container, TileTTL1Container_PERS >, T_AthenaPoolCustCnv< ZdcRawChannelCollection, ZdcRawChannelCollection_PERS >, T_AthenaPoolCustCnv< ALFA_HitCollection, ALFA_HitCollection_PERS >, T_AthenaPoolCustCnv< SimulationHitCollection, SimulationHitCollection_PERS >, T_AthenaPoolCustCnv< MissingEtTruth, MissingEtTruth_PERS >, T_AthenaPoolCustCnv< RingerRings, RingerRings_PERS >, T_AthenaPoolCustCnv< MuonCaloEnergyContainer, MuonCaloEnergyContainer_PERS >, T_AthenaPoolCustCnv< Analysis ::TauJetContainer, TauJetContainer_PERS >, T_AthenaPoolCustCnv< TileRawChannelContainer, TileRawChannelContainer_PERS >, T_AthenaPoolCustCnv< AFP_SIDSimHitCollection, AFP_SIDSimHitCollection_PERS >, T_AthenaPoolCustCnv< TileMuonReceiverContainer, TileMuonReceiverContainer_PERS >, T_AthenaPoolCustCnv< TRANS, TPCNV_CUR::Pers_t >, T_AthenaPoolCustCnv< AFP_TDLocRecoEvCollection, AFP_TDLocRecoEvCollection_PERS >, T_AthenaPoolCustCnv< TrackRecordCollection, TrackRecordCollection_PERS >, T_AthenaPoolCustCnv< COLL_T, ELEM_T >, T_AthenaPoolCustCnv< LArHitFloatContainer, LArHitContainer_PERS >, T_AthenaPoolCustCnv< MissingET, MissingET_PERS >, T_AthenaPoolCustCnv< T, DataVector< T::IDENTIFIABLE > >, T_AthenaPoolCustCnv< egDetailContainer, egDetailContainer_PERS >, T_AthenaPoolCustCnv< CaloCalibrationHitContainer, CaloCalibrationHitContainer_PERS >, T_AthenaPoolCustCnv< TrigComposite, TrigComposite_PERS >, T_AthenaPoolCustCnv< TrigTauCluster, TrigTauCluster_PERS >, T_AthenaPoolCustCnv< TrigRoiDescriptor, TrigRoiDescriptor_PERS >, T_AthenaPoolCustCnv< INav4MomAssocs, INav4MomAssocs_PERS >, T_AthenaPoolCustCnv< CaloRingsContainer, CaloRingsContainer_PERS >, T_AthenaPoolCustCnv< TileDigitsContainer, TileDigitsContainer_PERS >, T_AthenaPoolCustCnv< AUXSTORE, AUXSTORE >, T_AthenaPoolCustCnv< T, P >, T_AthenaPoolCustCnv< ALFA_GloRecEvCollection, ALFA_GloRecEvCollection_PERS >, T_AthenaPoolCustCnv< LArHitContainer, LArHitContainer_PERS >, T_AthenaPoolCustCnv< TrigRNNOutput, TrigRNNOutput_PERS >, T_AthenaPoolCustCnv< TrigTau, TrigTau_PERS >, T_AthenaPoolCustCnv< TrigOperationalInfo, TrigOperationalInfo_PERS >, T_AthenaPoolCustCnv< AFP_TDDigiCollection, AFP_TDDigiCollection_PERS >, T_AthenaPoolCustCnv< MissingEtCalo, MissingEtCalo_PERS >, T_AthenaPoolCustCnv< INav4MomLinkContainer, INav4MomLinkContainer_PERS >, T_AthenaPoolCustCnv< TrigTauTracksInfo, TrigTauTracksInfo_PERS >, T_AthenaPoolCustCnv< eflowObjectContainer, eflowObjectContainer_p5 >, T_AthenaPoolCustCnv< SiHitCollection, SiHitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecODEvCollection, ALFA_LocRecODEvCollection_PERS >, T_AthenaPoolCustCnv< TruthEtIsolationsContainer, TruthEtIsolationsContainer_PERS >, T_AthenaPoolCustCnv< LArTTL1Container, LArTTL1Container_PERS >, T_AthenaPoolCustCnv< ViewVector< DV >, ViewVector< DV > >, T_AthenaPoolCustCnv< TRTUncompressedHitCollection, TRT_HitCollection_PERS >, T_AthenaPoolCustCnv< ALFA_CLinkEvent, ALFA_CLinkEvent_PERS >, T_AthenaPoolCustCnv< TrigTauClusterDetails, TrigTauClusterDetails_PERS >, T_AthenaPoolCustCnv< TrigMonEventCollection, TrigMonEventCollection_PERS >, T_AthenaPoolCustCnv< egammaContainer, egammaContainer_PERS >, T_AthenaPoolCustCnv< TrigOperationalInfoCollection, TrigOperationalInfoCollection_PERS >, T_AthenaPoolCustCnv< TrigRoiDescriptorCollection, TrigRoiDescriptorCollection_PERS >, T_AthenaPoolCustCnv< ALFA_LocRecCorrEvCollection, ALFA_LocRecCorrEvCollection_PERS >, and T_AthenaPoolCustCnv< InDet::InDetLowBetaCandidate, InDetLowBetaCandidate_PERS >.

◆ repSvcType()

long AthenaPoolConverter::repSvcType ( ) const
overridevirtualinherited

Definition at line 60 of file AthenaPoolConverter.cxx.

60  {
61  return(POOL_StorageType);
62 }

◆ selectTracks() [1/3]

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

Definition at line 177 of file Converter.h.

177  {
178 
179  static int hpmap[20] = { 0, 1, 2, 7, 8, 9, 3, 4, 5, 6, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19 };
180 
181  Analysis::MuonContainer::const_iterator muonitr = muontracks->begin();
182  Analysis::MuonContainer::const_iterator muonend = muontracks->end();
183 
184  while(muonitr!=muonend) {
185 
186  bool hasInDet = (*muonitr)->hasInDetTrackParticle();
187  const Rec::TrackParticle *trackitr=NULL;
188  if(hasInDet) trackitr=(*muonitr)->inDetTrackParticle();
189  muonitr++;
190  if(!hasInDet) continue;
191 
192  const Trk::MeasuredPerigee* measPer = trackitr->measuredPerigee();
193 
194  CLHEP::HepVector perigeeParams = measPer->parameters();
195  double pT = measPer->pT();
196  double eta = measPer->eta();
197  double phi = perigeeParams[Trk::phi0];
198  double z0 = perigeeParams[Trk::z0];
199  double d0 = perigeeParams[Trk::d0];
200  //double theta = perigeeParams[Trk::theta];
201 
202  double deta = 1;
203  double dphi = 1;
204  double dz0 = 1;
205  double dd0 = 1;
206  double dpT = 1;
207 
208  // Check number of hits
209  // NB: a spacepoint is two offline "hits", so a pixel spacepoint is really
210  // 2 "hits" and an offline SCT "hit" is really a 1D cluster, so two intersetcting
211  // stereo clusters making a spacepoint are two "hits"
212  const Trk::TrackSummary *summary = trackitr->trackSummary();
213  int nBlayerHits = 2*summary->get(Trk::numberOfBLayerHits);
215  int nSctHits = summary->get(Trk::numberOfSCTHits);
216  int nStrawHits = summary->get(Trk::numberOfTRTHits);
217  int nTrHits = summary->get(Trk::numberOfTRTHighThresholdHits);
218 
219  int nSiHits = nPixelHits + nSctHits;
220 
221  const Trk::FitQuality *quality = trackitr->fitQuality();
222  double chi2 = quality->chiSquared();
223  double dof = quality->quality->numberDoF();
224 
225  unsigned bitmap = 0;
226 
227  for ( int ih=0 ; ih<20 ; ih++ ) {
228  if ( summary->isHit(Trk::DetectorType(ih)) ) bitmap |= ( 1<<hpmap[ih] );
229  }
230 
231  // Shift d0 and z0 according to beam position
232  ipCorr(d0, z0, d0, z0, phi, eta, pT);
233 
234  // Create and save Track
235  TIDA::Track* t = new TIDA::Track(eta, phi, z0, d0, pT, chi2, dof,
236  deta, dphi, dz0, dd0, dpT,
237  nBlayerHits, nPixelHits, nSctHits, nSiHits,
238  nStrawHits, nTrHits, bitmap, 0,
239  -1) ;
240 
241  addTrack(t);
242  }
243 
244  }

◆ selectTracks() [2/3]

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

Definition at line 111 of file Converter.h.

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

◆ selectTracks() [3/3]

void Converter::selectTracks ( const TrigInDetTrackCollection trigtracks)
inlineinherited

Definition at line 56 of file Converter.h.

56  {
57 
58  TrigInDetTrackCollection::const_iterator trackitr = trigtracks->begin();
59  TrigInDetTrackCollection::const_iterator trackend = trigtracks->end();
60 
61  while ( trackitr!=trackend ) {
62 
63  double eta = (*trackitr)->param()->eta();
64  double phi = (*trackitr)->param()->phi0();
65  double z0 = (*trackitr)->param()->z0();
66  double pT = (*trackitr)->param()->pT();
67  double d0 = (*trackitr)->param()->a0();
68  //double theta = 2*atan2(exp(-(*trackitr)->param()->eta()),1);
69 
70  double deta = (*trackitr)->param()->eeta();
71  double dphi = (*trackitr)->param()->ephi0();
72  double dz0 = (*trackitr)->param()->ez0();
73  double dpT = (*trackitr)->param()->epT();
74  double dd0 = (*trackitr)->param()->ea0();
75 
76  int algoid = (*trackitr)->algorithmId();
77 
78  int nBlayerHits = ((*trackitr)->HitPattern() & 0x1);
79  int nPixelHits = 2*(*trackitr)->NPixelSpacePoints(); // NB: for comparison with offline
80  int nSctHits = 2*(*trackitr)->NSCT_SpacePoints(); // a spacepoint is 2 "hits"
81  int nStrawHits = (*trackitr)->NStrawHits();
82  int nTrHits = (*trackitr)->NTRHits();
83 
84  int nSiHits = nPixelHits + nSctHits;
85  bool expectBL = false; //not available with TrigInDetTrack
86 
87  unsigned hitPattern = (*trackitr)->HitPattern();
88  unsigned multiPattern = 0;
89 
90  double chi2 = (*trackitr)->chi2();
91  double dof = 0;
92 
93  // Shift d0 and z0 according to beam position
94  ipCorr(d0, z0, d0, z0, phi, eta, pT);
95 
96  // Create and save Track
97  TIDA::Track* t = new TIDA::Track(eta, phi, z0, d0, pT, chi2, dof,
98  deta, dphi, dz0, dd0, dpT,
99  nBlayerHits, nPixelHits, nSctHits, nSiHits,
100  nStrawHits, nTrHits, hitPattern, multiPattern,
101  algoid,
102  expectBL ) ;
103 
104  addTrack(t);
105  trackitr++;
106  }
107  }

◆ setLevel()

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

Change the current logging level.

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

Definition at line 28 of file AthMessaging.cxx.

29 {
30  m_lvl = lvl;
31 }

◆ setPlacement()

template<class T >
virtual Placement T_AthenaPoolCnvBase< T >::setPlacement ( const std::string &  key,
const std::string &  output 
)
protectedvirtual

Set POOL placement.

Implements AthenaPoolConverter.

◆ setPlacementWithType()

Placement AthenaPoolConverter::setPlacementWithType ( const std::string &  tname,
const std::string &  key,
const std::string &  output 
)
protectedvirtualinherited

Set POOL placement hint for a given type.

Parameters
tname[IN] type name.
key[IN] SG key.

Definition at line 176 of file AthenaPoolConverter.cxx.

176  {
177  Placement placement;
178  // Override streaming parameters from StreamTool if requested.
179  std::string::size_type pos1 = output.find('[');
180  std::string outputConnectionSpec = output.substr(0, pos1);
181  int tech = 0;
182  m_athenaPoolCnvSvc->decodeOutputSpec(outputConnectionSpec, tech).ignore();
183  // Set DB and Container names
184  placement.setFileName(outputConnectionSpec);
185 
186  std::string containerPrefix = m_containerPrefix;
187  std::string dhContainerPrefix = pool::ROOTRNTUPLE_StorageType.exactMatch(tech) ? APRDefaults::RNTupleNames::DataHeader : APRDefaults::TTreeNames::DataHeader;
188  std::string containerName;
189 
190  // Get Technology from containerPrefix
191  std::size_t colonPos = containerPrefix.find(':');
192  if (colonPos != std::string::npos) {
193  dhContainerPrefix = containerPrefix.substr(0, colonPos + 1) + dhContainerPrefix;
194  }
195 
196  // Override streaming parameters from StreamTool if requested.
197  std::string containerNameHint = m_containerNameHint;
198  std::string branchNameHint = m_branchNameHint;
199  std::string containerFriendPostfix;
200  while (pos1 != std::string::npos) {
201  const std::string::size_type pos2 = output.find('=', pos1);
202  const std::string thisKey = output.substr(pos1 + 1, pos2 - pos1 - 1);
203  const std::string::size_type pos3 = output.find(']', pos2);
204  const std::string value = output.substr(pos2 + 1, pos3 - pos2 - 1);
205  if (thisKey == "OutputCollection") {
206  dhContainerPrefix = value;
207  } else if (thisKey == "PoolContainerPrefix") {
208  containerPrefix = value;
209  } else if (thisKey == "TopLevelContainerName") {
210  containerNameHint = value;
211  } else if (thisKey == "SubLevelBranchName") {
212  branchNameHint = value;
213  } else if (thisKey == "PoolContainerFriendPostfix") {
214  containerFriendPostfix = value;
215  }
216  pos1 = output.find('[', pos3);
217  }
218 
219  // --- Special types: DataHeader & Form
220  if( tname.compare(0, 10, "DataHeader") == 0 ) {
221  if( tname.compare(10, 4, "Form") == 0 ) {
222  containerName = dhContainerPrefix + "Form" + "(" + tname + ")";
223  } else {
224  if (key[key.size() - 1] == '/') {
225  containerName = dhContainerPrefix + "(" + key + tname + ")";
226  } else {
227  containerName = dhContainerPrefix + "(" + tname + ")";
228  }
229  }
230  }
231  // AttributeList - writing attributes separately to EventTag container group
232  else if (tname.compare(0, 13, "AttributeList") == 0) {
233  // Find the right storage type and name for EventTag values
234  if( pool::ROOTRNTUPLE_StorageType.exactMatch(tech) ) {
235  containerName = std::string(APRDefaults::RNTupleNames::EventTag) + "(" + key + ")";
236  } else {
237  // no indexing needed (nothing points to Tags)
238  // safe to set tech here - it will not be overwritten by decodeOutput
239  tech = pool::ROOTTREE_StorageType.type();
240  containerName = std::string(APRDefaults::TTreeNames::EventTag) + "(" + key + ")";
241  }
242  }
243  // all other object types
244  else {
245  const std::string typeTok = "<type>", keyTok = "<key>";
246  containerName = containerPrefix + containerFriendPostfix + containerNameHint;
247  if (!branchNameHint.empty()) {
248  containerName += "(" + branchNameHint + ")";
249  }
250  const std::size_t pos1 = containerName.find(typeTok);
251  if (pos1 != std::string::npos) {
252  containerName.replace(pos1, typeTok.size(), tname);
253  }
254  const std::size_t pos2 = containerName.find(keyTok);
255  if (pos2 != std::string::npos) {
256  if (key.empty()) {
257  containerName.replace(pos2, keyTok.size(), tname);
258  } else {
259  containerName.replace(pos2, keyTok.size(), key);
260  }
261  }
262  }
263  m_athenaPoolCnvSvc->decodeOutputSpec(containerName, tech).ignore();
264  placement.setContainerName(containerName);
265  placement.setTechnology(tech);
266  return(placement);
267 }

◆ storageType()

long AthenaPoolConverter::storageType ( )
staticinherited
Returns
storage type.

Definition at line 156 of file AthenaPoolConverter.cxx.

156  {
157  return(POOL_StorageType);
158 }

◆ tracks()

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

Definition at line 50 of file Converter.h.

50 {return m_tracks;}

Member Data Documentation

◆ ATLAS_THREAD_SAFE

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

Messaging initialized (initMessaging)

Definition at line 141 of file AthMessaging.h.

◆ m_athenaPoolCnvSvc

ServiceHandle<IAthenaPoolCnvSvc> AthenaPoolConverter::m_athenaPoolCnvSvc
protectedinherited

Definition at line 111 of file AthenaPoolConverter.h.

◆ m_beamX

double Converter::m_beamX
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_beamY

double Converter::m_beamY
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_beamZ

double Converter::m_beamZ
protectedinherited

Definition at line 320 of file Converter.h.

◆ m_branchNameHint

std::string AthenaPoolConverter::m_branchNameHint
protectedinherited

Definition at line 121 of file AthenaPoolConverter.h.

◆ m_classDesc

RootType AthenaPoolConverter::m_classDesc
protectedinherited

Definition at line 112 of file AthenaPoolConverter.h.

◆ m_classDescs

ClassMap AthenaPoolConverter::m_classDescs
protectedinherited

Definition at line 117 of file AthenaPoolConverter.h.

◆ m_className

std::string AthenaPoolConverter::m_className
protectedinherited

Definition at line 116 of file AthenaPoolConverter.h.

◆ m_containerNameHint

std::string AthenaPoolConverter::m_containerNameHint
protectedinherited

Definition at line 120 of file AthenaPoolConverter.h.

◆ m_containerPrefix

std::string AthenaPoolConverter::m_containerPrefix
protectedinherited

Definition at line 119 of file AthenaPoolConverter.h.

◆ m_conv_mut

CallMutex AthenaPoolConverter::m_conv_mut
protectedinherited

Definition at line 127 of file AthenaPoolConverter.h.

◆ m_dataObject

const DataObject* AthenaPoolConverter::m_dataObject
protectedinherited

Definition at line 123 of file AthenaPoolConverter.h.

◆ m_i_poolToken

const Token* AthenaPoolConverter::m_i_poolToken
protectedinherited

Definition at line 124 of file AthenaPoolConverter.h.

◆ m_imsg

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

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

◆ m_lvl

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

Current logging level.

Definition at line 138 of file AthMessaging.h.

◆ m_msg_tls

boost::thread_specific_ptr<MsgStream> AthMessaging::m_msg_tls
mutableprivateinherited

MsgStream instance (a std::cout like with print-out levels)

Definition at line 132 of file AthMessaging.h.

◆ m_nm

std::string AthMessaging::m_nm
privateinherited

Message source name.

Definition at line 129 of file AthMessaging.h.

◆ m_tracks

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

Definition at line 321 of file Converter.h.


The documentation for this class was generated from the following file:
AthMessaging::m_lvl
std::atomic< MSG::Level > m_lvl
Current logging level.
Definition: AthMessaging.h:138
Trk::numberOfPixelHits
@ numberOfPixelHits
number of pixel layers on track with absence of hits
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:57
AthenaPoolConverter::m_dataObject
const DataObject * m_dataObject
Definition: AthenaPoolConverter.h:123
CalculateHighPtTerm.pT
pT
Definition: ICHEP2016/CalculateHighPtTerm.py:57
Converter::ipCorr
void ipCorr(double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
Definition: Converter.h:257
python.tests.PyTestsLib.finalize
def finalize(self)
_info( "content of StoreGate..." ) self.sg.dump()
Definition: PyTestsLib.py:53
DataModel_detail::const_iterator
Const iterator class for DataVector/DataList.
Definition: DVLIterator.h:82
Placement
This class holds all the necessary information to guide the writing of an object in a physical place.
Definition: Placement.h:19
Trk::numberOfTRTHighThresholdHits
@ numberOfTRTHighThresholdHits
total number of TRT hits which pass the high threshold
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:87
AthenaPoolConverter::DataObjectToPool
virtual StatusCode DataObjectToPool(IOpaqueAddress *pAddr, DataObject *pObj)=0
Write an object into POOL.
Converter::m_beamY
double m_beamY
Definition: Converter.h:320
StateLessPT_NewConfig.proxy
proxy
Definition: StateLessPT_NewConfig.py:392
phi
Scalar phi() const
phi method
Definition: AmgMatrixBasePlugin.h:64
TauGNNUtils::Variables::Track::nPixelHits
bool nPixelHits(const xAOD::TauJet &, const xAOD::TauTrack &track, double &out)
Definition: TauGNNUtils.cxx:542
APRDefaults::RNTupleNames::DataHeader
static constexpr const char * DataHeader
Definition: APRDefaults.h:20
AthenaPoolConverter::m_athenaPoolCnvSvc
ServiceHandle< IAthenaPoolCnvSvc > m_athenaPoolCnvSvc
Definition: AthenaPoolConverter.h:111
eta
Scalar eta() const
pseudorapidity method
Definition: AmgMatrixBasePlugin.h:79
Trk::ParametersT
Dummy class used to allow special convertors to be called for surfaces owned by a detector element.
Definition: EMErrorDetail.h:25
InDetAccessor::phi0
@ phi0
Definition: InDetAccessor.h:33
theta
Scalar theta() const
theta method
Definition: AmgMatrixBasePlugin.h:71
conifer::pow
constexpr int pow(int x)
Definition: conifer.h:20
xAOD::JetInput::Track
@ Track
Definition: JetContainerInfo.h:61
Token::auxString
const std::string & auxString() const
Access auxiliary string.
Definition: Token.h:89
Trk::TrackParticleBase::trackSummary
const TrackSummary * trackSummary() const
accessor function for TrackSummary.
Definition: TrackParticleBase.h:247
AthenaPoolConverter::storageType
static long storageType()
Definition: AthenaPoolConverter.cxx:156
test_pyathena.pt
pt
Definition: test_pyathena.py:11
M_PI
#define M_PI
Definition: ActiveFraction.h:11
APRDefaults::TTreeNames::EventTag
static constexpr const char * EventTag
Definition: APRDefaults.h:13
Trk::z0
@ z0
Definition: ParamDefs.h:70
athena.value
value
Definition: athena.py:122
python.SystemOfUnits.TeV
int TeV
Definition: SystemOfUnits.py:158
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
drawFromPickle.cos
cos
Definition: drawFromPickle.py:36
Token::classID
const Guid & classID() const
Access database identifier.
Definition: Token.h:71
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
MCP::ScaleSmearParam::r2
@ r2
drawFromPickle.exp
exp
Definition: drawFromPickle.py:36
Placement::setContainerName
Placement & setContainerName(const std::string &containerName)
Set container name.
Definition: Placement.h:34
AthMessaging::m_imsg
std::atomic< IMessageSvc * > m_imsg
MessageSvc pointer.
Definition: AthMessaging.h:135
python.SystemOfUnits.ms
int ms
Definition: SystemOfUnits.py:132
Athena::getMessageSvc
IMessageSvc * getMessageSvc(bool quiet=false)
Definition: getMessageSvc.cxx:20
pool::DbType::type
int type() const
Access to full type.
Definition: DbType.h:66
Trk::numberOfBLayerHits
@ numberOfBLayerHits
these are the hits in the 0th pixel layer?
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:51
AthenaPoolConverter::m_conv_mut
CallMutex m_conv_mut
Definition: AthenaPoolConverter.h:127
Token
This class provides a token that identifies in a unique way objects on the persistent storage.
Definition: Token.h:21
Converter::phiCorr
double phiCorr(double phi)
Definition: Converter.h:248
TokenAddress
This class provides a Generic Transient Address for POOL tokens.
Definition: TokenAddress.h:21
Token::fromString
Token & fromString(const std::string &from)
Build from the string representation of a token.
Definition: Token.cxx:133
TauGNNUtils::Variables::Track::nSiHits
bool nSiHits(const xAOD::TauJet &, const xAOD::TauTrack &track, double &out)
Definition: TauGNNUtils.cxx:691
TrigConf::MSGTC::Level
Level
Definition: Trigger/TrigConfiguration/TrigConfBase/TrigConfBase/MsgStream.h:21
AthenaPoolConverter::m_i_poolToken
const Token * m_i_poolToken
Definition: AthenaPoolConverter.h:124
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
Converter::m_beamX
double m_beamX
Definition: Converter.h:320
Trk::numberOfSCTHits
@ numberOfSCTHits
number of SCT holes
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:71
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
AthenaPoolConverter::m_containerPrefix
std::string m_containerPrefix
Definition: AthenaPoolConverter.h:119
calibdata.exception
exception
Definition: calibdata.py:496
Trk::TrackParticleBase::fitQuality
const FitQuality * fitQuality() const
accessor function for FitQuality.
Definition: TrackParticleBase.h:259
chi2
double chi2(TH1 *h0, TH1 *h1)
Definition: comparitor.cxx:522
AthenaPoolConverter::m_containerNameHint
std::string m_containerNameHint
Definition: AthenaPoolConverter.h:120
TRT::Track::d0
@ d0
Definition: InnerDetector/InDetCalibEvent/TRT_CalibData/TRT_CalibData/TrackInfo.h:62
Placement::setFileName
Placement & setFileName(const std::string &fileName)
Set file name.
Definition: Placement.h:30
drawFromPickle.tan
tan
Definition: drawFromPickle.py:36
Trk::FitQuality
Class to represent and store fit qualities from track reconstruction in terms of and number of degre...
Definition: FitQuality.h:97
TRT::Track::z0
@ z0
Definition: InnerDetector/InDetCalibEvent/TRT_CalibData/TRT_CalibData/TrackInfo.h:63
CLID
uint32_t CLID
The Class ID type.
Definition: Event/xAOD/xAODCore/xAODCore/ClassID_traits.h:47
APRDefaults::RNTupleNames::EventTag
static constexpr const char * EventTag
Definition: APRDefaults.h:19
AthMessaging::msg
MsgStream & msg() const
The standard message stream.
Definition: AthMessaging.h:164
Converter::addTrack
void addTrack(TIDA::Track *t)
Definition: Converter.h:45
pool_uuid.guid
guid
Definition: pool_uuid.py:112
merge.output
output
Definition: merge.py:17
APRDefaults::TTreeNames::DataHeader
static constexpr const char * DataHeader
Definition: APRDefaults.h:14
Trk::numberOfTRTHits
@ numberOfTRTHits
number of TRT outliers
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:79
Trk::TrackSummary
A summary of the information contained by a track.
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:287
Trk::d0
@ d0
Definition: ParamDefs.h:69
AthenaPoolConverter::PoolToDataObject
virtual StatusCode PoolToDataObject(DataObject *&pObj, const Token *token, const std::string &key)=0
Read an object from POOL.
Token::toString
virtual const std::string toString() const
Retrieve the string representation of the token.
Definition: Token.cxx:114
Rec::TrackParticle
Definition: Reconstruction/Particle/Particle/TrackParticle.h:47
Rec::TrackParticle::measuredPerigee
const Trk::Perigee * measuredPerigee() const
Accessor method for Perigee.
Definition: Reconstruction/Particle/Particle/TrackParticle.h:180
DataVector::end
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
AthenaPoolConverter::DataObjectToPers
virtual StatusCode DataObjectToPers(DataObject *pObj, IOpaqueAddress *&pAddr)=0
Convert an object into Persistent.
Trk::DetectorType
DetectorType
enumerates the various detector types currently accessible from the isHit() method.
Definition: Tracking/TrkEvent/TrkTrackSummary/TrkTrackSummary/TrackSummary.h:231
DiTauMassTools::MaxHistStrategyV2::e
e
Definition: PhysicsAnalysis/TauID/DiTauMassTools/DiTauMassTools/HelperFunctions.h:26
pool::DbType::exactMatch
bool exactMatch(const DbType &typ) const
Definition: DbType.h:73
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
AthenaPoolConverter::m_branchNameHint
std::string m_branchNameHint
Definition: AthenaPoolConverter.h:121
TokenAddress::getToken
Token * getToken()
Definition: TokenAddress.h:48
Token::setAuxString
Token & setAuxString(const std::string &auxString)
Set auxiliary string.
Definition: Token.h:91
AthMessaging::m_nm
std::string m_nm
Message source name.
Definition: AthMessaging.h:129
Placement::setTechnology
Placement & setTechnology(int technology)
Set technology type.
Definition: Placement.h:38
TIDA::Track
Definition: Trigger/TrigAnalysis/TrigInDetAnalysis/TrigInDetAnalysis/Track.h:26
makeTransCanvas.text
text
Definition: makeTransCanvas.py:11
Trk::FitQuality::chiSquared
double chiSquared() const
returns the of the overall track fit
Definition: FitQuality.h:56
Trk::FitQuality::numberDoF
int numberDoF() const
returns the number of degrees of freedom of the overall track or vertex fit as integer
Definition: FitQuality.h:60
AthMessaging::initMessaging
void initMessaging() const
Initialize our message level and MessageSvc.
Definition: AthMessaging.cxx:39
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
MCP::ScaleSmearParam::r1
@ r1
AthMessaging::m_msg_tls
boost::thread_specific_ptr< MsgStream > m_msg_tls
MsgStream instance (a std::cout like with print-out levels)
Definition: AthMessaging.h:132
SG::DataProxy
Definition: DataProxy.h:44
Converter::m_tracks
std::vector< TIDA::Track * > m_tracks
Definition: Converter.h:321
Trk::phi0
@ phi0
Definition: ParamDefs.h:71
python.trfValidateRootFile.rc
rc
Definition: trfValidateRootFile.py:350
DataVector::begin
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37
SCT_Monitoring::summary
@ summary
Definition: SCT_MonitoringNumbers.h:65