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

#include <CheckFlow.h>

Inheritance diagram for CheckFlow:
Collaboration diagram for CheckFlow:

Public Member Functions

 CheckFlow (const std::string &name, ISvcLocator *pSvcLocator)
 
StatusCode initialize ()
 
StatusCode execute ()
 
StatusCode finalize ()
 
virtual StatusCode sysInitialize () override
 Override sysInitialize. More...
 
virtual const DataObjIDColl & extraOutputDeps () const override
 Return the list of extra output dependencies. More...
 
ServiceHandle< StoreGateSvc > & evtStore ()
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & evtStore () const
 The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc. More...
 
const ServiceHandle< StoreGateSvc > & detStore () const
 The standard StoreGateSvc/DetectorStore Returns (kind of) a pointer to the StoreGateSvc. More...
 
virtual StatusCode sysStart () override
 Handle START transition. More...
 
virtual std::vector< Gaudi::DataHandle * > inputHandles () const override
 Return this algorithm's input handles. More...
 
virtual std::vector< Gaudi::DataHandle * > outputHandles () const override
 Return this algorithm's output handles. More...
 
Gaudi::Details::PropertyBase & declareProperty (Gaudi::Property< T > &t)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKey &hndl, const std::string &doc, const SG::VarHandleKeyType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleBase &hndl, const std::string &doc, const SG::VarHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, SG::VarHandleKeyArray &hndArr, const std::string &doc, const SG::VarHandleKeyArrayType &)
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc, const SG::NotHandleType &)
 Declare a new Gaudi property. More...
 
Gaudi::Details::PropertyBase * declareProperty (const std::string &name, T &property, const std::string &doc="none")
 Declare a new Gaudi property. More...
 
void updateVHKA (Gaudi::Details::PropertyBase &)
 
MsgStream & msg () const
 
MsgStream & msg (const MSG::Level lvl) const
 
bool msgLvl (const MSG::Level lvl) const
 

Public Attributes

 InputCollections
 
 job = AlgSequence()
 
 EvtMax
 
 OutputLevel
 
 Output
 
 CheckFlow = job.CheckFlow
 
 McEventKey
 
 RapidityCutMax
 

Protected Member Functions

void renounceArray (SG::VarHandleKeyArray &handlesArray)
 remove all handles from I/O resolution More...
 
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. More...
 

Private Types

typedef ServiceHandle< StoreGateSvcStoreGateSvc_t
 

Private Member Functions

Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
 specialization for handling Gaudi::Property<SG::VarHandleKey> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleKeyArrayType &)
 specialization for handling Gaudi::Property<SG::VarHandleKeyArray> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &hndl, const SG::VarHandleType &)
 specialization for handling Gaudi::Property<SG::VarHandleBase> More...
 
Gaudi::Details::PropertyBase & declareGaudiProperty (Gaudi::Property< T > &t, const SG::NotHandleType &)
 specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray> More...
 

Private Attributes

std::string m_key
 
bool m_produceHistogram
 
double m_bcut_min
 
double m_bcut_max
 
double m_ptcut_min
 
double m_ptcut_max
 
double m_rapcut_min
 
double m_rapcut_max
 
TH1Fm_hgenerated
 
TH1Fm_b
 
TH1Fm_phi
 
TH1Fm_phiR
 
TH1Fm_phi_vs_phiR
 
TH2Fm_phiv1reco_vs_phiR
 
TH2Fm_phiv2reco_vs_phiR
 
TH1Fm_phi_vs_phiR_etap
 
TH1Fm_phi_vs_phiR_etan
 
TH3Fm_v2betapth
 
TH3Fm_ebetapth
 
StoreGateSvcm_sgSvc
 
TruthHelper::GenAccessIOm_tesIO
 
DataObjIDColl m_extendedExtraObjects
 
StoreGateSvc_t m_evtStore
 Pointer to StoreGate (event store by default) More...
 
StoreGateSvc_t m_detStore
 Pointer to StoreGate (detector store by default) More...
 
std::vector< SG::VarHandleKeyArray * > m_vhka
 
bool m_varHandleArraysDeclared
 

Detailed Description

Definition at line 29 of file CheckFlow.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

◆ CheckFlow()

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

Member Function Documentation

◆ declareGaudiProperty() [1/4]

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

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

Definition at line 170 of file AthCommonDataStore.h.

172  {
173  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
174  hndl.value(),
175  hndl.documentation());
176 
177  }

◆ declareGaudiProperty() [2/4]

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

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

Definition at line 156 of file AthCommonDataStore.h.

158  {
159  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
160  hndl.value(),
161  hndl.documentation());
162 
163  }

◆ declareGaudiProperty() [3/4]

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

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

Definition at line 184 of file AthCommonDataStore.h.

186  {
187  return *AthCommonDataStore<PBASE>::declareProperty(hndl.name(),
188  hndl.value(),
189  hndl.documentation());
190  }

◆ declareGaudiProperty() [4/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< Algorithm > >::declareGaudiProperty ( Gaudi::Property< T > &  t,
const SG::NotHandleType  
)
inlineprivateinherited

specialization for handling everything that's not a Gaudi::Property<SG::VarHandleKey> or a <SG::VarHandleKeyArray>

Definition at line 199 of file AthCommonDataStore.h.

200  {
201  return PBASE::declareProperty(t);
202  }

◆ declareProperty() [1/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty ( const std::string &  name,
SG::VarHandleBase hndl,
const std::string &  doc,
const SG::VarHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleBase. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 245 of file AthCommonDataStore.h.

249  {
250  this->declare(hndl.vhKey());
251  hndl.vhKey().setOwner(this);
252 
253  return PBASE::declareProperty(name,hndl,doc);
254  }

◆ declareProperty() [2/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty ( const std::string &  name,
SG::VarHandleKey hndl,
const std::string &  doc,
const SG::VarHandleKeyType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
hndlObject holding the property value.
docDocumentation string for the property.

This is the version for types that derive from SG::VarHandleKey. The property value object is put on the input and output lists as appropriate; then we forward to the base class.

Definition at line 221 of file AthCommonDataStore.h.

225  {
226  this->declare(hndl);
227  hndl.setOwner(this);
228 
229  return PBASE::declareProperty(name,hndl,doc);
230  }

◆ declareProperty() [3/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty ( const std::string &  name,
SG::VarHandleKeyArray hndArr,
const std::string &  doc,
const SG::VarHandleKeyArrayType  
)
inlineinherited

Definition at line 259 of file AthCommonDataStore.h.

263  {
264 
265  // std::ostringstream ost;
266  // ost << Algorithm::name() << " VHKA declareProp: " << name
267  // << " size: " << hndArr.keys().size()
268  // << " mode: " << hndArr.mode()
269  // << " vhka size: " << m_vhka.size()
270  // << "\n";
271  // debug() << ost.str() << endmsg;
272 
273  hndArr.setOwner(this);
274  m_vhka.push_back(&hndArr);
275 
276  Gaudi::Details::PropertyBase* p = PBASE::declareProperty(name, hndArr, doc);
277  if (p != 0) {
278  p->declareUpdateHandler(&AthCommonDataStore<PBASE>::updateVHKA, this);
279  } else {
280  ATH_MSG_ERROR("unable to call declareProperty on VarHandleKeyArray "
281  << name);
282  }
283 
284  return p;
285 
286  }

◆ declareProperty() [4/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc,
const SG::NotHandleType  
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This is the generic version, for types that do not derive from SG::VarHandleKey. It just forwards to the base class version of declareProperty.

Definition at line 333 of file AthCommonDataStore.h.

337  {
338  return PBASE::declareProperty(name, property, doc);
339  }

◆ declareProperty() [5/6]

Gaudi::Details::PropertyBase* AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty ( const std::string &  name,
T &  property,
const std::string &  doc = "none" 
)
inlineinherited

Declare a new Gaudi property.

Parameters
nameName of the property.
propertyObject holding the property value.
docDocumentation string for the property.

This dispatches to either the generic declareProperty or the one for VarHandle/Key/KeyArray.

Definition at line 352 of file AthCommonDataStore.h.

355  {
356  typedef typename SG::HandleClassifier<T>::type htype;
357  return declareProperty (name, property, doc, htype());
358  }

◆ declareProperty() [6/6]

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

Definition at line 145 of file AthCommonDataStore.h.

145  {
146  typedef typename SG::HandleClassifier<T>::type htype;
148  }

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

95 { return m_detStore; }

◆ evtStore() [1/2]

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.

85 { return m_evtStore; }

◆ evtStore() [2/2]

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

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

Definition at line 90 of file AthCommonDataStore.h.

90 { return m_evtStore; }

◆ execute()

StatusCode CheckFlow::execute ( )

Definition at line 158 of file CheckFlow.cxx.

158  {
159  msg(MSG::INFO) << ">>> CheckFlow from execute" << endmsg;
160 
161  //
162  // Event parameters
163  //
164 
165 
166 
167 //---------------------------------------------------------------------------------------------------
168  const HijingEventParams *hijing_pars;
169  //HijingEventParams *hijing_pars;
170 //---------------------------------------------------------------------------------------------------
171 
172 
173 
174 
175 
176 
177  if ( m_sgSvc->retrieve(hijing_pars, "Hijing_event_params").isFailure() ) {
178  msg(MSG::ERROR) << "Could not retrieve Hijing_event_params"
179  << endmsg;
180  return StatusCode::FAILURE;
181  }
182  float b = hijing_pars->get_b();
183  float phiR = hijing_pars->get_bphi();
184 
185 
186  // Check cut on impact parameter b
187  if(b<m_bcut_min || b>m_bcut_max)
188  return StatusCode::SUCCESS;
189 
190  m_b->Fill(b, 1.);
191  m_phiR->Fill(phiR, 1.);
192 
193  float ngenerated = 0;
194  double phiv1_recon, phiv1_recop;
195  double phiv1_reco = 0, phiv2_reco = 0;
196  double phi_reco_sin1phip = 0, phi_reco_cos1phip = 0;
197  double phi_reco_sin1phin = 0, phi_reco_cos1phin = 0;
198  double phi_reco_sin2phi = 0, phi_reco_cos2phi = 0;
199 
200  std::vector<HepMC::ConstGenParticlePtr> particles;
202  if (stat.isFailure()) {
203  msg(MSG::ERROR) << "Could not find " << m_key << endmsg;
204  return stat;
205  }
206 
207  for (auto pitr: particles) {
208  int pid = pitr->pdg_id();
209  int p_stat = pitr->status();
210  double pt = pitr->momentum().perp();
211  double rapid = pitr->momentum().pseudoRapidity();
212  double phi = pitr->momentum().phi();
213  msg(MSG::DEBUG)
214  << " PID = " << pid << " Status = " << p_stat
215  << " Eta = " << rapid << " Phi = " << phi
216  << " PhiR = " << phiR << endmsg;
217 
218  if( (std::abs(rapid) >= m_rapcut_min) && (std::abs(rapid) <= m_rapcut_max) &&
219  (std::abs(pt) >= m_ptcut_min) && (std::abs(pt) <= m_ptcut_max) ) {
220  ngenerated++;
221  m_phi->Fill(phi, 1.);
222  double phi_corr = phi - phiR;
223  // v2 vs b,eta,pt histograms
224  m_v2betapth->Fill(b,rapid,pt,cos(2*phi_corr));
225  m_ebetapth->Fill(b,rapid,pt,1);
226  // -----------------
227  // convert to (-pi,pi) range
228  int kpi = (int)(phi_corr/(2*M_PI));
229  phi_corr -= kpi * 2*M_PI;
230  if (phi_corr < -M_PI) phi_corr += 2*M_PI;
231  if (phi_corr > M_PI) phi_corr -= 2*M_PI;
232  // --------------------------------------
233  m_phi_vs_phiR->Fill(phi_corr, 1.);
234  if(rapid>=0) m_phi_vs_phiR_etap->Fill(phi_corr, 1.);
235  else m_phi_vs_phiR_etan->Fill(phi_corr, 1.);
236  // -------------------------------------------------
237  if( rapid >= 0 ) {
238  phi_reco_sin1phip += std::sin(1*phi);
239  phi_reco_cos1phip += std::cos(1*phi);
240  } else {
241  phi_reco_sin1phin += std::sin(1*phi);
242  phi_reco_cos1phin += std::cos(1*phi);
243  }
244  phi_reco_sin2phi += std::sin(2*phi);
245  phi_reco_cos2phi += std::cos(2*phi);
246  }
247  }
248  m_hgenerated->Fill(ngenerated, 1.);
249 
250  // calculate event plane position
251  phiv1_recop = std::atan2( phi_reco_sin1phip,phi_reco_cos1phip );
252  phiv1_recon = std::atan2( phi_reco_sin1phin,phi_reco_cos1phin ) + M_PI;
253  if( phiv1_recon > M_PI ) phiv1_recon -= 2*M_PI;
254  // averaged v1 plane position (in pos and neg eta ranges)
255  phiv1_reco = (phiv1_recop + phiv1_recon)/2;
256  phiv2_reco = 0.5 * std::atan2( phi_reco_sin2phi,phi_reco_cos2phi );
257  msg(MSG::INFO)
258  << " PhiR = " << phiR
259  << " PhiV1Reco = " << phiv1_reco
260  << " PhiV2Reco = " << phiv2_reco << endmsg;
261 
262  // convert phiR (0, 2*pi) to (-pi,pi) range
263  double phiR_v1corr = phiR;
264  if( phiR > M_PI ) phiR_v1corr = phiR_v1corr - 2*M_PI;
265  // convert phiR (0, 2*pi) to (-pi/2,pi/2) range
266  double phiR_v2corr = phiR;
267  if (phiR > M_PI/2) phiR_v2corr -= M_PI;
268  if (phiR > 3*M_PI/2) phiR_v2corr -= 2*M_PI;
269  m_phiv1reco_vs_phiR->Fill(phiR_v1corr, phiv1_reco);
270  m_phiv2reco_vs_phiR->Fill(phiR_v2corr, phiv2_reco);
271 
272  // End of execution for each event
273  return StatusCode::SUCCESS;
274 }

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

◆ finalize()

StatusCode CheckFlow::finalize ( )

Definition at line 276 of file CheckFlow.cxx.

276  {
277  msg(MSG::INFO) << ">>> CheckFlow from finalize" << endmsg;
278 
279  return StatusCode::SUCCESS;
280 }

◆ initialize()

StatusCode CheckFlow::initialize ( )

Definition at line 56 of file CheckFlow.cxx.

56  {
57  StatusCode result = StatusCode::SUCCESS;
58  msg(MSG::INFO) << ">>> CheckFlow from Initialize" << endmsg;
59 
60  StatusCode sc = service("StoreGateSvc", m_sgSvc);
61  if (sc.isFailure()) {
62  msg(MSG::ERROR) << "Could not find StoreGateSvc" << endmsg;
63  return sc;
64  }
65 
66  m_hgenerated = new TH1F("ngen","Generated",100,0,100000);
67  m_b = new TH1F("b","Impact parameter",35,0.,35.0);
68  m_phi = new TH1F("phi","Phi",100,-M_PI,M_PI);
69  m_phiR = new TH1F("phiR","PhiR",100,0,2*M_PI);
70  m_phi_vs_phiR = new TH1F("phi_vs_phiR","Phi - PhiR",100,-M_PI,M_PI);
71  m_phiv1reco_vs_phiR = new TH2F("phiv1reco_vs_phiR",
72  "PhiV1Reco vs PhiR", 30,-M_PI,M_PI,30,-M_PI,M_PI);
73  m_phiv2reco_vs_phiR = new TH2F("phiv2reco_vs_phiR",
74  "PhiV2Reco vs PhiR", 30,-M_PI/2,M_PI/2,30,-M_PI/2,M_PI/2);
75  m_phi_vs_phiR_etap = new TH1F("phi_vs_phiR_etap",
76  "Phi - PhiR positive eta",
77  100,-M_PI,M_PI);
78  m_phi_vs_phiR_etan = new TH1F("phi_vs_phiR_etan",
79  "Phi - PhiR negative eta",
80  100,-M_PI,M_PI);
81  m_v2betapth = new TH3F("v2betapth",
82  "V2 vs b, eta, pt",
83  20,0,20, 30,-7.5,7.5, 25,0,5000);
84  m_ebetapth = new TH3F("ebetapth",
85  "Tracks vs b, eta, pt",
86  20,0,20, 30,-7.5,7.5, 25,0,5000);
87 
88  ITHistSvc *rootHistSvc;
89  if (!service("THistSvc", rootHistSvc, true).isSuccess()) {
90  msg(MSG::ERROR) << "Unable to locate THistSvc" << endmsg;
91  return StatusCode::FAILURE;
92  }
93 
94  std::string StreamAndPath="/FlowOutPut/";
95  std::string histPath = StreamAndPath;
96  if ( rootHistSvc->regHist(histPath+m_hgenerated->GetName(),
97  m_hgenerated).isFailure() )
98  msg(MSG::WARNING) << "Can't book "
99  << histPath+m_hgenerated->GetName() << endmsg;
100 
101  if ( rootHistSvc->regHist(histPath+m_b->GetName(),
102  m_b).isFailure() )
103  msg(MSG::WARNING) << "Can't book "
104  << histPath+m_b->GetName() << endmsg;
105 
106  if ( rootHistSvc->regHist(histPath+m_phi->GetName(),
107  m_phi).isFailure() )
108  msg(MSG::WARNING) << "Can't book "
109  << histPath+m_phi->GetName() << endmsg;
110 
111  if ( rootHistSvc->regHist(histPath+m_phiR->GetName(),
112  m_phiR).isFailure() )
113  msg(MSG::WARNING) << "Can't book "
114  << histPath+m_phiR->GetName() << endmsg;
115 
116  if ( rootHistSvc->regHist(histPath+m_phi_vs_phiR->GetName(),
117  m_phi_vs_phiR).isFailure() )
118  msg(MSG::WARNING) << "Can't book "
119  << histPath+m_phi_vs_phiR->GetName() << endmsg;
120 
121  if ( rootHistSvc->regHist(histPath+m_phiv1reco_vs_phiR->GetName(),
122  m_phiv1reco_vs_phiR).isFailure() )
123  msg(MSG::WARNING) << "Can't book "
124  << histPath+m_phiv1reco_vs_phiR->GetName() << endmsg;
125 
126  if ( rootHistSvc->regHist(histPath+m_phiv2reco_vs_phiR->GetName(),
127  m_phiv2reco_vs_phiR).isFailure() )
128  msg(MSG::WARNING) << "Can't book "
129  << histPath+m_phiv2reco_vs_phiR->GetName() << endmsg;
130 
131  if ( rootHistSvc->regHist(histPath+m_phi_vs_phiR_etap->GetName(),
132  m_phi_vs_phiR_etap).isFailure() )
133  msg(MSG::WARNING) << "Can't book "
134  << histPath+m_phi_vs_phiR_etap->GetName() << endmsg;
135 
136  if ( rootHistSvc->regHist(histPath+m_phi_vs_phiR_etan->GetName(),
137  m_phi_vs_phiR_etan).isFailure() )
138  msg(MSG::WARNING) << "Can't book "
139  << histPath+m_phi_vs_phiR_etan->GetName() << endmsg;
140 
141  if ( rootHistSvc->regHist(histPath+m_v2betapth->GetName(),
142  m_v2betapth).isFailure() )
143  msg(MSG::WARNING) << "Can't book "
144  << histPath+m_v2betapth->GetName() << endmsg;
145 
146  if ( rootHistSvc->regHist(histPath+m_ebetapth->GetName(),
147  m_ebetapth).isFailure() )
148  msg(MSG::WARNING) << "Can't book "
149  << histPath+m_ebetapth->GetName() << endmsg;
150 
151  msg(MSG::DEBUG) << "Histograms have been booked " << endmsg;
152 
154 
155  return result;
156 }

◆ 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() [1/2]

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

Definition at line 24 of file AthCommonMsg.h.

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

◆ msg() [2/2]

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

Definition at line 27 of file AthCommonMsg.h.

27  {
28  return this->msgStream(lvl);
29  }

◆ 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();
383  PBASE::renounce (h);
384  }

◆ 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  {
365  handlesArray.renounce();
366  }

◆ 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, PyAthena::Alg, and AthHistogramAlgorithm.

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 }

◆ 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) {
312  std::vector<SG::VarHandleKey*> keys = a->keys();
313  for (auto k : keys) {
314  k->setOwner(this);
315  }
316  }
317  }

Member Data Documentation

◆ CheckFlow

CheckFlow.CheckFlow = job.CheckFlow

Definition at line 50 of file CheckFlow.py.

◆ EvtMax

CheckFlow.EvtMax

Definition at line 34 of file CheckFlow.py.

◆ InputCollections

CheckFlow.InputCollections

Definition at line 13 of file CheckFlow.py.

◆ job

CheckFlow.job = AlgSequence()

Definition at line 26 of file CheckFlow.py.

◆ m_b

TH1F* CheckFlow::m_b
private

Definition at line 49 of file CheckFlow.h.

◆ m_bcut_max

double CheckFlow::m_bcut_max
private

Definition at line 41 of file CheckFlow.h.

◆ m_bcut_min

double CheckFlow::m_bcut_min
private

Definition at line 40 of file CheckFlow.h.

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

TH3F* CheckFlow::m_ebetapth
private

Definition at line 58 of file CheckFlow.h.

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

TH1F* CheckFlow::m_hgenerated
private

Definition at line 48 of file CheckFlow.h.

◆ m_key

std::string CheckFlow::m_key
private

Definition at line 37 of file CheckFlow.h.

◆ m_phi

TH1F* CheckFlow::m_phi
private

Definition at line 50 of file CheckFlow.h.

◆ m_phi_vs_phiR

TH1F* CheckFlow::m_phi_vs_phiR
private

Definition at line 52 of file CheckFlow.h.

◆ m_phi_vs_phiR_etan

TH1F* CheckFlow::m_phi_vs_phiR_etan
private

Definition at line 56 of file CheckFlow.h.

◆ m_phi_vs_phiR_etap

TH1F* CheckFlow::m_phi_vs_phiR_etap
private

Definition at line 55 of file CheckFlow.h.

◆ m_phiR

TH1F* CheckFlow::m_phiR
private

Definition at line 51 of file CheckFlow.h.

◆ m_phiv1reco_vs_phiR

TH2F* CheckFlow::m_phiv1reco_vs_phiR
private

Definition at line 53 of file CheckFlow.h.

◆ m_phiv2reco_vs_phiR

TH2F* CheckFlow::m_phiv2reco_vs_phiR
private

Definition at line 54 of file CheckFlow.h.

◆ m_produceHistogram

bool CheckFlow::m_produceHistogram
private

Definition at line 38 of file CheckFlow.h.

◆ m_ptcut_max

double CheckFlow::m_ptcut_max
private

Definition at line 43 of file CheckFlow.h.

◆ m_ptcut_min

double CheckFlow::m_ptcut_min
private

Definition at line 42 of file CheckFlow.h.

◆ m_rapcut_max

double CheckFlow::m_rapcut_max
private

Definition at line 45 of file CheckFlow.h.

◆ m_rapcut_min

double CheckFlow::m_rapcut_min
private

Definition at line 44 of file CheckFlow.h.

◆ m_sgSvc

StoreGateSvc* CheckFlow::m_sgSvc
private

Definition at line 60 of file CheckFlow.h.

◆ m_tesIO

TruthHelper::GenAccessIO* CheckFlow::m_tesIO
private

Definition at line 61 of file CheckFlow.h.

◆ m_v2betapth

TH3F* CheckFlow::m_v2betapth
private

Definition at line 57 of file CheckFlow.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.

◆ McEventKey

CheckFlow.McEventKey

Definition at line 51 of file CheckFlow.py.

◆ Output

CheckFlow.Output

Definition at line 43 of file CheckFlow.py.

◆ OutputLevel

CheckFlow.OutputLevel

Definition at line 35 of file CheckFlow.py.

◆ RapidityCutMax

CheckFlow.RapidityCutMax

Definition at line 52 of file CheckFlow.py.


The documentation for this class was generated from the following files:
get_generator_info.result
result
Definition: get_generator_info.py:21
python.PerfMonSerializer.p
def p
Definition: PerfMonSerializer.py:743
CheckFlow::m_phi
TH1F * m_phi
Definition: CheckFlow.h:50
phi
Scalar phi() const
phi method
Definition: AmgMatrixBasePlugin.h:64
CaloCellPos2Ntuple.int
int
Definition: CaloCellPos2Ntuple.py:24
AthCommonDataStore::declareProperty
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
Definition: AthCommonDataStore.h:145
CheckFlow::m_bcut_max
double m_bcut_max
Definition: CheckFlow.h:41
test_pyathena.pt
pt
Definition: test_pyathena.py:11
M_PI
#define M_PI
Definition: ActiveFraction.h:11
AthCommonDataStore< AthCommonMsg< Algorithm > >::m_evtStore
StoreGateSvc_t m_evtStore
Pointer to StoreGate (event store by default)
Definition: AthCommonDataStore.h:390
AthCommonDataStore< AthCommonMsg< Algorithm > >::m_vhka
std::vector< SG::VarHandleKeyArray * > m_vhka
Definition: AthCommonDataStore.h:398
CheckFlow::m_v2betapth
TH3F * m_v2betapth
Definition: CheckFlow.h:57
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
drawFromPickle.cos
cos
Definition: drawFromPickle.py:36
python.TrigEgammaMonitorHelper.TH2F
def TH2F(name, title, nxbins, bins_par2, bins_par3, bins_par4, bins_par5=None, bins_par6=None, path='', **kwargs)
Definition: TrigEgammaMonitorHelper.py:45
CheckFlow::m_phi_vs_phiR_etap
TH1F * m_phi_vs_phiR_etap
Definition: CheckFlow.h:55
CheckFlow::m_phiv1reco_vs_phiR
TH2F * m_phiv1reco_vs_phiR
Definition: CheckFlow.h:53
CheckFlow::m_ebetapth
TH3F * m_ebetapth
Definition: CheckFlow.h:58
AthenaPoolTestRead.sc
sc
Definition: AthenaPoolTestRead.py:27
SG::VarHandleKeyArray::setOwner
virtual void setOwner(IDataHandleHolder *o)=0
StoreGateSvc::retrieve
StatusCode retrieve(const T *&ptr) const
Retrieve the default object into a const T*.
CheckFlow::m_ptcut_max
double m_ptcut_max
Definition: CheckFlow.h:43
AthCommonDataStore
Definition: AthCommonDataStore.h:52
AthAlgorithm::sysInitialize
virtual StatusCode sysInitialize() override
Override sysInitialize.
Definition: AthAlgorithm.cxx:66
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
CheckFlow::m_rapcut_max
double m_rapcut_max
Definition: CheckFlow.h:45
AthCommonDataStore< AthCommonMsg< Algorithm > >::outputHandles
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override
Return this algorithm's output handles.
CheckFlow::m_rapcut_min
double m_rapcut_min
Definition: CheckFlow.h:44
CheckFlow::m_ptcut_min
double m_ptcut_min
Definition: CheckFlow.h:42
endmsg
#define endmsg
Definition: AnalysisConfig_Ntuple.cxx:63
EL::StatusCode
::StatusCode StatusCode
StatusCode definition for legacy code.
Definition: PhysicsAnalysis/D3PDTools/EventLoop/EventLoop/StatusCode.h:22
HijingEventParams
Definition: HijingEventParams.h:23
CheckFlow::m_phi_vs_phiR
TH1F * m_phi_vs_phiR
Definition: CheckFlow.h:52
ParticleGun_EoverP_Config.pid
pid
Definition: ParticleGun_EoverP_Config.py:62
CheckFlow::m_phiR
TH1F * m_phiR
Definition: CheckFlow.h:51
CheckFlow::m_hgenerated
TH1F * m_hgenerated
Definition: CheckFlow.h:48
TruthHelper::GenAccessIO::getMC
StatusCode getMC(MCParticleCollection &mcParticles, const bool ifgen=false, const std::string &key="GEN_EVENT") const
Definition: Generators/FlowAfterburner/FlowAfterburner/GenAccessIO.h:32
AthCommonDataStore< AthCommonMsg< Algorithm > >::m_detStore
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
Definition: AthCommonDataStore.h:393
CheckFlow::m_phi_vs_phiR_etan
TH1F * m_phi_vs_phiR_etan
Definition: CheckFlow.h:56
HijingEventParams::get_bphi
float get_bphi() const
Definition: HijingEventParams.h:92
beamspotman.stat
stat
Definition: beamspotman.py:266
SG::VarHandleKeyArray::renounce
virtual void renounce()=0
SG::HandleClassifier::type
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
Definition: HandleClassifier.h:54
merge_scale_histograms.doc
string doc
Definition: merge_scale_histograms.py:9
CheckFlow::m_tesIO
TruthHelper::GenAccessIO * m_tesIO
Definition: CheckFlow.h:61
CheckFlow::m_key
std::string m_key
Definition: CheckFlow.h:37
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:195
plotBeamSpotMon.b
b
Definition: plotBeamSpotMon.py:77
CheckFlow::m_phiv2reco_vs_phiR
TH2F * m_phiv2reco_vs_phiR
Definition: CheckFlow.h:54
TruthHelper::GenAccessIO
Definition: Generators/FlowAfterburner/FlowAfterburner/GenAccessIO.h:24
TH3F
Definition: rootspy.cxx:495
HijingEventParams::get_b
float get_b() const
Definition: HijingEventParams.h:91
AthAlgorithm::m_extendedExtraObjects
DataObjIDColl m_extendedExtraObjects
Definition: AthAlgorithm.h:79
a
TList * a
Definition: liststreamerinfos.cxx:10
h
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
CheckFlow::m_sgSvc
StoreGateSvc * m_sgSvc
Definition: CheckFlow.h:60
DEBUG
#define DEBUG
Definition: page_access.h:11
AthCommonMsg< Algorithm >::msg
MsgStream & msg() const
Definition: AthCommonMsg.h:24
LArG4FSStartPointFilter.particles
list particles
Definition: LArG4FSStartPointFilter.py:84
SG::VarHandleBase::vhKey
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
Definition: StoreGate/src/VarHandleBase.cxx:616
CheckFlow::m_b
TH1F * m_b
Definition: CheckFlow.h:49
declareProperty
#define declareProperty(n, p, h)
Definition: BaseFakeBkgTool.cxx:15
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:790
python.TrigEgammaMonitorHelper.TH1F
def TH1F(name, title, nxbins, bins_par2, bins_par3=None, path='', **kwargs)
Definition: TrigEgammaMonitorHelper.py:24
LHEF::Writer
Pythia8::Writer Writer
Definition: Prophecy4fMerger.cxx:12
drawFromPickle.sin
sin
Definition: drawFromPickle.py:36
AthCommonDataStore::declareGaudiProperty
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition: AthCommonDataStore.h:156
fitman.k
k
Definition: fitman.py:528
ServiceHandle< ICondSvc >