ATLAS Offline Software
Loading...
Searching...
No Matches
LArMinBiasAlg Class Reference

#include <LArMinBiasAlg.h>

Inheritance diagram for LArMinBiasAlg:

Classes

struct  CellInfo

Public Member Functions

 LArMinBiasAlg (const std::string &name, ISvcLocator *pSvcLocator)
 Standard Athena-Algorithm Constructor.
 ~LArMinBiasAlg ()
 Default Destructor.
virtual StatusCode initialize () override
virtual StatusCode execute () override
virtual StatusCode stop () override
virtual StatusCode sysInitialize () override
 Override sysInitialize.
virtual const DataObjIDColl & extraOutputDeps () const override
 Return the list of extra output dependencies.
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.
virtual StatusCode sysStart () override
 Handle START transition.
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles.
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles.
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T, V, H > &t)
void updateVHKA (Gaudi::Details::PropertyBase &)
MsgStream & msg () const
bool msgLvl (const MSG::Level lvl) const

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce (T &h)
void extraDeps_update_handler (Gaudi::Details::PropertyBase &ExtraDeps)
 Add StoreName to extra input/output deps as needed.

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t

Private Member Functions

void fillNtuple ()
void addCell (int index, double e1, double e2, double wt=1.)
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey>

Private Attributes

Gaudi::Property< int > m_datasetID_lowPt {this, "datasetID_lowPt", 119995}
Gaudi::Property< int > m_datasetID_highPt {this, "datasetID_highPt", 119996}
Gaudi::Property< double > m_weight_lowPt {this, "weight_highPt", 39.8606}
Gaudi::Property< double > m_weight_highPt {this, "weight_lowPt", 0.138128}
SG::ReadCondHandleKey< LArMCSymm_mcSymKey { this, "MCSymKey", "LArMCSym", "SG Key of LArMCSym object" }
SG::ReadCondHandleKey< LArOnOffIdMappingm_cablingKey {this,"CablingKey","LArOnOffIdMap","SG Key of LArOnOffIdMapping object"}
SG::ReadCondHandleKey< CaloDetDescrManagerm_caloMgrKey
SG::ReadCondHandleKey< CaloSuperCellDetDescrManagerm_caloSCMgrKey
const CaloCell_Base_IDm_calo_id = nullptr
std::vector< double > m_eCell
ServiceHandle< ITHistSvc > m_thistSvc {this,"THistSvc","THistSvc"}
TTree * m_tree = nullptr
int m_nevt_total = 0
int m_n1 = 0
int m_n2 = 0
int m_nsymcell = 0
double m_nevt [MAX_SYM_CELLS] {}
int m_layer [MAX_SYM_CELLS] {}
int m_region [MAX_SYM_CELLS] {}
int m_identifier [MAX_SYM_CELLS] {}
int m_ieta [MAX_SYM_CELLS] {}
float m_eta [MAX_SYM_CELLS] {}
float m_phi [MAX_SYM_CELLS] {}
double m_average [MAX_SYM_CELLS] {}
double m_rms [MAX_SYM_CELLS] {}
double m_offset [MAX_SYM_CELLS] {}
std::vector< CellInfom_CellList
std::vector< int > m_symCellIndex
float m_first {true}
int m_ncell = 0
SG::ReadHandleKey< xAOD::EventInfom_eventInfoKey {this,"EvtInfo", "EventInfo", "EventInfo name"}
StringArrayProperty m_inputKeys
SG::ReadHandleKeyArray< LArHitContainerm_larHitKeys
BooleanProperty m_isSC {this, "SuperCell", false, "Creating for SC ?"}
ToolHandle< ICaloSuperCellIDToolm_scidtool {this, "CaloSuperCellIDTool", "CaloSuperCellIDTool", "Offline / SuperCell ID mapping tool"}
DataObjIDColl m_extendedExtraObjects
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default).
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default).
std::vector< SG::VarHandleKeyArray * > m_vhka
bool m_varHandleArraysDeclared

Detailed Description

Definition at line 38 of file LArMinBiasAlg.h.

Member Typedef Documentation

◆ StoreGateSvc_t

typedef ServiceHandle<StoreGateSvc> AthCommonDataStore< AthCommonMsg< Algorithm > >::StoreGateSvc_t
privateinherited

Definition at line 388 of file AthCommonDataStore.h.

Constructor & Destructor Documentation

◆ LArMinBiasAlg()

LArMinBiasAlg::LArMinBiasAlg ( const std::string & name,
ISvcLocator * pSvcLocator )

Standard Athena-Algorithm Constructor.

Definition at line 19 of file LArMinBiasAlg.cxx.

19 :
20 AthAlgorithm(name,pSvcLocator)
21 {
22 }
AthAlgorithm()
Default constructor:

◆ ~LArMinBiasAlg()

LArMinBiasAlg::~LArMinBiasAlg ( )
default

Default Destructor.

Member Function Documentation

◆ addCell()

void LArMinBiasAlg::addCell ( int index,
double e1,
double e2,
double wt = 1. )
private

Definition at line 256 of file LArMinBiasAlg.cxx.

257 {
258 if (index < m_ncell && index>=0) {
260 if (index2<0) return;
261 if (index2 >= ((int)(m_CellList.size())) ) {
262 ATH_MSG_INFO(" LArMinBiasAlg::addCell: for " << index << ", " << index2 << " is out-of bounds for list of size " << m_CellList.size());
263 return;
264 }
265 double oldN = m_CellList[index2].nevt;
266 double oldAverage = m_CellList[index2].average;
267 double oldRMS = m_CellList[index2].rms;
268 double oldAverage2 = m_CellList[index2].offset;
269
270 double frac = oldN/(weight+oldN);
271 double Anew = weight+oldN;
272 double newAverage = frac*oldAverage + weight*energy/Anew;
273 double deltaE = energy-newAverage;
274 double newRMS = frac*(oldRMS + (newAverage-oldAverage)*(newAverage-oldAverage)) + weight*deltaE*deltaE/Anew;
275
276 double newAverage2 = frac*oldAverage2 + weight*eshift/Anew;
277
278 m_CellList[index2].nevt = Anew;
279 m_CellList[index2].average = newAverage;
280 m_CellList[index2].rms = newRMS;
281 m_CellList[index2].offset = newAverage2;
282
283 }
284 }
#define ATH_MSG_INFO(x)
std::vector< CellInfo > m_CellList
std::vector< int > m_symCellIndex
str index
Definition DeMoScan.py:362

◆ declareGaudiProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Algorithm > >::declareGaudiProperty ( Gaudi::Property< T, V, H > & hndl,
const SG::VarHandleKeyType &  )
inlineprivateinherited

specialization for handling Gaudi::Property<SG::VarHandleKey>

Definition at line 156 of file AthCommonDataStore.h.

158 {
160 hndl.value(),
161 hndl.documentation());
162
163 }
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)

◆ declareProperty()

Gaudi::Details::PropertyBase & AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty ( Gaudi::Property< T, V, H > & t)
inlineinherited

Definition at line 145 of file AthCommonDataStore.h.

145 {
146 typedef typename SG::HandleClassifier<T>::type htype;
148 }
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>

◆ detStore()

const ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< Algorithm > >::detStore ( ) const
inlineinherited

The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 95 of file AthCommonDataStore.h.

◆ evtStore()

ServiceHandle< StoreGateSvc > & AthCommonDataStore< AthCommonMsg< Algorithm > >::evtStore ( )
inlineinherited

The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.

Definition at line 85 of file AthCommonDataStore.h.

◆ execute()

StatusCode LArMinBiasAlg::execute ( )
overridevirtual

Definition at line 98 of file LArMinBiasAlg.cxx.

99 {
100 //.............................................
101
102 ATH_MSG_DEBUG(" LArMinBiasAlg execute()");
103
104 const EventContext& ctx = Gaudi::Hive::currentContext();
105
106 if (m_first) {
107
108 const CaloDetDescrManager_Base *cMgr=nullptr;
109 if(m_isSC){
110 SG::ReadCondHandle<CaloSuperCellDetDescrManager> caloMgrHandle{m_caloSCMgrKey};
111 ATH_CHECK(caloMgrHandle.isValid());
112 cMgr=(const CaloDetDescrManager_Base *)(*caloMgrHandle);
113 } else {
114 SG::ReadCondHandle<CaloDetDescrManager> caloMgrHandle{m_caloMgrKey};
115 ATH_CHECK(caloMgrHandle.isValid());
116 cMgr=(const CaloDetDescrManager_Base *)(*caloMgrHandle);
117 }
118
119 SG::ReadCondHandle<LArMCSym> mcsym (m_mcSymKey, ctx);
120 SG::ReadCondHandle<LArOnOffIdMapping> cablingHdl (m_cablingKey, ctx);
121 const LArOnOffIdMapping* cabling{*cablingHdl};
122 if(!cabling) {
123 ATH_MSG_ERROR( "Do not have cabling mapping from key " << m_cablingKey.key() );
124 return StatusCode::FAILURE;
125 }
126
127 m_ncell = m_calo_id->calo_cell_hash_max();
128 ATH_MSG_DEBUG("Hash max: "<<m_ncell);
129
130 ATH_MSG_INFO(" --- first event " << m_ncell);
131 m_symCellIndex.resize(m_ncell,-1);
132 std::vector<int> doneCell;
133 doneCell.resize(m_ncell,-1);
134
135 //m_readCell.resize(m_ncell,0);
136
137 m_eCell.resize(m_ncell,0.);
138
139 m_CellList.reserve(MAX_SYM_CELLS);
140 int nsym=0;
141 // loop over cells
142 // and find symmetry cells
143 for (unsigned int i=0;i<((unsigned int)(m_ncell));i++) {
144 IdentifierHash idHash=i;
145 Identifier id=m_calo_id->cell_id(idHash);
146 if (m_calo_id->is_tile(id)) continue;
147 // convert cell id to symmetric identifier
148 HWIdentifier hwid2 = mcsym->ZPhiSymOfl(id);
149 Identifier id2 = cabling->cnvToIdentifier(hwid2);
150 int i2 = (int) (m_calo_id->calo_cell_hash(id2));
151 if(i2>=m_ncell) {
152 ATH_MSG_WARNING("problem: i2: "<<i2<<" for id: "<<m_calo_id->print_to_string(id)<<" symmetrized: "<<m_calo_id->print_to_string(id2));
153 }
154 // we have already processed this hash => just need to associate cell i to the same symmetric cell
155 if (doneCell[i2]>=0) {
156 m_symCellIndex[i]=doneCell[i2];
157 ATH_MSG_DEBUG("Adding cell "<<id.get_identifier32().get_compact()<<" to a symmetrized cell "<<id2.get_identifier32().get_compact());
158 }
159 // we have not already processed this hash, add an entry for this new symmetric cell
160 else {
161 ATH_MSG_DEBUG("New symmetrized cell "<<id2.get_identifier32().get_compact());
162 doneCell[i2]=nsym;
163 m_symCellIndex[i] = nsym;
165 const CaloDetDescrElement* calodde = cMgr->get_element(id);
166 cell.eta = calodde->eta();
167 cell.phi = calodde->phi();
168 cell.region = m_calo_id->region(id);
169 cell.ieta = m_calo_id->eta(id);
170 cell.layer = m_calo_id->calo_sample(id);
171 cell.region = m_calo_id->region(id);
172 cell.ieta = m_calo_id->eta(id);
173 //cell.identifier = id2.get_identifier32().get_compact();
174 cell.identifier = id2;
175 cell.average=0.;
176 cell.offset=0.;
177 cell.rms=0.;
178 cell.nevt=0.;
179 m_CellList.push_back(cell);
180 nsym++;
181 }
182 }
183 ATH_MSG_INFO(" --- number of symmetric cells found " << nsym << " " << m_CellList.size());
184 if (nsym>=MAX_SYM_CELLS) ATH_MSG_ERROR(" More than "<<MAX_SYM_CELLS<<" number of symmetric cells... Fix array size for ntuple writing !!!! ");
185 m_nsymcell=nsym;
186 m_first=false;
187 }
188
189 SG::ReadHandle<xAOD::EventInfo> eventInfo(m_eventInfoKey);
190 if (!eventInfo.isValid()) {
191 ATH_MSG_ERROR ("Could not retrieve EventInfo");
192 return StatusCode::FAILURE;
193 }
194 int channelNumber = eventInfo->mcChannelNumber();
195
196 m_nevt_total++;
197
198 double weight=1.;
199
200// Dataset ID for lowPt MinBias
201 if (channelNumber==m_datasetID_lowPt) {
203 m_n1+=1;
204 }
205// Dataset ID for highPt MinBias
206 else if (channelNumber==m_datasetID_highPt) {
208 m_n2+=1;
209 }
210 else {
211 ATH_MSG_WARNING(" Neither low nor high Pt MinBias sample " << channelNumber << " set weight to 1.0 ");
212 weight=1.;
213 }
214
215
216 if ((m_nevt_total%100)==1) ATH_MSG_INFO(" ---- process event number " << m_nevt_total << " " << channelNumber << " weight " << weight);
217
218 for (int i=0;i<m_ncell;i++) m_eCell[i]=0.;
219
220 auto hitVectorHandles = m_larHitKeys.makeHandles(ctx);
221 for (auto & inputHits : hitVectorHandles) {
222 if (!inputHits.isValid()) {
223 ATH_MSG_ERROR("BAD HANDLE"); //FIXME improve error here
224 //return StatusCode::FAILURE;
225 continue;
226 }
227
228 for (const LArHit* hit : *inputHits)
229 {
230 Identifier hitCellID=hit->cellID();
231 double energy = hit->energy();
232 double time =hit->time();
233 Identifier cellID;
234 if(m_isSC){
235 cellID=m_scidtool->offlineToSuperCellID(hitCellID);
236 } else {
237 cellID=hitCellID;
238 }
239 int index = (int) (m_calo_id->calo_cell_hash(cellID));
240
241 if (index < m_ncell && index>=0 && std::fabs(time)<25.) {
242 m_eCell[index] += energy;
243 }
244
245 } // loop over hits in container
246 } // loop over containers
247
248 for (int i=0;i<m_ncell;i++) {
249 addCell(i,m_eCell[i],0.,weight);
250 }
251
252
253 return StatusCode::SUCCESS;
254 }
#define ATH_CHECK
Evaluate an expression and check for errors.
#define ATH_MSG_ERROR(x)
#define ATH_MSG_WARNING(x)
#define ATH_MSG_DEBUG(x)
#define MAX_SYM_CELLS
const CaloDetDescrElement * get_element(const Identifier &cellId) const
get element by its identifier
value_type get_compact() const
Get the compact id.
Identifier32 get_identifier32() const
Get the 32-bit version Identifier, will be invalid if >32 bits needed.
Gaudi::Property< int > m_datasetID_lowPt
SG::ReadHandleKey< xAOD::EventInfo > m_eventInfoKey
SG::ReadHandleKeyArray< LArHitContainer > m_larHitKeys
SG::ReadCondHandleKey< LArOnOffIdMapping > m_cablingKey
Gaudi::Property< double > m_weight_lowPt
Gaudi::Property< int > m_datasetID_highPt
SG::ReadCondHandleKey< CaloDetDescrManager > m_caloMgrKey
ToolHandle< ICaloSuperCellIDTool > m_scidtool
SG::ReadCondHandleKey< LArMCSym > m_mcSymKey
std::vector< double > m_eCell
BooleanProperty m_isSC
const CaloCell_Base_ID * m_calo_id
Gaudi::Property< double > m_weight_highPt
SG::ReadCondHandleKey< CaloSuperCellDetDescrManager > m_caloSCMgrKey
void addCell(int index, double e1, double e2, double wt=1.)
time(flags, cells_name, *args, **kw)

◆ extraDeps_update_handler()

void AthCommonDataStore< AthCommonMsg< Algorithm > >::extraDeps_update_handler ( Gaudi::Details::PropertyBase & ExtraDeps)
protectedinherited

Add StoreName to extra input/output deps as needed.

use the logic of the VarHandleKey to parse the DataObjID keys supplied via the ExtraInputs and ExtraOuputs Properties to add the StoreName if it's not explicitly given

◆ extraOutputDeps()

const DataObjIDColl & AthAlgorithm::extraOutputDeps ( ) const
overridevirtualinherited

Return the list of extra output dependencies.

This list is extended to include symlinks implied by inheritance relations.

Definition at line 50 of file AthAlgorithm.cxx.

51{
52 // If we didn't find any symlinks to add, just return the collection
53 // from the base class. Otherwise, return the extended collection.
54 if (!m_extendedExtraObjects.empty()) {
56 }
57 return Algorithm::extraOutputDeps();
58}
DataObjIDColl m_extendedExtraObjects

◆ fillNtuple()

void LArMinBiasAlg::fillNtuple ( )
private

Definition at line 286 of file LArMinBiasAlg.cxx.

287 {
288
289 ATH_MSG_INFO(" in fillNtuple " << m_nsymcell);
290 for (int i=0;i<m_nsymcell;i++) {
291 m_identifier[i] = m_CellList[i].identifier.get_identifier32().get_compact();
292 m_layer[i] = m_CellList[i].layer;
293 m_region[i] = m_CellList[i].region;
294 m_ieta[i] = m_CellList[i].ieta;
295 m_eta[i] = m_CellList[i].eta;
296 m_phi[i] = m_CellList[i].phi;
297 m_nevt[i] = m_CellList[i].nevt;
298 m_offset[i] = (float) (m_CellList[i].offset);
299 m_average[i] = (float) (m_CellList[i].average);
300 m_rms[i] = (float) (std::sqrt(m_CellList[i].rms));
301 }
302 m_tree->Fill();
303 ATH_MSG_INFO(" after tree fill ");
304
305 for (int i=0;i<m_nsymcell;i++) {
306 m_CellList[i].nevt=0;
307 m_CellList[i].offset=0.;
308 m_CellList[i].average=0;
309 m_CellList[i].rms=0;
310 }
311 ATH_MSG_INFO(" end of fillNtuple ");
312
313 }
double m_average[MAX_SYM_CELLS]
double m_rms[MAX_SYM_CELLS]
double m_offset[MAX_SYM_CELLS]
int m_region[MAX_SYM_CELLS]
double m_nevt[MAX_SYM_CELLS]
int m_layer[MAX_SYM_CELLS]
float m_eta[MAX_SYM_CELLS]
float m_phi[MAX_SYM_CELLS]
int m_ieta[MAX_SYM_CELLS]
int m_identifier[MAX_SYM_CELLS]

◆ initialize()

StatusCode LArMinBiasAlg::initialize ( )
overridevirtual

Definition at line 28 of file LArMinBiasAlg.cxx.

29 {
30
31 ATH_MSG_INFO ( " LArMinBiasAlg initialize() " );
32
33 ATH_CHECK( m_thistSvc.retrieve() );
34
35
36 m_tree = new TTree("m_tree","Offset ntuple");
37 m_tree->Branch("ncell",&m_nsymcell,"ncell/I");
38 m_tree->Branch("nevt_total",&m_nevt_total,"nevt_total/I");
39 m_tree->Branch("identifier",m_identifier,"identifier[ncell]/I");
40 m_tree->Branch("region",m_region,"region[ncell]/I");
41 m_tree->Branch("ieta",m_ieta,"ieta[ncell]/I");
42 m_tree->Branch("layer",m_layer,"layer[ncell]/I");
43 m_tree->Branch("region",m_region,"region[ncell]/I");
44 m_tree->Branch("ieta",m_ieta,"ieta[ncell]/I");
45 m_tree->Branch("eta",m_eta,"eta[ncell]/F");
46 m_tree->Branch("phi",m_phi,"phi[ncell]/F");
47 m_tree->Branch("nevt",m_nevt,"nevt[ncell]/D");
48 m_tree->Branch("average",m_average,"average[ncell]/D");
49 m_tree->Branch("rms",m_rms,"rms[ncell]/D");
50 m_tree->Branch("reference",m_offset,"offset[ncell]/D");
51
52 if( m_thistSvc->regTree("/file1/offset",m_tree).isFailure()) {
53 ATH_MSG_WARNING(" cannot register ntuple " );
54 return StatusCode::SUCCESS;
55 }
56
57 const CaloIdManager* mgr = nullptr;
58 ATH_CHECK( detStore()->retrieve( mgr ) );
59 if(m_isSC) {
60 m_calo_id = (const CaloCell_Base_ID*)mgr->getCaloCell_SuperCell_ID();
61 } else {
62 m_calo_id = (const CaloCell_Base_ID*)mgr->getCaloCell_ID();
63 }
64
65 ATH_CHECK(m_mcSymKey.initialize());
66
67 ATH_CHECK(m_cablingKey.initialize());
68
69 ATH_CHECK(m_caloMgrKey.initialize());
70
71 ATH_CHECK(m_caloSCMgrKey.initialize(m_isSC));
72
73 ATH_CHECK(m_eventInfoKey.initialize());
74
75 ATH_CHECK(m_larHitKeys.assign(m_inputKeys.value()));
76 ATH_CHECK(m_larHitKeys.initialize(!m_inputKeys.empty() ));
77
78 if(m_isSC) ATH_CHECK( m_scidtool.retrieve() );
79
80 m_n1=0;
81 m_n2=0;
82
84
85 return StatusCode::SUCCESS;
86
87 }
const ServiceHandle< StoreGateSvc > & detStore() const
StringArrayProperty m_inputKeys
ServiceHandle< ITHistSvc > m_thistSvc

◆ inputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Algorithm > >::inputHandles ( ) const
overridevirtualinherited

Return this algorithm's input handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ msg()

MsgStream & AthCommonMsg< Algorithm >::msg ( ) const
inlineinherited

Definition at line 24 of file AthCommonMsg.h.

24 {
25 return this->msgStream();
26 }

◆ msgLvl()

bool AthCommonMsg< Algorithm >::msgLvl ( const MSG::Level lvl) const
inlineinherited

Definition at line 30 of file AthCommonMsg.h.

30 {
31 return this->msgLevel(lvl);
32 }

◆ outputHandles()

virtual std::vector< Gaudi::DataHandle * > AthCommonDataStore< AthCommonMsg< Algorithm > >::outputHandles ( ) const
overridevirtualinherited

Return this algorithm's output handles.

We override this to include handle instances from key arrays if they have not yet been declared. See comments on updateVHKA.

◆ renounce()

std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > AthCommonDataStore< AthCommonMsg< Algorithm > >::renounce ( T & h)
inlineprotectedinherited

Definition at line 380 of file AthCommonDataStore.h.

381 {
382 h.renounce();
384 }
std::enable_if_t< std::is_void_v< std::result_of_t< decltype(&T::renounce)(T)> > &&!std::is_base_of_v< SG::VarHandleKeyArray, T > &&std::is_base_of_v< Gaudi::DataHandle, T >, void > renounce(T &h)

◆ renounceArray()

void AthCommonDataStore< AthCommonMsg< Algorithm > >::renounceArray ( SG::VarHandleKeyArray & handlesArray)
inlineprotectedinherited

remove all handles from I/O resolution

Definition at line 364 of file AthCommonDataStore.h.

364 {
366 }

◆ stop()

StatusCode LArMinBiasAlg::stop ( )
overridevirtual

Definition at line 89 of file LArMinBiasAlg.cxx.

90 {
91 ATH_MSG_INFO("number of events in the two samples " << m_n1 << " " << m_n2);
92 this->fillNtuple();
93 ATH_MSG_INFO(" stop after fill ntuple");
94 return StatusCode::SUCCESS;
95 }

◆ sysInitialize()

StatusCode AthAlgorithm::sysInitialize ( )
overridevirtualinherited

Override sysInitialize.

Override sysInitialize from the base class.

Loop through all output handles, and if they're WriteCondHandles, automatically register them and this Algorithm with the CondSvc

Scan through all outputHandles, and if they're WriteCondHandles, register them with the CondSvc

Reimplemented from AthCommonDataStore< AthCommonMsg< Algorithm > >.

Reimplemented in AthAnalysisAlgorithm, AthFilterAlgorithm, AthHistogramAlgorithm, and PyAthena::Alg.

Definition at line 66 of file AthAlgorithm.cxx.

66 {
68
69 if (sc.isFailure()) {
70 return sc;
71 }
72 ServiceHandle<ICondSvc> cs("CondSvc",name());
73 for (auto h : outputHandles()) {
74 if (h->isCondition() && h->mode() == Gaudi::DataHandle::Writer) {
75 // do this inside the loop so we don't create the CondSvc until needed
76 if ( cs.retrieve().isFailure() ) {
77 ATH_MSG_WARNING("no CondSvc found: won't autoreg WriteCondHandles");
78 return StatusCode::SUCCESS;
79 }
80 if (cs->regHandle(this,*h).isFailure()) {
81 sc = StatusCode::FAILURE;
82 ATH_MSG_ERROR("unable to register WriteCondHandle " << h->fullKey()
83 << " with CondSvc");
84 }
85 }
86 }
87 return sc;
88}
static Double_t sc
virtual StatusCode sysInitialize() override
Override sysInitialize.
AthCommonDataStore(const std::string &name, T... args)
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override
::StatusCode StatusCode
StatusCode definition for legacy code.

◆ sysStart()

virtual StatusCode AthCommonDataStore< AthCommonMsg< Algorithm > >::sysStart ( )
overridevirtualinherited

Handle START transition.

We override this in order to make sure that conditions handle keys can cache a pointer to the conditions container.

◆ updateVHKA()

void AthCommonDataStore< AthCommonMsg< Algorithm > >::updateVHKA ( Gaudi::Details::PropertyBase & )
inlineinherited

Definition at line 308 of file AthCommonDataStore.h.

308 {
309 // debug() << "updateVHKA for property " << p.name() << " " << p.toString()
310 // << " size: " << m_vhka.size() << endmsg;
311 for (auto &a : m_vhka) {
313 for (auto k : keys) {
314 k->setOwner(this);
315 }
316 }
317 }
std::vector< SG::VarHandleKeyArray * > m_vhka

Member Data Documentation

◆ m_average

double LArMinBiasAlg::m_average[MAX_SYM_CELLS] {}
private

Definition at line 97 of file LArMinBiasAlg.h.

97{};

◆ m_cablingKey

SG::ReadCondHandleKey<LArOnOffIdMapping> LArMinBiasAlg::m_cablingKey {this,"CablingKey","LArOnOffIdMap","SG Key of LArOnOffIdMapping object"}
private

Definition at line 65 of file LArMinBiasAlg.h.

65{this,"CablingKey","LArOnOffIdMap","SG Key of LArOnOffIdMapping object"};

◆ m_calo_id

const CaloCell_Base_ID* LArMinBiasAlg::m_calo_id = nullptr
private

Definition at line 77 of file LArMinBiasAlg.h.

◆ m_caloMgrKey

SG::ReadCondHandleKey<CaloDetDescrManager> LArMinBiasAlg::m_caloMgrKey
private
Initial value:
{ this
, "CaloDetDescrManager"
, "CaloDetDescrManager"
, "SG Key for CaloDetDescrManager in the Condition Store" }

Definition at line 67 of file LArMinBiasAlg.h.

67 { this
68 , "CaloDetDescrManager"
69 , "CaloDetDescrManager"
70 , "SG Key for CaloDetDescrManager in the Condition Store" };

◆ m_caloSCMgrKey

SG::ReadCondHandleKey<CaloSuperCellDetDescrManager> LArMinBiasAlg::m_caloSCMgrKey
private
Initial value:
{ this
, "CaloSuperCellDetDescrManager"
, "CaloSuperCellDetDescrManager"
, "SG Key for CaloSuperCellDetDescrManager in the Condition Store" }

Definition at line 72 of file LArMinBiasAlg.h.

72 { this
73 , "CaloSuperCellDetDescrManager"
74 , "CaloSuperCellDetDescrManager"
75 , "SG Key for CaloSuperCellDetDescrManager in the Condition Store" };

◆ m_CellList

std::vector<CellInfo> LArMinBiasAlg::m_CellList
private

Definition at line 114 of file LArMinBiasAlg.h.

◆ m_datasetID_highPt

Gaudi::Property<int> LArMinBiasAlg::m_datasetID_highPt {this, "datasetID_highPt", 119996}
private

Definition at line 60 of file LArMinBiasAlg.h.

60{this, "datasetID_highPt", 119996};

◆ m_datasetID_lowPt

Gaudi::Property<int> LArMinBiasAlg::m_datasetID_lowPt {this, "datasetID_lowPt", 119995}
private

Definition at line 59 of file LArMinBiasAlg.h.

59{this, "datasetID_lowPt", 119995};

◆ m_detStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Algorithm > >::m_detStore
privateinherited

Pointer to StoreGate (detector store by default).

Definition at line 393 of file AthCommonDataStore.h.

◆ m_eCell

std::vector<double> LArMinBiasAlg::m_eCell
private

Definition at line 79 of file LArMinBiasAlg.h.

◆ m_eta

float LArMinBiasAlg::m_eta[MAX_SYM_CELLS] {}
private

Definition at line 95 of file LArMinBiasAlg.h.

95{};

◆ m_eventInfoKey

SG::ReadHandleKey<xAOD::EventInfo> LArMinBiasAlg::m_eventInfoKey {this,"EvtInfo", "EventInfo", "EventInfo name"}
private

Definition at line 118 of file LArMinBiasAlg.h.

118{this,"EvtInfo", "EventInfo", "EventInfo name"};

◆ m_evtStore

StoreGateSvc_t AthCommonDataStore< AthCommonMsg< Algorithm > >::m_evtStore
privateinherited

Pointer to StoreGate (event store by default).

Definition at line 390 of file AthCommonDataStore.h.

◆ m_extendedExtraObjects

DataObjIDColl AthAlgorithm::m_extendedExtraObjects
privateinherited

Definition at line 79 of file AthAlgorithm.h.

◆ m_first

float LArMinBiasAlg::m_first {true}
private

Definition at line 116 of file LArMinBiasAlg.h.

116{true};

◆ m_identifier

int LArMinBiasAlg::m_identifier[MAX_SYM_CELLS] {}
private

Definition at line 93 of file LArMinBiasAlg.h.

93{};

◆ m_ieta

int LArMinBiasAlg::m_ieta[MAX_SYM_CELLS] {}
private

Definition at line 94 of file LArMinBiasAlg.h.

94{};

◆ m_inputKeys

StringArrayProperty LArMinBiasAlg::m_inputKeys
private
Initial value:
{this, "InputHitContainers", {"LArHitEMB", "LArHitEMEC", "LArHitHEC", "LArHitFCAL"},
"Name of input hit vectors (default=[LArHitEMB, LArHitEMEC, LArHitHEC, LArHitFCAL])" }

Definition at line 119 of file LArMinBiasAlg.h.

119 {this, "InputHitContainers", {"LArHitEMB", "LArHitEMEC", "LArHitHEC", "LArHitFCAL"},
120 "Name of input hit vectors (default=[LArHitEMB, LArHitEMEC, LArHitHEC, LArHitFCAL])" };

◆ m_isSC

BooleanProperty LArMinBiasAlg::m_isSC {this, "SuperCell", false, "Creating for SC ?"}
private

Definition at line 122 of file LArMinBiasAlg.h.

122{this, "SuperCell", false, "Creating for SC ?"};

◆ m_larHitKeys

SG::ReadHandleKeyArray<LArHitContainer> LArMinBiasAlg::m_larHitKeys
private

Definition at line 121 of file LArMinBiasAlg.h.

◆ m_layer

int LArMinBiasAlg::m_layer[MAX_SYM_CELLS] {}
private

Definition at line 91 of file LArMinBiasAlg.h.

91{};

◆ m_mcSymKey

SG::ReadCondHandleKey<LArMCSym> LArMinBiasAlg::m_mcSymKey { this, "MCSymKey", "LArMCSym", "SG Key of LArMCSym object" }
private

Definition at line 63 of file LArMinBiasAlg.h.

64{ this, "MCSymKey", "LArMCSym", "SG Key of LArMCSym object" };

◆ m_n1

int LArMinBiasAlg::m_n1 = 0
private

Definition at line 85 of file LArMinBiasAlg.h.

◆ m_n2

int LArMinBiasAlg::m_n2 = 0
private

Definition at line 86 of file LArMinBiasAlg.h.

◆ m_ncell

int LArMinBiasAlg::m_ncell = 0
private

Definition at line 117 of file LArMinBiasAlg.h.

◆ m_nevt

double LArMinBiasAlg::m_nevt[MAX_SYM_CELLS] {}
private

Definition at line 90 of file LArMinBiasAlg.h.

90{};

◆ m_nevt_total

int LArMinBiasAlg::m_nevt_total = 0
private

Definition at line 84 of file LArMinBiasAlg.h.

◆ m_nsymcell

int LArMinBiasAlg::m_nsymcell = 0
private

Definition at line 89 of file LArMinBiasAlg.h.

◆ m_offset

double LArMinBiasAlg::m_offset[MAX_SYM_CELLS] {}
private

Definition at line 99 of file LArMinBiasAlg.h.

99{};

◆ m_phi

float LArMinBiasAlg::m_phi[MAX_SYM_CELLS] {}
private

Definition at line 96 of file LArMinBiasAlg.h.

96{};

◆ m_region

int LArMinBiasAlg::m_region[MAX_SYM_CELLS] {}
private

Definition at line 92 of file LArMinBiasAlg.h.

92{};

◆ m_rms

double LArMinBiasAlg::m_rms[MAX_SYM_CELLS] {}
private

Definition at line 98 of file LArMinBiasAlg.h.

98{};

◆ m_scidtool

ToolHandle<ICaloSuperCellIDTool> LArMinBiasAlg::m_scidtool {this, "CaloSuperCellIDTool", "CaloSuperCellIDTool", "Offline / SuperCell ID mapping tool"}
private

Definition at line 123 of file LArMinBiasAlg.h.

123{this, "CaloSuperCellIDTool", "CaloSuperCellIDTool", "Offline / SuperCell ID mapping tool"};

◆ m_symCellIndex

std::vector<int> LArMinBiasAlg::m_symCellIndex
private

Definition at line 115 of file LArMinBiasAlg.h.

◆ m_thistSvc

ServiceHandle<ITHistSvc> LArMinBiasAlg::m_thistSvc {this,"THistSvc","THistSvc"}
private

Definition at line 82 of file LArMinBiasAlg.h.

82{this,"THistSvc","THistSvc"};

◆ m_tree

TTree* LArMinBiasAlg::m_tree = nullptr
private

Definition at line 83 of file LArMinBiasAlg.h.

◆ m_varHandleArraysDeclared

bool AthCommonDataStore< AthCommonMsg< Algorithm > >::m_varHandleArraysDeclared
privateinherited

Definition at line 399 of file AthCommonDataStore.h.

◆ m_vhka

std::vector<SG::VarHandleKeyArray*> AthCommonDataStore< AthCommonMsg< Algorithm > >::m_vhka
privateinherited

Definition at line 398 of file AthCommonDataStore.h.

◆ m_weight_highPt

Gaudi::Property<double> LArMinBiasAlg::m_weight_highPt {this, "weight_lowPt", 0.138128}
private

Definition at line 62 of file LArMinBiasAlg.h.

62{this, "weight_lowPt", 0.138128};

◆ m_weight_lowPt

Gaudi::Property<double> LArMinBiasAlg::m_weight_lowPt {this, "weight_highPt", 39.8606}
private

Definition at line 61 of file LArMinBiasAlg.h.

61{this, "weight_highPt", 39.8606};

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