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

#include <TileCellContainerCnv.h>

Inheritance diagram for TileCellContainerCnv:
Collaboration diagram for TileCellContainerCnv:

Public Types

typedef T_AthenaPoolCustCnv< TileCellContainer, TileCellVecBaseType

Public Member Functions

 TileCellContainerCnv (ISvcLocator *svcloc)
virtual ~TileCellContainerCnv ()
virtual StatusCode initialize () override
 initialization
virtual TileCellVeccreatePersistent (TileCellContainer *cont) override
virtual TileCellContainercreateTransient () override
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.
virtual StatusCode createRep (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Create a POOL persistent representation for a transient object.
virtual StatusCode fillRepRefs (IOpaqueAddress *pAddr, DataObject *pObj) override
 Create a POOL persistent representation for a transient object.
const ServiceHandle< StoreGateSvc > & detStore () const
 Handle to DetectorStore.
void addTrack (TIDA::Track *t)
const std::vector< TIDA::Track * > & tracks () const
void clear ()
void selectTracks (const TrigInDetTrackCollection *trigtracks)
void selectTracks (const Rec::TrackParticleContainer *trigtracks)
void selectTracks (const Analysis::MuonContainer *muontracks)
bool msgLvl (const MSG::Level lvl) const
 Test the output level.
MsgStream & msg () const
 The standard message stream.
MsgStream & msg (const MSG::Level lvl) const
 The standard message stream.
void setLevel (MSG::Level lvl)
 Change the current logging level.

Static Public Member Functions

static 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 TileCellVeccreatePersistentWithKey (TileCellContainer *obj, const std::string &) override
 method to be implemented by the developer.
virtual PERScreatePersistentWithKey (TRANS *obj, const std::string &key)=0
 method to be implemented by the developer.
virtual TileCellContainercreateTransientWithKey (const std::string &) override
 method to be implemented by the developer.
PpoolReadObject ()
 Read object of type P.
void poolReadObject (TopLevelTPCnvBase &tlp_converter)
 Read object of type P (plus all extending objects) using the indicated top-level TP converter.
void keepPoolObj (TileCellVec *obj, const std::string &output)
 Remember the POOL object to be written out (will be deleted after commit)
void keepPoolObj (PERS *obj, const std::string &output)
 Remember the POOL object to be written out (will be deleted after commit)
virtual StatusCode transToPers (TileCellContainer *, TileCellVec *&) override
 Obsolete methods replaced by createPersistent() and createTransient() obsolete.
virtual StatusCode persToTrans (TileCellContainer *&, TileCellVec *) override
 obsolete
virtual StatusCode DataObjectToPers (DataObject *pObj, IOpaqueAddress *&pAddr) override
 Convert an object into Persistent.
virtual StatusCode DataObjectToPool (IOpaqueAddress *pAddr, DataObject *pObj) override
 Write an object into POOL.
virtual StatusCode PoolToDataObject (DataObject *&pObj, const Token *token, const std::string &key) override
 Read an object from POOL.
virtual StatusCode cleanUp (const std::string &output) override
 Callback from the CleanupSvc to delete persistent object in the local list.
Placement setPlacementForP (P &p, const std::string &key, const std::string &output)
 Set POOL placement for type P.
StatusCode objectToPool (P *pObj, std::unique_ptr< Token > &token, const std::string &key, const std::string &output)
 Write an object into POOL returning its token.
StatusCode poolToObject (const Token *&token, P *&pObj)
 Read an object from POOL.
virtual bool compareClassGuid (const Guid &clid) const
 Compare POOL class GUID with the one of the object being read.
virtual void setToken (const std::string &token)
 Set the token (in std::string representation) and classID for the object that will be read next.
virtual Placement setPlacement (const std::string &key, const std::string &output)
 Set POOL placement.
virtual Placement setPlacementWithType (const std::string &tname, const std::string &key, const std::string &output)
 Set POOL placement hint for a given type.
virtual const DataObject * getDataObject () const
double phiCorr (double phi)
void ipCorr (double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)

Protected Attributes

std::map< std::string, std::vector< std::unique_ptr< TileCellVec > > > m_persObjLists
 Local cache for persistent objects created by this converter, grouped by processing slot These objects are deleted after a commit.
std::mutex m_pListMutex
 protection mutex for m_persObjLists
Guid m_classID
ServiceHandle< StoreGateSvcm_detStore
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

int cell_index (int side, int phi, int eta) const
void initIdToIndex ()
int round32 (double x)
int round16 (double x)
void initMessaging () const
 Initialize our message level and MessageSvc.

Private Attributes

ServiceHandle< StoreGateSvcm_storeGate
const TileTBIDm_tileTBID {nullptr}
const MbtsDetDescrManagerm_mbtsMgr {nullptr}
int m_version {0}
Identifier m_id [NCELLMBTS] {}
CaloDetDescrElementm_dde [NCELLMBTS] {}
int m_gainIndex [17] {}
int m_gain [8] {}
std::string m_nm
 Message source name.
boost::thread_specific_ptr< MsgStream > m_msg_tls
 MsgStream instance (a std::cout like with print-out levels)
std::atomic< IMessageSvc * > m_imsg
 MessageSvc pointer.
std::atomic< MSG::Level > m_lvl
 Current logging level.
std::atomic_flag m_initialized ATLAS_THREAD_SAFE
 Messaging initialized (initMessaging)

Static Private Attributes

static const int NSIDE = 2
static const int NPHI = 8
static const int NETA = 2
static const int NCELLMBTS = NSIDE*NPHI*NETA

Friends

class CnvFactory< TileCellContainerCnv >

Detailed Description

Definition at line 18 of file TileCellContainerCnv.h.

Member Typedef Documentation

◆ BaseType

◆ CallMutex

typedef std::mutex AthenaPoolConverter::CallMutex
protectedinherited

Definition at line 132 of file AthenaPoolConverter.h.

◆ ClassMap

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

Definition at line 120 of file AthenaPoolConverter.h.

◆ ClassMapIt

typedef ClassMap::const_iterator AthenaPoolConverter::ClassMapIt
protectedinherited

Definition at line 121 of file AthenaPoolConverter.h.

Constructor & Destructor Documentation

◆ TileCellContainerCnv()

TileCellContainerCnv::TileCellContainerCnv ( ISvcLocator * svcloc)

Definition at line 12 of file TileCellContainerCnv.cxx.

13 : TileCellContainerCnvBase::T_AthenaPoolCustomCnv(svcloc, "TileCellContainerCnv"),
14 m_storeGate("StoreGateSvc", "TileCellContainerCnv")
15{
16}
ServiceHandle< StoreGateSvc > m_storeGate

◆ ~TileCellContainerCnv()

TileCellContainerCnv::~TileCellContainerCnv ( )
virtual

Definition at line 18 of file TileCellContainerCnv.cxx.

19{
20}

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 }
Compatibility for old converter classes that don't get passed the key.

◆ cell_index()

int TileCellContainerCnv::cell_index ( int side,
int phi,
int eta ) const
inlineprivate

Definition at line 46 of file TileCellContainerCnv.h.

46{ return (side*NPHI+phi)*NETA+eta; }
Scalar eta() const
pseudorapidity method
Scalar phi() const
phi method

◆ classID()

const CLID & T_AthenaPoolCustCnv< TileCellContainer, TileCellVec >::classID ( )
staticinherited
Returns
class ID.

◆ cleanUp()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::cleanUp ( const std::string & output)
overrideprotectedvirtualinherited

Callback from the CleanupSvc to delete persistent object in the local list.

◆ clear()

void Converter::clear ( )
inlineinherited

Definition at line 53 of file Converter.h.

53{m_tracks.clear();}

◆ compareClassGuid()

virtual bool T_AthenaPoolCustCnv< TileCellContainer, TileCellVec >::compareClassGuid ( const Guid & clid) const
protectedvirtualinherited

Compare POOL class GUID with the one of the object being read.

Parameters
clid[IN] GUID to compare
Returns
true if the type of the object about to be read matches the GUID

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

Definition at line 56 of file AthenaPoolConverter.cxx.

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

◆ createPersistent()

TileCellVec * TileCellContainerCnv::createPersistent ( TileCellContainer * cont)
overridevirtual

Implements T_AthenaPoolCustomCnv< TileCellContainer, TileCellVec >.

Definition at line 94 of file TileCellContainerCnv.cxx.

95{
96 // Convert every TileCell to 3 32-bit integers: ID,Ene, and (time,qual,qain)
97
98 std::string name = m_storeGate->proxy(cont)->name();
99 auto vecCell = std::make_unique<TileCellVec>();
100 vecCell->reserve(NCELLMBTS);
101
102 ATH_MSG_DEBUG("storing TileCells from " << name << " in POOL");
103
104 vecCell->push_back(m_version);
105 int nMBTSfound=0;
106
107 std::vector<const TileCell *> allCells;
108
109 switch (m_version) {
110
111 case 1: // 3 words per cell, energy scale factor is 1000, time scale factor is 100
112 for (const TileCell* cell : *cont) {
113 ATH_MSG_VERBOSE("ene=" << cell->energy()
114 << " time=" << cell->time()
115 << " qual=" << (int)cell->qual1()
116 << " gain=" << (int)cell->gain());
117 unsigned int id = cell->ID().get_identifier32().get_compact();
118 int ene = round32(cell->energy() * 1000.);
119 unsigned int tim = 0x8000 + round16(cell->time()*100.);
120 unsigned int qua = std::max(0, std::min(0xFF, (int)cell->qual1()));
121 unsigned int gai = std::max(0, std::min(0xFF, 0x80 + (int)(cell->gain())));
122 unsigned int tqg = (tim<<16) | (qua<<8) | gai;
123 vecCell->push_back(id);
124 vecCell->push_back((unsigned int)ene);
125 vecCell->push_back(tqg);
126 ATH_MSG_VERBOSE("packing cell in three words " << MSG::hex << id <<
127 " " << ene << " " << tqg << MSG::dec);
128 }
129 break;
130
131 case 2: // 1 or 2 words for MBTS cells, 3 words for others, energy scale factor is 1000, time scale factor is 100
132
133 // prepare vector with all cells first, expect at least 32 MBTS cells
134 allCells.resize(NCELLMBTS);
135 for (const TileCell* cell : *cont) {
136 Identifier id = cell->ID();
137 if (m_tileTBID->is_tiletb(id)) {
138 int side = std::max(0,m_tileTBID->type(id));
139 int phi = m_tileTBID->module(id);
140 int eta = m_tileTBID->channel(id);
141 int ind = cell_index(side,phi,eta);
142 if (eta<NETA && phi<NPHI && ind < NCELLMBTS) {
143 allCells[ind] = cell;
144 ++nMBTSfound;
145 } else {
146 allCells.push_back(cell);
147 }
148 } else {
149 allCells.push_back(cell);
150 }
151 }
152
153 if (nMBTSfound>0) {
154
155 // save first 32 cells (MBTS) without identifiers, 2 words per cell, put zeros for empty cells
156 // if MBTS energy is in pCb, then LSB corresponds to 1/12 ADC count of high gain
157 for (int ind=0; ind<NCELLMBTS; ++ind) {
158 int energy = 0;
159 int time = 0;
160 int quality= 0;
161 int gain = m_gain[0]; // non-existing gain in CaloGain - to mark non-existing cells
162 const TileCell* cell = allCells[ind];
163 if (cell) {
164 energy = round32(cell->energy() * 1000.);
165 time = round16(cell->time() * 100.);
166 quality= cell->qual1();
167 gain = cell->gain();
168
169 ATH_MSG_VERBOSE("ind=" << ind <<
170 " ene=" << cell->energy() <<
171 " time=" << cell->time() <<
172 " qual=" << (int)cell->qual1() <<
173 " gain=" << (int)cell->gain());
174 }
175 else {
176 ATH_MSG_VERBOSE("ind=" << ind << " create MBTS cell with zero energy");
177 }
178
179 // put correct MBTS cells in one word
180 if (time == 0 && // expect time to be equal to zero
181 -0x10000 < energy && energy < 0xEFFFF && // expect energy within (-65,980) pCb
182 -17 < gain && gain < 0 ) { // expext only gains in TileCal range
183
184 unsigned int ene = energy+0x10000; // shift by 65 pCb (65*10^3 because of scaling)
185 unsigned int qua = std::max(0, std::min(0xFF, quality)); // 8 bits for quality
186 unsigned int gai = m_gainIndex[-gain];
187 unsigned int gqe = (gai << 28) | (qua<<20) | ene; // upper most bit is always 1 here
188 vecCell->push_back(gqe);
189
190 ATH_MSG_VERBOSE("packing cell " << ind << " in one word " <<
191 MSG::hex << gqe << MSG::dec);
192
193 } else { // cells with time, use 2 words for channel
194 // but make sure that upper most bit in energy word is zero
195
196 unsigned int ene = std::max(0, std::min(0x7FFFFFFF, 0x40000000 + energy));
197 unsigned int tim = std::max(0, std::min(0xFFFF, 0x8000 + time));
198 unsigned int qua = std::max(0, std::min(0xFF, quality)); // 8 bits for quality
199 unsigned int gai = std::max(0, std::min(0xFF, 0x80 + gain));
200 unsigned int tqg = (tim<<16) | (qua<<8) | gai;
201 vecCell->push_back(ene);
202 vecCell->push_back(tqg);
203
204 ATH_MSG_VERBOSE("packing cell " << ind << " in two words " <<
205 MSG::hex << ene << " " << tqg << MSG::dec);
206 }
207 }
208
209 } else {
210
211 (*vecCell)[0] = 1; // no MBTS found - use version 1 for packing
212 }
213
214 // keep all other cells (if any) with identifiers, 3 words per cell
215 for (unsigned int ind=NCELLMBTS; ind<allCells.size(); ++ind) {
216
217 const TileCell* cell = allCells[ind];
218
219 ATH_MSG_VERBOSE("ind=" << ind <<
220 " ene=" << cell->energy() <<
221 " time=" << cell->time() <<
222 " qual=" << (int)cell->qual1() <<
223 " gain=" << (int)cell->gain());
224
225 unsigned int id = cell->ID().get_identifier32().get_compact();
226 int ene = round32(cell->energy() * 1000.);
227 unsigned int tim = 0x8000 + round16(cell->time()*100.);
228 unsigned int qua = std::max(0, std::min(0xFF, (int)cell->qual1()));
229 unsigned int gai = std::max(0, std::min(0xFF, 0x80 + (int)(cell->gain())));
230 unsigned int tqg = (tim<<16) | (qua<<8) | gai;
231 vecCell->push_back(id);
232 vecCell->push_back((unsigned int)ene);
233 vecCell->push_back(tqg);
234
235 ATH_MSG_VERBOSE("packing cell " << ind << " in three words " <<
236 MSG::hex << id << " " << ene << " " << tqg << MSG::dec);
237 }
238 break;
239
240 default:
241
242 ATH_MSG_ERROR("Unknown version of TileCellVec, ver="<<m_version);
243
244 }
245
246 ATH_MSG_DEBUG("Storing data vector of size " << vecCell->size() << " with version " << vecCell->front());
247
248 return vecCell.release();
249}
#define ATH_MSG_DEBUG(x)
const TileTBID * m_tileTBID
int cell_index(int side, int phi, int eta) const
time(flags, cells_name, *args, **kw)

◆ createPersistentWithKey() [1/2]

virtual TileCellVec * T_AthenaPoolCustomCnv< TileCellContainer, TileCellVec >::createPersistentWithKey ( TileCellContainer * obj,
const std::string &  )
overrideprotectedvirtualinherited

method to be implemented by the developer.

It should create the persistent representation of the object, using the default top-level TP converter.

Parameters
obj[IN] transient object
Returns
the created persistent representation (by pointer)

◆ createPersistentWithKey() [2/2]

template<class TRANS, class PERS>
virtual PERS * T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::createPersistentWithKey ( TRANS * obj,
const std::string & key )
protectedpure virtualinherited

method to be implemented by the developer.

It should create the persistent representation of the object, using the default top-level TP converter.

Parameters
obj[IN] transient object
Returns
the created persistent representation (by pointer)

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

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

Definition at line 61 of file AthenaPoolConverter.cxx.

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

◆ createTransient()

TileCellContainer * TileCellContainerCnv::createTransient ( )
overridevirtual

Implements T_AthenaPoolCustomCnv< TileCellContainer, TileCellVec >.

Definition at line 251 of file TileCellContainerCnv.cxx.

252{
253 // Fill TileCellContainer from vector, creating cells from 3 integers
254
255 std::unique_ptr<TileCellVec> vec(this->poolReadObject<TileCellVec>());
256
257 ATH_MSG_DEBUG("Read TileCell Vec, size " << vec->size());
258
259 // create the TileCellContainer
260 auto cont = std::make_unique<TileCellContainer>();
261
262 TileCellVec::const_iterator it = vec->begin();
263 TileCellVec::const_iterator last = vec->end();
264
265 unsigned int version = *it++;
266 int iCell = 0;
267
268 switch (version) {
269 case 1:
270
271 for (; it != last; ) {
272
273 Identifier id(Identifier32(*it++));
274 int ene = (int)(*it++);
275 unsigned int tqg = *it++;
276
277 float ener = ene*1e-3;
278 float time = ((int)(tqg>>16) - 0x8000 ) * 0.01;
279 uint16_t qual = ((tqg>>8) & 0xFF);
281 int gain = (int)(tqg & 0xFF) - 0x80;
282
283 ATH_MSG_VERBOSE("reading cell " << (iCell++) << " " <<
284 MSG::hex << id << MSG::dec << " " << ene << " " <<
285 MSG::hex << tqg << MSG::dec);
286
287 ATH_MSG_VERBOSE("ene=" << ener << " time=" << time <<
288 " qual=" << qual << " gain=" << gain);
289
290 TileCell * cell = new TileCell(NULL,id,ener,time,qual,qbit,(CaloGain::CaloGain)gain);
291 cont->push_back(cell);
292 }
293 break;
294
295 case 2:
296
297 for (; it != last; ) {
298
299 Identifier id;
300 CaloDetDescrElement * dde = NULL;
301 float ener = 0.0;
302 float time = 0.0;
303 uint16_t qual = 0;
305 int gain = m_gain[0]; // non-existing gain in CaloGain - to mark non-existing cells
306
307 if (msgLvl(MSG::VERBOSE))
308 msg() << MSG::VERBOSE << "reading cell " << iCell << " ";
309
310 if (iCell < NCELLMBTS) { // first 32 cells are MBTS cells without identifier
311
312 id = m_id[iCell]; // identifier is taken from array
313 dde = m_dde[iCell]; // mbtsDDE is taken from array
314
315 int ene = (int)(*it++); // first word is energy
316
317 if (msgLvl(MSG::VERBOSE))
318 msg() << MSG::hex << id << " " << ene << " " << MSG::dec;
319
320 if (ene < 0 ) { // upper most bit is set, it means that everything is packed in one word
321
322 if (msgLvl(MSG::VERBOSE))
323 msg() << endmsg;
324
325 time = 0.0; // time was zero and it was not saved
326 ener = ((ene & 0xFFFFF) - 0x10000) * 1e-3;
327 qual = ((ene>>20) & 0xFF);
328 gain = m_gain[((ene>>28) & 0x7)]; // gain is taken from array
329
330 } else { // two words packing
331
332 unsigned int tqg = *it++;
333 ATH_MSG_VERBOSE(MSG::hex << tqg << MSG::dec);
334
335 ener = (ene - 0x40000000) * 1e-3;
336 time = ((int)(tqg>>16) - 0x8000 ) * 0.01;
337 qual = ((tqg>>8) & 0xFF);
338 gain = (int)(tqg & 0xFF) - 0x80;
339 }
340
341 } else { // three words packing for remaining cells
342
343 id = Identifier(Identifier32(*it++));
344 int ene = (int)(*it++);
345 unsigned int tqg = *it++;
346
347 ATH_MSG_VERBOSE(MSG::hex << id << MSG::dec << " " << ene <<
348 " " << MSG::hex << tqg << MSG::dec);
349
350 ener = ene*1e-3;
351 time = ((int)(tqg>>16) - 0x8000 ) * 0.01;
352 qual = ((tqg>>8) & 0xFF);
353 gain = (int)(tqg & 0xFF) - 0x80;
354 }
355
356 ATH_MSG_VERBOSE("ene=" << ener << " time=" << time
357 << " qual=" << qual << " gain=" << gain);
358
359 if (gain != m_gain[0]) { // don't create cells with non-existing gain
360 TileCell * cell = new TileCell(dde,id,ener,time,qual,qbit,(CaloGain::CaloGain)gain);
361 cont->push_back(cell);
362 }
363 else {
364 ATH_MSG_VERBOSE("Don't create MBTS cell with invalid gain");
365 }
366 ++iCell;
367 }
368 break;
369
370 default:
371
372 ATH_MSG_ERROR("Unknown version of TileCellVec, ver="<<version);
373 }
374
375 return cont.release();
376}
#define endmsg
std::vector< size_t > vec
P * poolReadObject()
Read object of type P.
CaloDetDescrElement * m_dde[NCELLMBTS]
Identifier m_id[NCELLMBTS]
@ MASK_TIME
Definition TileCell.h:67
@ MASK_CMPC
Definition TileCell.h:66
setWord1 uint16_t

◆ createTransientWithKey()

virtual TileCellContainer * T_AthenaPoolCustomCnv< TileCellContainer, TileCellVec >::createTransientWithKey ( const std::string & key)
overrideprotectedvirtualinherited

method to be implemented by the developer.

It has to find out the type of the persistent object to be read (by comparing GUIDs), read it using poolReadObject<P>(), call TLP converter to create a transient representation and return it. if the version 1 of poolReadObject is used, the persistent object HAS TO BE DELETED manually.

Implements T_AthenaPoolCustomCnvWithKey< TRANS, PERS >.

◆ DataObjectToPers()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::DataObjectToPers ( DataObject * pObj,
IOpaqueAddress *& pAddr )
overrideprotectedvirtualinherited

Convert an object into Persistent.

Parameters
pObj[IN] pointer to the transient object.
key[IN] StoreGate key (string) - placement hint to generate POOL container name

◆ DataObjectToPool()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::DataObjectToPool ( IOpaqueAddress * pAddr,
DataObject * pObj )
overrideprotectedvirtualinherited

Write an object into POOL.

Parameters
pObj[IN] pointer to the transient object.
key[IN] StoreGate key (string) - placement hint to generate POOL container name

◆ detStore()

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

Handle to DetectorStore.

Definition at line 69 of file AthenaPoolConverter.h.

69{ return m_detStore; }

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

Definition at line 66 of file AthenaPoolConverter.cxx.

141 {
143 try {
145 ATH_MSG_ERROR("FillRepRefs failed, key = " << pObj->name());
146 return StatusCode::FAILURE;
147 }
148 } catch (std::exception& e) {
149 ATH_MSG_ERROR("fillRepRefs - caught exception: " << e.what());
150 return StatusCode::FAILURE;
151 }
152 return StatusCode::SUCCESS;
153}
virtual StatusCode DataObjectToPool(IOpaqueAddress *pAddr, DataObject *pObj) override

◆ finalize()

StatusCode AthenaPoolConverter::finalize ( )
overridevirtualinherited

Definition at line 49 of file AthenaPoolConverter.cxx.

50 {
51 // Release AthenaPoolCnvSvc
52 if (!m_athenaPoolCnvSvc.release().isSuccess()) {
53 ATH_MSG_WARNING("Cannot release AthenaPoolCnvSvc.");
54 }
55 return(::Converter::finalize());
56}
#define ATH_MSG_WARNING(x)

◆ getDataObject()

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

Definition at line 111 of file AthenaPoolConverter.cxx.

◆ initialize()

StatusCode TileCellContainerCnv::initialize ( void )
overridevirtual

initialization

Reimplemented from T_AthenaPoolCustCnv< TRANS, PERS >.

Definition at line 22 of file TileCellContainerCnv.cxx.

23{
24 // Call base clase initialize
26
27 // version 2 by default
28 m_version = 2;
29
30 // Get the messaging service, print where you are
31 ATH_MSG_INFO("TileCellContainerCnv::initialize(), packing format version " << m_version);
32
33 // get StoreGate service
34 StatusCode sc = m_storeGate.retrieve();
35 if (sc.isFailure()) {
36 this->initIdToIndex();
37 ATH_MSG_ERROR("StoreGate service not found !");
38 }
39
40 sc = detStore()->retrieve(m_tileTBID);
41 if (sc.isFailure()) {
42 this->initIdToIndex();
43 ATH_MSG_ERROR("No TileTBID helper");
44 } else {
45 for (int side=0; side<NSIDE; ++side) {
46 for (int phi=0; phi<NPHI; ++phi) {
47 for (int eta=0; eta<NETA; ++eta) {
48 m_id[cell_index(side,phi,eta)] = m_tileTBID->channel_id((side>0)?1:-1,phi,eta);
49 }
50 }
51 }
52 }
53
54 sc = detStore()->retrieve(m_mbtsMgr);
55 if (sc.isFailure()) {
56 ATH_MSG_WARNING("Unable to retrieve MbtsDetDescrManager from DetectorStore");
57 memset(m_dde,0,sizeof(m_dde));
58 } else {
59 for (int side=0; side<NSIDE; ++side) {
60 for (int phi=0; phi<NPHI; ++phi) {
61 for (int eta=0; eta<NETA; ++eta) {
62 m_dde[cell_index(side,phi,eta)] = m_mbtsMgr->get_element(m_id[cell_index(side,phi,eta)]);
63 }
64 }
65 }
66 }
67
68
69 // set CaloGain <-> gain index mapping for all possible TileCal gains
70 for (int i=0; i<17; ++i) m_gainIndex[i] = 8;
71 m_gain[0] = -2; // put non-existing gain here
79
80 return StatusCode::SUCCESS;
81}
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_INFO(x)
static Double_t sc
virtual StatusCode initialize() override
Gaudi Service Interface method implementations:
const ServiceHandle< StoreGateSvc > & detStore() const
const MbtsDetDescrManager * m_mbtsMgr
@ TILELOWLOW
Definition CaloGain.h:12
@ INVALIDGAIN
Definition CaloGain.h:18
@ TILEONEHIGH
Definition CaloGain.h:17
@ TILEONELOW
Definition CaloGain.h:16
@ TILELOWHIGH
Definition CaloGain.h:13
@ TILEHIGHLOW
Definition CaloGain.h:14
@ TILEHIGHHIGH
Definition CaloGain.h:15
::StatusCode StatusCode
StatusCode definition for legacy code.

◆ initIdToIndex()

void TileCellContainerCnv::initIdToIndex ( )
private

Definition at line 83 of file TileCellContainerCnv.cxx.

84{
85 for (int side=0; side<NSIDE; ++side) {
86 for (int phi=0; phi<NPHI; ++phi) {
87 for (int eta=0; eta<NETA; ++eta) {
88 m_id[cell_index(side,phi,eta)] = (Identifier)cell_index(side,phi,eta);
89 }
90 }
91 }
92}

◆ initMessaging()

void AthMessaging::initMessaging ( ) const
privateinherited

Initialize our message level and MessageSvc.

This method should only be called once.

Definition at line 121 of file AthMessaging.cxx.

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

◆ ipCorr()

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

Definition at line 257 of file Converter.h.

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

◆ keepPoolObj() [1/2]

void T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::keepPoolObj ( TileCellVec * obj,
const std::string & output )
protectedinherited

Remember the POOL object to be written out (will be deleted after commit)

Parameters
obj[IN] persistent object

◆ keepPoolObj() [2/2]

template<class TRANS, class PERS>
void T_AthenaPoolCustomCnvWithKey< TRANS, PERS >::keepPoolObj ( PERS * obj,
const std::string & output )
protectedinherited

Remember the POOL object to be written out (will be deleted after commit)

Parameters
obj[IN] persistent object

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

164{
165 MsgStream* ms = m_msg_tls.get();
166 if (!ms) {
167 if (!m_initialized.test_and_set()) initMessaging();
168 ms = new MsgStream(m_imsg,m_nm);
169 m_msg_tls.reset( ms );
170 }
171
172 ms->setLevel (m_lvl);
173 return *ms;
174}
boost::thread_specific_ptr< MsgStream > m_msg_tls
void setLevel(MSG::Level lvl)
Change the current logging level.

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

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

152{
153 if (m_lvl <= lvl) {
154 msg() << lvl;
155 return true;
156 } else {
157 return false;
158 }
159}

◆ objectToPool()

StatusCode T_AthenaPoolCustCnv< TileCellContainer, TileCellVec >::objectToPool ( P * pObj,
std::unique_ptr< Token > & token,
const std::string & key,
const std::string & output )
protectedinherited

Write an object into POOL returning its token.

Parameters
pObj[IN] pointer to the object to be written.
token[OUT] POOL token of the persistent representation.
key[IN] StoreGate key (string) - placement hint to generate POOL container name

◆ persToTrans()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::persToTrans ( TileCellContainer *& ,
TileCellVec *  )
inlineoverrideprotectedvirtualinherited

obsolete

Definition at line 96 of file T_AthenaPoolCustomCnv.h.

96{ return(StatusCode::FAILURE); }

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

◆ poolReadObject() [1/2]

P * T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::poolReadObject ( )
protectedinherited

Read object of type P.

This is an exception-throwing version of poolToObject() plus reading of all extending objects. Version 1 - (see createTransient() above)

Returns
object read from POOL (by pointer)

◆ poolReadObject() [2/2]

void T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::poolReadObject ( TopLevelTPCnvBase & tlp_converter)
protectedinherited

Read object of type P (plus all extending objects) using the indicated top-level TP converter.

Version 2 - (see createTransient() above) NOTE: the TLP converter will delete the persistent object after createTransient()

Parameters
tlp_converter[IN] top-level TP converter to be used when reading

◆ PoolToDataObject()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::PoolToDataObject ( DataObject *& pObj,
const Token * token,
const std::string & key )
overrideprotectedvirtualinherited

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.

◆ poolToObject()

StatusCode T_AthenaPoolCustCnv< TileCellContainer, TileCellVec >::poolToObject ( const Token *& token,
P *& pObj )
protectedinherited

Read an object from POOL.

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

◆ repSvcType()

long AthenaPoolConverter::repSvcType ( ) const
overridevirtualinherited

Definition at line 51 of file AthenaPoolConverter.cxx.

58 {
59 return pool::POOL_StorageType.type();
60}

◆ round16()

int TileCellContainerCnv::round16 ( double x)
inlineprivate

Definition at line 60 of file TileCellContainerCnv.h.

60 {
61 if (x<-32767.) return -0x7FFF;
62 else if (x>32767.) return 0x7FFF;
63 else return (int)lround(x);
64 }
#define x

◆ round32()

int TileCellContainerCnv::round32 ( double x)
inlineprivate

Definition at line 54 of file TileCellContainerCnv.h.

54 {
55 if (x<-2147483647.) return -0x7FFFFFFF;
56 else if (x>2147483647.) return 0x7FFFFFFF;
57 else return (int)lround(x);
58 }

◆ 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
183
184 while(muonitr!=muonend) {
185
186 bool hasInDet = (*muonitr)->hasInDetTrackParticle();
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();
218
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,
239 -1) ;
240
241 addTrack(t);
242 }
243
244 }
void ipCorr(double d0, double z0, double &d0c, double &z0c, double phi0, double eta, double pt)
Definition Converter.h:257

◆ selectTracks() [2/3]

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

Definition at line 111 of file Converter.h.

111 {
112
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();
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,
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
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
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,
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 108 of file AthMessaging.cxx.

29{
30 m_lvl = lvl;
31}

◆ setPlacement()

virtual Placement T_AthenaPoolCnvBase< TileCellContainer >::setPlacement ( const std::string & key,
const std::string & output )
protectedvirtualinherited

Set POOL placement.

◆ setPlacementForP()

Placement T_AthenaPoolCustCnv< TileCellContainer, TileCellVec >::setPlacementForP ( P & p,
const std::string & key,
const std::string & output )
protectedinherited

Set POOL placement for type P.

◆ 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 106 of file AthenaPoolConverter.cxx.

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

◆ setToken()

virtual void T_AthenaPoolCustCnv< TileCellContainer, TileCellVec >::setToken ( const std::string & token)
protectedvirtualinherited

Set the token (in std::string representation) and classID for the object that will be read next.

Required by compareClassGuid() and poolReadObject(). Only extending converter needs to call this method explicitely

Parameters
token[IN] token for the object to be read

◆ storageType()

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

Definition at line 72 of file AthenaPoolConverter.cxx.

155 {
156 return pool::POOL_StorageType.type();
157}

◆ tracks()

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

Definition at line 50 of file Converter.h.

50{return m_tracks;}

◆ transToPers()

virtual StatusCode T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::transToPers ( TileCellContainer * ,
TileCellVec *&  )
inlineoverrideprotectedvirtualinherited

Obsolete methods replaced by createPersistent() and createTransient() obsolete.

Definition at line 94 of file T_AthenaPoolCustomCnv.h.

94{ return(StatusCode::FAILURE); }

◆ CnvFactory< TileCellContainerCnv >

friend class CnvFactory< TileCellContainerCnv >
friend

Definition at line 16 of file TileCellContainerCnv.h.

Member Data Documentation

◆ ATLAS_THREAD_SAFE

std::atomic_flag m_initialized AthMessaging::ATLAS_THREAD_SAFE
mutableprivateinherited

Messaging initialized (initMessaging)

Definition at line 141 of file AthMessaging.h.

◆ m_athenaPoolCnvSvc

ServiceHandle<IAthenaPoolCnvSvc> AthenaPoolConverter::m_athenaPoolCnvSvc
protectedinherited

Definition at line 117 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 127 of file AthenaPoolConverter.h.

◆ m_classDesc

RootType AthenaPoolConverter::m_classDesc
protectedinherited

Definition at line 118 of file AthenaPoolConverter.h.

◆ m_classDescs

ClassMap AthenaPoolConverter::m_classDescs
protectedinherited

Definition at line 123 of file AthenaPoolConverter.h.

◆ m_classID

Guid T_AthenaPoolCustCnv< TileCellContainer, TileCellVec >::m_classID
protectedinherited

Definition at line 96 of file T_AthenaPoolCustCnv.h.

◆ m_className

std::string AthenaPoolConverter::m_className
protectedinherited

Definition at line 122 of file AthenaPoolConverter.h.

◆ m_containerNameHint

std::string AthenaPoolConverter::m_containerNameHint
protectedinherited

Definition at line 126 of file AthenaPoolConverter.h.

◆ m_containerPrefix

std::string AthenaPoolConverter::m_containerPrefix
protectedinherited

Definition at line 125 of file AthenaPoolConverter.h.

◆ m_conv_mut

CallMutex AthenaPoolConverter::m_conv_mut
protectedinherited

Definition at line 133 of file AthenaPoolConverter.h.

◆ m_dataObject

const DataObject* AthenaPoolConverter::m_dataObject
protectedinherited

Definition at line 129 of file AthenaPoolConverter.h.

◆ m_dde

CaloDetDescrElement* TileCellContainerCnv::m_dde[NCELLMBTS] {}
private

Definition at line 50 of file TileCellContainerCnv.h.

50{};

◆ m_detStore

ServiceHandle<StoreGateSvc> AthenaPoolConverter::m_detStore
protectedinherited

Definition at line 116 of file AthenaPoolConverter.h.

◆ m_gain

int TileCellContainerCnv::m_gain[8] {}
private

Definition at line 52 of file TileCellContainerCnv.h.

52{};

◆ m_gainIndex

int TileCellContainerCnv::m_gainIndex[17] {}
private

Definition at line 51 of file TileCellContainerCnv.h.

51{};

◆ m_i_poolToken

const Token* AthenaPoolConverter::m_i_poolToken
protectedinherited

Definition at line 130 of file AthenaPoolConverter.h.

◆ m_id

Identifier TileCellContainerCnv::m_id[NCELLMBTS] {}
private

Definition at line 49 of file TileCellContainerCnv.h.

49{};

◆ m_imsg

std::atomic<IMessageSvc*> AthMessaging::m_imsg
mutableprivateinherited

MessageSvc pointer.

Definition at line 135 of file AthMessaging.h.

135{ nullptr };

◆ m_lvl

std::atomic<MSG::Level> AthMessaging::m_lvl
mutableprivateinherited

Current logging level.

Definition at line 138 of file AthMessaging.h.

138{ MSG::NIL };

◆ m_mbtsMgr

const MbtsDetDescrManager* TileCellContainerCnv::m_mbtsMgr {nullptr}
private

Definition at line 37 of file TileCellContainerCnv.h.

37{nullptr};

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

std::map<std::string, std::vector< std::unique_ptr<TileCellVec> > > T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::m_persObjLists
protectedinherited

Local cache for persistent objects created by this converter, grouped by processing slot These objects are deleted after a commit.

Definition at line 120 of file T_AthenaPoolCustomCnv.h.

◆ m_pListMutex

std::mutex T_AthenaPoolCustomCnvWithKey< TileCellContainer, TileCellVec >::m_pListMutex
protectedinherited

protection mutex for m_persObjLists

Definition at line 123 of file T_AthenaPoolCustomCnv.h.

◆ m_storeGate

ServiceHandle<StoreGateSvc> TileCellContainerCnv::m_storeGate
private

Definition at line 34 of file TileCellContainerCnv.h.

◆ m_tileTBID

const TileTBID* TileCellContainerCnv::m_tileTBID {nullptr}
private

Definition at line 36 of file TileCellContainerCnv.h.

36{nullptr};

◆ m_tracks

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

Definition at line 321 of file Converter.h.

◆ m_version

int TileCellContainerCnv::m_version {0}
private

Definition at line 39 of file TileCellContainerCnv.h.

39{0};

◆ NCELLMBTS

const int TileCellContainerCnv::NCELLMBTS = NSIDE*NPHI*NETA
staticprivate

Definition at line 44 of file TileCellContainerCnv.h.

◆ NETA

const int TileCellContainerCnv::NETA = 2
staticprivate

Definition at line 43 of file TileCellContainerCnv.h.

◆ NPHI

const int TileCellContainerCnv::NPHI = 8
staticprivate

Definition at line 42 of file TileCellContainerCnv.h.

◆ NSIDE

const int TileCellContainerCnv::NSIDE = 2
staticprivate

Definition at line 41 of file TileCellContainerCnv.h.


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