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

#include <EvtInclusiveDecay.h>

Inheritance diagram for EvtInclusiveDecay:
Collaboration diagram for EvtInclusiveDecay:

Public Member Functions

 EvtInclusiveDecay (const std::string &name, ISvcLocator *pSvcLocator)
 
virtual ~EvtInclusiveDecay ()
 
StatusCode initialize ()
 
StatusCode execute ()
 
StatusCode finalize ()
 
std::string xmlpath (void)
 
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, V, H > &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
 

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

Private Attributes

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
 

Features for derived classes to use internally

ServiceHandle< IAthRNGSvcm_rndmSvc {this, "RndmSvc", "AthRNGSvc"}
 
IntegerProperty m_dsid {this, "Dsid", 999999}
 
IntegerProperty m_randomSeed {this, "RandomSeed", 1234567, "Random seed for the built-in random engine"}
 Seed for random number engine. More...
 
McEventCollectionm_mcEvtColl {}
 
EvtInclusiveAtRndmGenm_evtAtRndmGen {}
 
EvtGen * m_myEvtGen {}
 
std::string m_pdtFile
 
std::string m_decayFile
 
std::string m_userDecayFile
 
std::string m_randomStreamName
 
std::string m_inputKeyName
 
std::string m_outputKeyName
 
bool m_readExisting
 
bool m_prohibitFinalStateDecay
 
bool m_prohibitReDecay
 
bool m_prohibitUnDecay
 
bool m_prohibitRemoveSelfDecay
 
std::vector< int > m_blackList
 
std::set< int > m_blackListSet
 
bool m_allowAllKnownDecays
 
bool m_allowDefaultBDecays
 
std::vector< int > m_whiteList
 
std::set< int > m_whiteListSet
 
bool m_printHepMCBeforeEvtGen
 
bool m_printHepMCAfterEvtGen
 
bool m_printHepMCHighlighted
 
bool m_printHepMCHighLightTopLevelDecays
 
bool m_checkDecayTree
 
bool m_checkDecayChannels
 
std::map< int, long > m_noDecayChannels
 
int m_nRepeatedDecays
 
int m_maxNRepeatedDecays
 
bool m_applyUserSelection
 
bool m_userSelRequireOppositeSignedMu
 
double m_userSelMu1MinPt
 
double m_userSelMu2MinPt
 
double m_userSelMu1MaxEta
 
double m_userSelMu2MaxEta
 
double m_userSelMinDimuMass
 
double m_userSelMaxDimuMass
 
bool m_isfHerwig
 
bool m_setVMtransversePol
 
void reseedRandomEngine (const std::string &streamName, const EventContext &ctx)
 
CLHEP::HepRandomEngine * getRandomEngine (const std::string &streamName, unsigned long int randomSeedOffset, const EventContext &ctx) const
 
CLHEP::HepRandomEngine * getRandomEngineDuringInitialize (const std::string &streamName, unsigned long int randomSeedOffset, unsigned int conditionsRun=1, unsigned int lbn=1) const
 
StatusCode traverseDecayTree (HepMC::GenParticlePtr p, bool isToBeRemoved, std::set< HepMC::GenVertexPtr > &visited, std::set< int > &toBeDecayed)
 
void removeDecayTree (HepMC::GenEvent *hepMC, HepMC::GenParticlePtr p)
 
void decayParticle (HepMC::GenEvent *hepMC, HepMC::GenParticlePtr p)
 
void addEvtGenDecayTree (HepMC::GenEvent *hepMC, HepMC::GenParticlePtr part, EvtParticle *evtPart, EvtVector4R treeStart, double momentumScaleFactor=1.0)
 
bool isToBeDecayed (HepMC::ConstGenParticlePtr p, bool doCrossChecks)
 
bool isDefaultB (const int pId) const
 
bool passesUserSelection (HepMC::GenEvent *hepMC)
 
double invMass (HepMC::ConstGenParticlePtr p1, HepMC::ConstGenParticlePtr p2)
 
void printHepMC (HepMC::GenEvent *hepMC, std::set< int > *barcodeList=nullptr)
 
unsigned int printTree (HepMC::GenParticlePtr p, std::set< HepMC::GenVertexPtr > &visited, int level, std::set< int > *barcodeList=nullptr)
 
std::string pdgName (HepMC::ConstGenParticlePtr p, bool statusHighlighting=false, std::set< int > *barcodeList=nullptr)
 

Utility event-mangling functions

Todo:
Replace with HepMC units when available
ServiceHandle< IPartPropSvc > m_ppSvc {this, "PartPropSvc", "PartPropSvc"}
 Handle on the particle property service. More...
 
SG::ReadHandleKey< McEventCollectionm_mcevents_const { this, "McEventKey", "GEN_EVENT", "StoreGate key of the MC event collection" }
 Const handle to the MC event collection. More...
 
void GeVToMeV (HepMC::GenEvent *evt)
 Scale event energies/momenta by x 1000. More...
 
void MeVToGeV (HepMC::GenEvent *evt)
 Scale event energies/momenta by x 1/1000. More...
 
void cmTomm (HepMC::GenEvent *evt)
 Scale event lengths by x 10. More...
 
void mmTocm (HepMC::GenEvent *evt)
 Scale event lengths by x 1/10. More...
 

Detailed Description

Definition at line 55 of file EvtInclusiveDecay.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

◆ EvtInclusiveDecay()

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

Definition at line 56 of file EvtInclusiveDecay.cxx.

56  :
57  GenBase( name, pSvcLocator ),
59 
60  // Basic EvtGen configuration: decay and particle definition files, random number stream
61  declareProperty("pdtFile", m_pdtFile = "inclusive.pdt");
62  declareProperty("decayFile", m_decayFile = "2014inclusive.dec");
63  declareProperty("userDecayFile", m_userDecayFile = "");
64  declareProperty("randomStreamName", m_randomStreamName = "EVTGEN");
65  declareProperty("inputKeyName", m_inputKeyName = "GEN_EVENT");
66  declareProperty("outputKeyName",m_outputKeyName = "GEN_EVENT_EVTGEN");
67  declareProperty("readExisting",m_readExisting=false);
68 
69  // Selection of particles to be decayed
70  declareProperty("prohibitFinalStateDecay", m_prohibitFinalStateDecay=false);
71  declareProperty("prohibitReDecay", m_prohibitReDecay=false);
72  declareProperty("prohibitUnDecay", m_prohibitUnDecay=true);
73  declareProperty("prohibitRemoveSelfDecay", m_prohibitRemoveSelfDecay=false);
74  declareProperty("blackList",m_blackList);
75  declareProperty("allowAllKnownDecays", m_allowAllKnownDecays=true);
76  declareProperty("allowDefaultBDecays", m_allowDefaultBDecays=true);
77  declareProperty("whiteList",m_whiteList);
78 
79  // Level of output
80  declareProperty("printHepMCBeforeEvtGen", m_printHepMCBeforeEvtGen=false);
81  declareProperty("printHepMCAfterEvtGen", m_printHepMCAfterEvtGen=false);
82  declareProperty("printHepMCHighlighted", m_printHepMCHighlighted=true);
83  declareProperty("printHepMCHighLightTopLevelDecays", m_printHepMCHighLightTopLevelDecays=true);
84 
85  // Optional checks
86  declareProperty("checkDecayTree", m_checkDecayTree=false);
87  declareProperty("checkDecayChannels", m_checkDecayChannels=false);
88 
89  // Repeated decays
90  declareProperty("maxNRepeatedDecays", m_maxNRepeatedDecays=1);
91 
92  // User selection
93  declareProperty("applyUserSelection", m_applyUserSelection=false);
94  declareProperty("userSelRequireOppositeSignedMu", m_userSelRequireOppositeSignedMu=true);
95  declareProperty("userSelMu1MinPt", m_userSelMu1MinPt=0.);
96  declareProperty("userSelMu2MinPt", m_userSelMu2MinPt=0.);
97  declareProperty("userSelMu1MaxEta", m_userSelMu1MaxEta=102.5);
98  declareProperty("userSelMu2MaxEta", m_userSelMu2MaxEta=102.5);
99  declareProperty("userSelMinDimuMass", m_userSelMinDimuMass=0.);
100  declareProperty("userSelMaxDimuMass", m_userSelMaxDimuMass=-1.); // set to negative to not apply cut
101  declareProperty("isfHerwig", m_isfHerwig=false);
102  declareProperty("setVMtransversePol", m_setVMtransversePol=false);
103 
104  // We have decided to blacklist Tau decays because we are not sure whether the polarization
105  // would be properly passed to EvtGen
106  m_blackList.push_back(15);
107 }

◆ ~EvtInclusiveDecay()

EvtInclusiveDecay::~EvtInclusiveDecay ( )
virtual

Definition at line 111 of file EvtInclusiveDecay.cxx.

111  {
112  delete m_myEvtGen;
113  delete m_evtAtRndmGen;
114 }

Member Function Documentation

◆ addEvtGenDecayTree()

void EvtInclusiveDecay::addEvtGenDecayTree ( HepMC::GenEvent *  hepMC,
HepMC::GenParticlePtr  part,
EvtParticle *  evtPart,
EvtVector4R  treeStart,
double  momentumScaleFactor = 1.0 
)
private

Definition at line 520 of file EvtInclusiveDecay.cxx.

521  {
522  if(evtPart->getNDaug()!=0) {
523  // Add decay vertex, starting from production vertex of particle
524  double ct=(evtPart->getDaug(0)->get4Pos()).get(0)+treeStart.get(0);
525  double x=(evtPart->getDaug(0)->get4Pos()).get(1)+treeStart.get(1);
526  double y=(evtPart->getDaug(0)->get4Pos()).get(2)+treeStart.get(2);
527  double z=(evtPart->getDaug(0)->get4Pos()).get(3)+treeStart.get(3);
528 
529  HepMC::GenVertexPtr end_vtx = HepMC::newGenVertexPtr(HepMC::FourVector(x,y,z,ct));
530 
531  hepMC->add_vertex(end_vtx);
532  end_vtx->add_particle_in(std::move(part));
533 
534  // Add decay daughter with their own decay trees
535  for(uint it=0; it<evtPart->getNDaug(); it++) {
536  double e=(evtPart->getDaug(it)->getP4Lab()).get(0) * momentumScaleFactor;
537  double px=(evtPart->getDaug(it)->getP4Lab()).get(1) * momentumScaleFactor;
538  double py=(evtPart->getDaug(it)->getP4Lab()).get(2) * momentumScaleFactor;
539  double pz=(evtPart->getDaug(it)->getP4Lab()).get(3) * momentumScaleFactor;
540  int id=EvtPDL::getStdHep(evtPart->getDaug(it)->getId());
541  int status=1;
542  if(evtPart->getDaug(it)->getNDaug() != 0) status=2;
543  HepMC::GenParticlePtr daughter = HepMC::newGenParticlePtr(HepMC::FourVector(px,py,pz,e),id,status);
544  end_vtx->add_particle_out(daughter);
545  addEvtGenDecayTree(hepMC, std::move(daughter), evtPart->getDaug(it), treeStart, momentumScaleFactor);
546  }
547  }
548 }

◆ ATLAS_NOT_CONST_THREAD_SAFE() [1/2]

HepMC::GenEvent* event GenBase::ATLAS_NOT_CONST_THREAD_SAFE ( )
inlineinherited

Access the current signal event (first in the McEventCollection)

Note
This function will make a new McEventCollection if there is not already a valid one and MakeMcEvent=True.

Definition at line 76 of file GenBase.h.

76  {
77  if (events()->empty())
78  ATH_MSG_ERROR("McEventCollection is empty during first event access");
79  return *(events()->begin());
80  }

◆ ATLAS_NOT_CONST_THREAD_SAFE() [2/2]

McEventCollection* events GenBase::ATLAS_NOT_CONST_THREAD_SAFE ( )
inherited

Access the current event's McEventCollection.

Note
This function will make a new McEventCollection if there is not already a valid one and MakeMcEvent=True.

◆ cmTomm()

void GenBase::cmTomm ( HepMC::GenEvent *  evt)
protectedinherited

Scale event lengths by x 10.

Definition at line 78 of file GenBase.cxx.

78  {
79  for (HepMC::GenEvent::vertex_iterator vtx = evt->vertices_begin(); vtx != evt->vertices_end(); ++vtx) {
80  const HepMC::FourVector fv((*vtx)->position().x() * 10,
81  (*vtx)->position().y() * 10,
82  (*vtx)->position().z() * 10,
83  (*vtx)->position().t() * 10);
84  (*vtx)->set_position(fv);
85  }
86 }

◆ decayParticle()

void EvtInclusiveDecay::decayParticle ( HepMC::GenEvent *  hepMC,
HepMC::GenParticlePtr  p 
)
private

Definition at line 482 of file EvtInclusiveDecay.cxx.

482  {
483  ATH_MSG_DEBUG("Decaying particle " << pdgName(part) << " " << part);
484  if (msgLvl(MSG::VERBOSE)) HepMC::Print::line(std::cout,part);
485 
486  // Remove existing decay tree, if any, and flag particle as being decayed by EvtGen
487  removeDecayTree(hepMC,part);
488  part->set_status(0);
489 
490  // Create EvtGen version of part and have EvtGen decay it.
491  // Since EvtGen uses GeV, convert particles momentum from MeV to GeV.
492  int id = part->pdg_id();
493  EvtId evtId=EvtPDL::evtIdFromStdHep(id);
494  double en =(part->momentum()).e()/1000.;
495  double px=(part->momentum()).px()/1000.;
496  double py=(part->momentum()).py()/1000.;
497  double pz=(part->momentum()).pz()/1000.;
498  EvtVector4R evtP(en,px,py,pz);
499  EvtParticle* evtPart = EvtParticleFactory::particleFactory(evtId,evtP);
500 
501  // set transverse polarization to vector mesons (relevant for coherent production of J/Psi etc in UPC)
502  if(m_setVMtransversePol && (id==113 || id== 443 || id==100443 || id==553 || id==100553 || id==200553) )evtPart->setVectorSpinDensity();
503 
504  m_myEvtGen->generateDecay(evtPart);
505  if (msgLvl(MSG::VERBOSE)) evtPart->printTree();
506  double ct_s = part->production_vertex()->position().t();
507  double x_s = part->production_vertex()->position().x();
508  double y_s = part->production_vertex()->position().y();
509  double z_s = part->production_vertex()->position().z();
510 
511  EvtVector4R treeStart(ct_s,x_s,y_s,z_s);
512  // Add new decay tree to hepMC, converting back from GeV to MeV.
513  addEvtGenDecayTree(hepMC, part, evtPart, treeStart, 1000.);
514  if(evtPart->getNDaug() !=0) part->set_status(2);
515  evtPart->deleteTree();
516 }

◆ declareGaudiProperty() [1/4]

Gaudi::Details::PropertyBase& AthCommonDataStore< AthCommonMsg< Algorithm > >::declareGaudiProperty ( Gaudi::Property< T, V, H > &  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, V, H > &  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, V, H > &  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, V, H > &  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, V, H > &  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; }

◆ event_const()

const HepMC::GenEvent* GenBase::event_const ( ) const
inlineinherited

Access the current signal event (const)

Definition at line 83 of file GenBase.h.

83  {
84  if (events_const()->empty())
85  ATH_MSG_ERROR("Const McEventCollection is empty during first event access");
86  return *(events_const()->begin());
87  }

◆ events_const() [1/2]

const McEventCollection* GenBase::events_const ( ) const
inlineinherited

Access the current event's McEventCollection (const)

Definition at line 96 of file GenBase.h.

96  {
97  return events_const( getContext() );
98  }

◆ events_const() [2/2]

const McEventCollection* GenBase::events_const ( const EventContext &  ctx) const
inlineinherited

Definition at line 99 of file GenBase.h.

99  {
101  if (!ret.isValid())
102  ATH_MSG_ERROR("No McEventCollection found in StoreGate with key " << m_mcevents_const.key());
103  return ret.cptr();
104  }

◆ 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 EvtInclusiveDecay::execute ( )
virtual

Reimplemented from GenBase.

Definition at line 217 of file EvtInclusiveDecay.cxx.

217  {
218  ATH_MSG_DEBUG("EvtInclusiveDecay executing");
219 
220  const EventContext& ctx = Gaudi::Hive::currentContext();
222 
223  std::string key = m_inputKeyName;
224  // retrieve event from Transient Store (Storegate)
225 
226  // Load HepMC info
227  // FIXME should be using Read/WriteHandles here
228  const McEventCollection* oldmcEvtColl{};
229  if(m_readExisting) {
230  CHECK(evtStore()->retrieve(oldmcEvtColl, key));
231  // Fill the new McEventCollection with a copy of the initial HepMC::GenEvent
232  m_mcEvtColl = new McEventCollection(*oldmcEvtColl);
233  }
234  else {CHECK(evtStore()->retrieve(m_mcEvtColl, key));}
235 
236  if(m_readExisting) {
237  if(m_outputKeyName!=key) {
239  }
240  }
241 
243  for( mcItr = m_mcEvtColl->begin(); mcItr != m_mcEvtColl->end(); ++mcItr ) {
244  HepMC::GenEvent* hepMC = *mcItr;
245 
246  // Search HepMC record for particles to be decayed by EvtGen
247  // NOTE: In order to ensure repeatability, we use a std::set of barcodes to obtain
248  // an ordered list of particles to be decayed by EvtGen.
249  std::set<HepMC::GenVertexPtr> visited;
250 #ifdef HEPMC3
251  std::set<HepMC::GenParticlePtr,ParticleIdCompare> toBeDecayed;
252  for (auto p: hepMC->particles()) {
253  if ( (!p->production_vertex()) ||
254  (p->production_vertex()->particles_in().size() == 0) ) {
255  StatusCode sc = traverseDecayTree(std::move(p),false,visited,toBeDecayed);
256  if (sc.isFailure())
257  return StatusCode::FAILURE;
258  }
259  }
260 #else
261  std::set<int> toBeDecayed;
262  for (HepMC::GenEvent::particle_iterator itp = hepMC->particles_begin(); itp != hepMC->particles_end(); ++itp) {
264  if ( (!p->production_vertex()) ||
265  (p->production_vertex()->particles_in_size() == 0) ) {
266  StatusCode sc = traverseDecayTree(p,false,visited,toBeDecayed);
267  if (sc.isFailure())
268  return StatusCode::FAILURE;
269  }
270  }
271 #endif
272  // Print HepMC in tree format if desired (before doing anything)
274  msg(MSG::INFO) << "Printing HepMC record at " << hepMC << " BEFORE running EvtGen:" << endmsg;
276  printHepMC(hepMC,&toBeDecayed);
277  else
278  printHepMC(hepMC);
279  }
280 
281 
282  // Decay selected particles
283  bool eventPassesCuts(false);
284  int loopCounter(0);
285  while( !eventPassesCuts && loopCounter < m_maxNRepeatedDecays ) {
286 #ifdef HEPMC3
287  for (auto p: toBeDecayed) {
288  if (p==0) {
289  msg(MSG::ERROR ) << "Overlapping decay tree for particle" << p <<endmsg;
290  return StatusCode::FAILURE;
291  }
292  decayParticle(hepMC,std::move(p));
294  }
295 #else
296  for (std::set<int>::iterator itb = toBeDecayed.begin(); itb!=toBeDecayed.end(); ++itb) {
297  auto p = hepMC->barcode_to_particle(*itb);
298  if (p==0) {
299  msg(MSG::ERROR ) << "Overlapping decay tree encountered for barcode " << *itb << endmsg;
300  return StatusCode::FAILURE;
301  }
302  decayParticle(hepMC,p);
304  }
305 #endif
306 
308  eventPassesCuts = passesUserSelection(hepMC);
309  else
310  eventPassesCuts = true;
311 
313  loopCounter++;
314  }
315 
316  // Store the number of decay attempts in event weights std::map, only if repeated decays enabled
317 #ifdef HEPMC3
318  if(m_maxNRepeatedDecays > 1)
319  hepMC->weight("nEvtGenDecayAttempts") = loopCounter;
320 #else
321  if(m_maxNRepeatedDecays > 1)
322  hepMC->weights()["nEvtGenDecayAttempts"] = loopCounter;
323 #endif
324  // Print HepMC in tree format if desired (after finishing all EvtGen decays)
326  msg(MSG::INFO) << "Printing HepMC record at " << hepMC << " AFTER running EvtGen:" << endmsg;
328  printHepMC(hepMC,&toBeDecayed);
329  else
330  printHepMC(hepMC);
331  }
332  }
333 
335  CHECK(evtStore()->overwrite(m_mcEvtColl, m_outputKeyName));
336  }
337 
338  return StatusCode::SUCCESS;
339 }

◆ 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 EvtInclusiveDecay::finalize ( )

Definition at line 342 of file EvtInclusiveDecay.cxx.

342  {
343 
344  if (m_checkDecayChannels) {
345  ATH_MSG_INFO("The following particles were checked and didn't have any decay channels:");
346  if (msgLvl(MSG::INFO)) {
347  std::cout << std::endl;
348  std::cout << " Particle code Name from HepPDT # Occurences" << std::endl;
349  std::cout << "------------------------------------------------------" << std::endl;
351  int id = p->first;
352  int count = p->second;
353  std::cout << std::setw(14) << id
354  << std::setw(20) << HepPID::particleName(id)
355  << std::setw(20) << count
356  << std::endl;
357  }
358  std::cout << std::endl;
359  }
360  }
361  ATH_MSG_INFO("Total number of repeated decays: " << m_nRepeatedDecays);
362  ATH_MSG_INFO("EvtInclusiveDecay finalized");
363  return StatusCode::SUCCESS;
364 }

◆ getRandomEngine()

CLHEP::HepRandomEngine * EvtInclusiveDecay::getRandomEngine ( const std::string &  streamName,
unsigned long int  randomSeedOffset,
const EventContext &  ctx 
) const
private

Definition at line 191 of file EvtInclusiveDecay.cxx.

193 {
194  ATHRNG::RNGWrapper* rngWrapper = m_rndmSvc->getEngine(this, streamName);
195  rngWrapper->setSeed( streamName, ctx.slot(), randomSeedOffset, ctx.eventID().run_number() );
196  return rngWrapper->getEngine(ctx);
197 }

◆ getRandomEngineDuringInitialize()

CLHEP::HepRandomEngine * EvtInclusiveDecay::getRandomEngineDuringInitialize ( const std::string &  streamName,
unsigned long int  randomSeedOffset,
unsigned int  conditionsRun = 1,
unsigned int  lbn = 1 
) const
private

Definition at line 200 of file EvtInclusiveDecay.cxx.

201 {
202  const size_t slot=0;
203  EventContext ctx;
204  ctx.setSlot( slot );
205  ctx.setEventID (EventIDBase (conditionsRun,
206  EventIDBase::UNDEFEVT, // event
207  EventIDBase::UNDEFNUM, // timestamp
208  EventIDBase::UNDEFNUM, // timestamp ns
209  lbn));
211  Atlas::ExtendedEventContext( evtStore()->hiveProxyDict(),
212  conditionsRun) );
213  return getRandomEngine(streamName, randomSeedOffset, ctx);
214 }

◆ GeVToMeV()

void GenBase::GeVToMeV ( HepMC::GenEvent *  evt)
protectedinherited

Scale event energies/momenta by x 1000.

Todo:
Add HepMC units awareness and do it differently when HepMC provides this functionality directly (and reference-based FourVector accessors)

Definition at line 58 of file GenBase.cxx.

58  {
59  for (HepMC::GenEvent::particle_iterator p = evt->particles_begin(); p != evt->particles_end(); ++p) {
60  const HepMC::FourVector fv((*p)->momentum().px() * 1000,
61  (*p)->momentum().py() * 1000,
62  (*p)->momentum().pz() * 1000,
63  (*p)->momentum().e() * 1000);
64  (*p)->set_momentum(fv);
65  (*p)->set_generated_mass(1000 * (*p)->generated_mass());
66  }
67 }

◆ initialize()

StatusCode EvtInclusiveDecay::initialize ( )
virtual

Reimplemented from GenBase.

Definition at line 118 of file EvtInclusiveDecay.cxx.

118  {
119 
121  // Get the random number service
122  CHECK(m_rndmSvc.retrieve());
123 
124  msg(MSG::INFO) << "EvtInclusiveDecay initialize" << endmsg;
125  msg(MSG::INFO) << "Particle properties definition file = " << m_pdtFile << endmsg;
126  msg(MSG::INFO) << "Main decay file = " << m_decayFile << endmsg;
127  msg(MSG::INFO) << "User decay file = " << m_userDecayFile << endmsg;
128  msg(MSG::INFO) << "Max number of repeated decays = " << m_maxNRepeatedDecays << endmsg;
129  msg(MSG::INFO) << "EvtInclusiveDecay selection parameters:" << endmsg;
130  msg(MSG::INFO) << "* prohibitFinalStateDecay = " << m_prohibitFinalStateDecay << endmsg;
131  msg(MSG::INFO) << "* prohibitReDecay = " << m_prohibitReDecay << endmsg;
132  msg(MSG::INFO) << "* prohibitUnDecay = " << m_prohibitUnDecay << endmsg;
133  msg(MSG::INFO) << "* prohibitRemoveSelfDecay = " << m_prohibitRemoveSelfDecay << endmsg;
134  msg(MSG::INFO) << "* allowAllKnownDecays = " << m_allowAllKnownDecays << endmsg;
135  msg(MSG::INFO) << "* allowDefaultBDecays = " << m_allowDefaultBDecays << endmsg;
136  msg(MSG::INFO) << "User selection parameters:" << endmsg;
137  msg(MSG::INFO) << "* applyUserSelection = " << m_applyUserSelection << endmsg;
138  msg(MSG::INFO) << "* userSelRequireOppositeSignedMu = " << m_userSelRequireOppositeSignedMu << endmsg;
139  msg(MSG::INFO) << "* userSelMu1MinPt = " << m_userSelMu1MinPt << endmsg;
140  msg(MSG::INFO) << "* userSelMu2MinPt = " << m_userSelMu2MinPt << endmsg;
141  msg(MSG::INFO) << "* userSelMu1MaxEta = " << m_userSelMu1MaxEta << endmsg;
142  msg(MSG::INFO) << "* userSelMu2MaxEta = " << m_userSelMu2MaxEta << endmsg;
143  msg(MSG::INFO) << "* userSelMinDimuMass = " << m_userSelMinDimuMass << endmsg;
144  msg(MSG::INFO) << "* userSelMaxDimuMass = " << m_userSelMaxDimuMass << endmsg;
145 
146  // Initialize and print blackList
147  m_blackListSet.insert(m_blackList.begin(),m_blackList.end());
148  msg(MSG::INFO) << "* blackList; = ";
149  for (std::set<int>::iterator i = m_blackListSet.begin(); i!=m_blackListSet.end(); ++i)
150  msg(MSG::INFO) << (*i) << " ";
151  msg(MSG::INFO)<< endmsg;
152 
153  // Initialize and print whiteList
154  m_whiteListSet.insert(m_whiteList.begin(),m_whiteList.end());
155  msg(MSG::INFO) << "* whiteList = ";
156  for (std::set<int>::iterator i = m_whiteListSet.begin(); i!=m_whiteListSet.end(); ++i)
157  msg(MSG::INFO) << (*i) << " ";
158  msg(MSG::INFO) << endmsg;
159 
160  CLHEP::HepRandomEngine* rndmEngine = getRandomEngineDuringInitialize(m_randomStreamName, m_randomSeed, m_dsid);
161  // Obtain random number generator for EvtGen
162  m_evtAtRndmGen = new EvtInclusiveAtRndmGen(rndmEngine);
163 
164  // Create an instance of EvtGen and read particle properties and decay files
165  EvtExternalGenList genList(true,xmlpath(),"gamma");
166  EvtAbsRadCorr* radCorrEngine = genList.getPhotosModel();
167  std::list<EvtDecayBase*> extraModels = genList.getListOfModels();
168 
169  // Create the EvtGen generator object
170  // EvtGen myGenerator("decayFile.dec", "evt.pdl", randomEnginePointer,
171  // radCorrEngine, &extraModels);
172 
173 
174  m_myEvtGen = new EvtGen( m_decayFile.c_str(), m_pdtFile.c_str(), m_evtAtRndmGen, radCorrEngine, &extraModels);
175  if(!m_userDecayFile.empty())
176  m_myEvtGen->readUDecay(m_userDecayFile.c_str());
177 
178  return StatusCode::SUCCESS;
179 }

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

◆ invMass()

double EvtInclusiveDecay::invMass ( HepMC::ConstGenParticlePtr  p1,
HepMC::ConstGenParticlePtr  p2 
)
private

Definition at line 687 of file EvtInclusiveDecay.cxx.

687  {
688  double p1Px = p1->momentum().px();
689  double p1Py = p1->momentum().py();
690  double p1Pz = p1->momentum().pz();
691  double p1E = p1->momentum().e();
692  double p2Px = p2->momentum().px();
693  double p2Py = p2->momentum().py();
694  double p2Pz = p2->momentum().pz();
695  double p2E = p2->momentum().e();
696  double dimuE = p2E + p1E;
697  double dimuPx = p2Px + p1Px;
698  double dimuPy = p2Py + p1Py;
699  double dimuPz = p2Pz + p1Pz;
700  double invMass = std::sqrt(dimuE*dimuE - dimuPx*dimuPx - dimuPy*dimuPy - dimuPz*dimuPz);
701 
702  return invMass;
703 }

◆ isDefaultB()

bool EvtInclusiveDecay::isDefaultB ( const int  pId) const
private

Definition at line 635 of file EvtInclusiveDecay.cxx.

635  {
636  int id = std::abs(pId);
637  if ( id == 511 ||
638  id == 521 ||
639  id == 531 ||
640  id == 541 ||
641  id == 5122 ||
642  id == 5132 ||
643  id == 5232 ||
644  id == 5112 ||
645  id == 5212 ||
646  id == 5222 )
647  return true;
648  else
649  return false;
650 }

◆ isToBeDecayed()

bool EvtInclusiveDecay::isToBeDecayed ( HepMC::ConstGenParticlePtr  p,
bool  doCrossChecks 
)
private

Definition at line 558 of file EvtInclusiveDecay.cxx.

558  {
559  int id = p->pdg_id();
560  int nDaughters = 0;
561  auto v = p->end_vertex();
562  if (v) nDaughters = v->particles_out_size();
563 
564  // Ignore documentation lines
565  if (p->status() == 3) return false;
566  // And any particles that aren't stable or decayed
567  if(!m_isfHerwig && !MC::isPhysical(p)) return false;
568 
569  // Particularly for Herwig, try to ignore particles that really should
570  // be flagged as documentation lines
571  double m2 = p->momentum().m2();
572  if (m2 < -1.0E-3) {
573  ATH_MSG_DEBUG("Ignoring particle " << pdgName(std::move(p)) << " with m^2 = " << m2);
574  return false;
575  }
576 
577  // Check whether EvtGen has any decay channels defined for this particle
578  EvtId evtId = EvtPDL::evtIdFromStdHep(id);
579  // std::cout << "EVTID: " << evtId.getId() << " alias " << evtId.getAlias() << std::endl;
580  int nModes = 0;
581  if (evtId.getId()>=0)
582  // nModes = EvtDecayTable::getNMode(evtId.getAlias());
583  nModes = EvtDecayTable::getInstance()->getNMode(evtId.getAlias());
584  if (doCrossChecks) {
585  ATH_MSG_VERBOSE("Checking particle " << pdgName(p)
586  << " (status = " << p->status()
587  <<") -- " << nModes << " decay modes found");
588  if (m_checkDecayChannels && nModes==0) {
590  if (pos != m_noDecayChannels.end())
591  (pos->second)++;
592  else
593  m_noDecayChannels[id] = 1;
594  }
595  }
596 
597  // Check prohibit* settings
598  if (m_prohibitFinalStateDecay && MC::isStable(p)) return false;
599  if (m_prohibitReDecay && nDaughters>0) return false;
600  if (m_prohibitUnDecay && nModes==0) return false;
601  if (m_prohibitRemoveSelfDecay && nDaughters>0) {
602  // For now, check only children - this should be sufficient and checking all
603  // descendants would be very expensive.
604 #ifdef HEPMC3
605  for (auto itd: v->particles_out()) {
606  if (std::abs(itd->pdg_id()) == std::abs(id)) return false;
607  }
608 #else
609  for (HepMC::GenVertex::particle_iterator itd = v->particles_begin(HepMC::children);
610  itd != v->particles_end(HepMC::children);
611  ++itd) {
612  if (std::abs((*itd)->pdg_id()) == std::abs(id)) return false;
613  }
614 #endif
615  }
616 
617  // Check blackList
618  if (m_blackListSet.count(std::abs(id))>0) return false;
619 
620  // Check allow* settings
621  if (m_allowAllKnownDecays && nModes>0) return true;
622  if (m_allowDefaultBDecays && isDefaultB(id)) return true;
623 
624  // Check whiteList
625  if (m_whiteListSet.count(std::abs(id))>0) return true;
626 
627  return false; // Default is NOT to decay through EvtGen
628 }

◆ MeVToGeV()

void GenBase::MeVToGeV ( HepMC::GenEvent *  evt)
protectedinherited

Scale event energies/momenta by x 1/1000.

Definition at line 68 of file GenBase.cxx.

68  {
69  for (HepMC::GenEvent::particle_iterator p = evt->particles_begin(); p != evt->particles_end(); ++p) {
70  const HepMC::FourVector fv((*p)->momentum().px() / 1000,
71  (*p)->momentum().py() / 1000,
72  (*p)->momentum().pz() / 1000,
73  (*p)->momentum().e() / 1000);
74  (*p)->set_momentum(fv);
75  (*p)->set_generated_mass((*p)->generated_mass() / 1000);
76  }
77 }

◆ mmTocm()

void GenBase::mmTocm ( HepMC::GenEvent *  evt)
protectedinherited

Scale event lengths by x 1/10.

Definition at line 87 of file GenBase.cxx.

87  {
88  for (HepMC::GenEvent::vertex_iterator vtx = evt->vertices_begin(); vtx != evt->vertices_end(); ++vtx) {
89  const HepMC::FourVector fv((*vtx)->position().x() / 10,
90  (*vtx)->position().y() / 10,
91  (*vtx)->position().z() / 10,
92  (*vtx)->position().t() / 10);
93  (*vtx)->set_position(fv);
94  }
95 }

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

◆ particleData()

const HepPDT::ParticleData* GenBase::particleData ( int  pid) const
inlineinherited

Access an element in the particle data table.

Definition at line 126 of file GenBase.h.

126  {
127  return pdt().particle(HepPDT::ParticleID(std::abs(pid)));
128  }

◆ particleTable()

const HepPDT::ParticleDataTable& GenBase::particleTable ( ) const
inlineinherited

Get a particle data table.

Definition at line 118 of file GenBase.h.

118  {
119  return *(m_ppSvc->PDT());
120  }

◆ partPropSvc()

const ServiceHandle<IPartPropSvc> GenBase::partPropSvc ( ) const
inlineinherited

Access the particle property service.

Definition at line 113 of file GenBase.h.

113  {
114  return m_ppSvc;
115  }

◆ passesUserSelection()

bool EvtInclusiveDecay::passesUserSelection ( HepMC::GenEvent *  hepMC)
private

Definition at line 657 of file EvtInclusiveDecay.cxx.

657  {
658  bool passed(false);
659  std::vector<HepMC::GenParticlePtr> *muons = new std::vector<HepMC::GenParticlePtr>;
660 
661  for ( const auto& p: *hepMC) {
662  if( std::abs(p->pdg_id()) == 13 )
663  muons->push_back(p);
664  }
665 
666  for (auto muItr1 = muons->begin(); muItr1 != muons->end(); ++muItr1) {
667  for (auto muItr2 = muItr1+1; muItr2 != muons->end(); ++muItr2) {
668  if( m_userSelRequireOppositeSignedMu && (*muItr1)->pdg_id() * (*muItr2)->pdg_id() > 0)
669  continue;
670  if( !( (*muItr1)->momentum().perp() > m_userSelMu1MinPt && std::abs((*muItr1)->momentum().pseudoRapidity()) < m_userSelMu1MaxEta &&
671  (*muItr2)->momentum().perp() > m_userSelMu2MinPt && std::abs((*muItr2)->momentum().pseudoRapidity()) < m_userSelMu2MaxEta ) &&
672  !( (*muItr2)->momentum().perp() > m_userSelMu1MinPt && std::abs((*muItr2)->momentum().pseudoRapidity()) < m_userSelMu1MaxEta &&
673  (*muItr1)->momentum().perp() > m_userSelMu2MinPt && std::abs((*muItr1)->momentum().pseudoRapidity()) < m_userSelMu2MaxEta ) )
674  continue;
675  double dimuMass = invMass((*muItr1),(*muItr2));
676  if( !( dimuMass > m_userSelMinDimuMass && (dimuMass < m_userSelMaxDimuMass || m_userSelMaxDimuMass < 0.) ) )
677  continue;
678  passed = true;
679  }
680  }
681 
682  delete muons;
683 
684  return passed;
685 }

◆ pdgName()

std::string EvtInclusiveDecay::pdgName ( HepMC::ConstGenParticlePtr  p,
bool  statusHighlighting = false,
std::set< int > *  barcodeList = nullptr 
)
private

Definition at line 835 of file EvtInclusiveDecay.cxx.

835  {
836  std::ostringstream buf;
837  if (statusHighlighting) {
838  if ( ((barcodeList!=0) && (barcodeList->find(HepMC::barcode(p)) != barcodeList->end())) ||
839  ((barcodeList==0) && isToBeDecayed(p,false)) )
840  buf << "\033[7m"; // reverse
841  if (!MC::isStable(p)) {
842  if (MC::isDecayed(p))
843  buf << "\033[33m"; // yellow
844  else
845  buf << "\033[31m"; // red
846  }
847  }
848  buf << p->pdg_id();
849  buf << "/" << HepPID::particleName(p->pdg_id());
850  if (statusHighlighting) {
851  buf << "\033[0m"; // revert color attributes
852  }
853  return buf.str();
854 }

◆ pdt()

const HepPDT::ParticleDataTable& GenBase::pdt ( ) const
inlineinherited

Shorter alias to get a particle data table.

Definition at line 123 of file GenBase.h.

123 { return particleTable(); }

◆ printHepMC()

void EvtInclusiveDecay::printHepMC ( HepMC::GenEvent *  hepMC,
std::set< int > *  barcodeList = nullptr 
)
private

Definition at line 729 of file EvtInclusiveDecay.cxx.

729  {
730  std::set<HepMC::GenVertexPtr> visited;
731  unsigned int nParticlesFound = 0;
732  unsigned int nTreesFound = 0;
733  for (HepMC::GenEvent::particle_iterator itp = hepMC->particles_begin(); itp != hepMC->particles_end(); ++itp) {
735  if ( (!p->production_vertex()) ||
736  (p->production_vertex()->particles_in_size() == 0) ) {
737  nTreesFound++;
738  std::cout << "\n Found new partial decay tree:\n" << std::endl;
739  unsigned int nParticlesVisited = printTree(p,visited,1,barcodeList);
740  std::cout << "\n " << nParticlesVisited << " particles in this subtree" << std::endl;
741  nParticlesFound += nParticlesVisited;
742  }
743  }
744  std::cout << "\n Total of " << nParticlesFound << " particles found in "
745  << nTreesFound << " decay subtrees in HepMC event record\n" << std::endl;
746 }

◆ printTree()

unsigned int EvtInclusiveDecay::printTree ( HepMC::GenParticlePtr  p,
std::set< HepMC::GenVertexPtr > &  visited,
int  level,
std::set< int > *  barcodeList = nullptr 
)
private

Definition at line 778 of file EvtInclusiveDecay.cxx.

778  {
779  unsigned int nParticlesVisited = 1;
780  for (int i=0; i<level; i++) std::cout << " ";
781  std::cout << pdgName(p,m_printHepMCHighlighted,barcodeList);
782  auto v = p->end_vertex();
783  if (v) {
784  if (v->particles_in_size() > 1)
785  std::cout << " [interaction: " << v->particles_in_size() << " particles, vertex " << v << "] --> ";
786  else
787  std::cout << " --> ";
788  if (visited.insert(v).second) {
789  for (HepMC::GenVertex::particle_iterator itp = v->particles_begin(HepMC::children);
790  itp != v->particles_end(HepMC::children);
791  ++itp) {
792  std::cout << pdgName(*itp,m_printHepMCHighlighted,barcodeList) << " ";
793  }
794  std::cout << std::endl;
795  for (HepMC::GenVertex::particle_iterator itp = v->particles_begin(HepMC::children);
796  itp != v->particles_end(HepMC::children);
797  ++itp) {
798  if ((*itp)->end_vertex())
799  nParticlesVisited += printTree(*itp, visited, level+1, barcodeList);
800  else
801  nParticlesVisited++;
802  }
803  } else
804  std:: cout << "see above" << std::endl;
805  } else
806  std::cout << " no decay vertex\n" << std::endl;
807  return nParticlesVisited;
808 }

◆ removeDecayTree()

void EvtInclusiveDecay::removeDecayTree ( HepMC::GenEvent *  hepMC,
HepMC::GenParticlePtr  p 
)
private

Definition at line 439 of file EvtInclusiveDecay.cxx.

439  {
440  auto v = p->end_vertex();
441  if (v) {
442 #ifdef HEPMC3
443  //This is recursive in HepMC3. But explicit deletion is allowed as well.
444  hepMC->remove_vertex(std::move(v));
445  p->set_status(1); // For now, flag particle as undecayed (stable)
446  ATH_MSG_DEBUG("Removed existing " << pdgName(p) << " " << p );
447 #else
448  std::set<int> vtxBarCodesToDelete;
449  vtxBarCodesToDelete.insert(v->barcode());
450  for (HepMC::GenVertex::vertex_iterator itv = v->vertices_begin(HepMC::descendants);
451  itv != v->vertices_end(HepMC::descendants);
452  ++itv)
453  vtxBarCodesToDelete.insert((*itv)->barcode());
454  for (std::set<int>::iterator itb = vtxBarCodesToDelete.begin(); itb != vtxBarCodesToDelete.end(); ++itb) {
455  auto vdel = hepMC->barcode_to_vertex(*itb);
456  hepMC->remove_vertex(vdel);
457  delete vdel;
458  }
459  p->set_status(1); // For now, flag particle as undecayed (stable)
460  ATH_MSG_DEBUG("Removed existing " << pdgName(p) << " (barcode " << p->barcode() << ")" << " decay tree with " << vtxBarCodesToDelete.size() << " vertices");
461 #endif
462  }
463 }

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

◆ reseedRandomEngine()

void EvtInclusiveDecay::reseedRandomEngine ( const std::string &  streamName,
const EventContext &  ctx 
)
private

Definition at line 182 of file EvtInclusiveDecay.cxx.

184 {
185  long seeds[7];
186  ATHRNG::calculateSeedsMC21(seeds, streamName, ctx.eventID().event_number(), m_dsid, m_randomSeed);
187  m_evtAtRndmGen->getEngine()->setSeeds(seeds, 0); // NOT THREAD-SAFE
188 }

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

◆ traverseDecayTree()

StatusCode EvtInclusiveDecay::traverseDecayTree ( HepMC::GenParticlePtr  p,
bool  isToBeRemoved,
std::set< HepMC::GenVertexPtr > &  visited,
std::set< int > &  toBeDecayed 
)
private

Definition at line 381 of file EvtInclusiveDecay.cxx.

384  {
385 #endif
386  ATH_MSG_VERBOSE("Inspecting: " << pdgName(p) << " " << p);
387  if (!isToBeRemoved) {
388  if (isToBeDecayed(p,true)) {
389 #ifdef HEPMC3
390  toBeDecayed.insert(p);
391 #else
392  toBeDecayed.insert(HepMC::barcode(p));
393 #endif
394  isToBeRemoved = true;
395  ATH_MSG_VERBOSE("Selected particle for decay: " << pdgName(p) << " " << p );
396 
397  // In principle we could stop the recursion here. However, to prevent
398  // pathological cases in certain decay trees (in particular from Herwig),
399  // we continue in order to mark all descendants of this particle
400  // as visited. Thus none of these descendants can be flagged for further
401  // decay, even if it has several mothers.
402  }
403  }
404  auto v = p->end_vertex();
405 #ifdef HEPMC3
406  if (v) {
407  if (visited.insert(v).second) {
408  if ( isToBeRemoved && (v->particles_in().size()>1) && m_checkDecayTree ) {
409  ATH_MSG_WARNING("Found particle to be decayed with vertex with >1 incoming mother particles in decay tree");
410  ATH_MSG_WARNING( ([&p, &v](){ std::stringstream ss; HepMC::Print::line(ss,p); HepMC::Print::line(ss,v); return ss.str();})());
411  }
412  for (auto itp: v->particles_out()) {
413  ATH_CHECK(traverseDecayTree(std::move(itp),isToBeRemoved,visited,toBeDecayed) );
414  }
415  }
416  }
417 #else
418  if (v) {
419  if (visited.insert(v).second) {
420  if ( isToBeRemoved && (v->particles_in_size()>1) && m_checkDecayTree ) {
421  // This is normal for Herwig but should not occur for Pythia
422  ATH_MSG_WARNING("Found particle to be decayed with vertex with >1 incoming mother particles in decay tree");
423  ATH_MSG_WARNING( ([&p, &v](){ std::stringstream ss; HepMC::Print::line(ss,p); HepMC::Print::line(ss,v); return ss.str();})());
424  }
425  for (auto itp = v->particles_begin(HepMC::children); itp != v->particles_end(HepMC::children); ++itp) {
426  ATH_CHECK(traverseDecayTree(*itp,isToBeRemoved,visited,toBeDecayed) );
427  }
428  }
429  }
430 #endif
431  return StatusCode::SUCCESS;
432 }

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

◆ xmlpath()

std::string EvtInclusiveDecay::xmlpath ( void  )

Definition at line 872 of file EvtInclusiveDecay.cxx.

872  {
873  return PathResolverFindCalibDirectory( "Pythia8/xmldoc" );
874 }

Member Data Documentation

◆ m_allowAllKnownDecays

bool EvtInclusiveDecay::m_allowAllKnownDecays
private

Definition at line 142 of file EvtInclusiveDecay.h.

◆ m_allowDefaultBDecays

bool EvtInclusiveDecay::m_allowDefaultBDecays
private

Definition at line 143 of file EvtInclusiveDecay.h.

◆ m_applyUserSelection

bool EvtInclusiveDecay::m_applyUserSelection
private

Definition at line 160 of file EvtInclusiveDecay.h.

◆ m_blackList

std::vector<int> EvtInclusiveDecay::m_blackList
private

Definition at line 139 of file EvtInclusiveDecay.h.

◆ m_blackListSet

std::set<int> EvtInclusiveDecay::m_blackListSet
private

Definition at line 140 of file EvtInclusiveDecay.h.

◆ m_checkDecayChannels

bool EvtInclusiveDecay::m_checkDecayChannels
private

Definition at line 153 of file EvtInclusiveDecay.h.

◆ m_checkDecayTree

bool EvtInclusiveDecay::m_checkDecayTree
private

Definition at line 152 of file EvtInclusiveDecay.h.

◆ m_decayFile

std::string EvtInclusiveDecay::m_decayFile
private

Definition at line 128 of file EvtInclusiveDecay.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_dsid

IntegerProperty EvtInclusiveDecay::m_dsid {this, "Dsid", 999999}
private

Definition at line 115 of file EvtInclusiveDecay.h.

◆ m_evtAtRndmGen

EvtInclusiveAtRndmGen* EvtInclusiveDecay::m_evtAtRndmGen {}
private

Definition at line 123 of file EvtInclusiveDecay.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_inputKeyName

std::string EvtInclusiveDecay::m_inputKeyName
private

Definition at line 131 of file EvtInclusiveDecay.h.

◆ m_isfHerwig

bool EvtInclusiveDecay::m_isfHerwig
private

Definition at line 168 of file EvtInclusiveDecay.h.

◆ m_maxNRepeatedDecays

int EvtInclusiveDecay::m_maxNRepeatedDecays
private

Definition at line 158 of file EvtInclusiveDecay.h.

◆ m_mcEventKey

std::string GenBase::m_mcEventKey {}
protectedinherited

StoreGate key for the MC event collection (defaults to GEN_EVENT)

Definition at line 137 of file GenBase.h.

◆ m_mcevents_const

SG::ReadHandleKey<McEventCollection> GenBase::m_mcevents_const { this, "McEventKey", "GEN_EVENT", "StoreGate key of the MC event collection" }
privateinherited

Const handle to the MC event collection.

Definition at line 163 of file GenBase.h.

◆ m_mcEvtColl

McEventCollection* EvtInclusiveDecay::m_mcEvtColl {}
private

Definition at line 120 of file EvtInclusiveDecay.h.

◆ m_mkMcEvent

BooleanProperty GenBase::m_mkMcEvent {this, "MakeMcEvent", false, "Create a new MC event collection if it doesn't exist"}
protectedinherited

Flag to determine if a new MC event collection should be made if it doesn't exist.

Definition at line 139 of file GenBase.h.

◆ m_myEvtGen

EvtGen* EvtInclusiveDecay::m_myEvtGen {}
private

Definition at line 124 of file EvtInclusiveDecay.h.

◆ m_noDecayChannels

std::map<int,long> EvtInclusiveDecay::m_noDecayChannels
private

Definition at line 154 of file EvtInclusiveDecay.h.

◆ m_nRepeatedDecays

int EvtInclusiveDecay::m_nRepeatedDecays
private

Definition at line 156 of file EvtInclusiveDecay.h.

◆ m_outputKeyName

std::string EvtInclusiveDecay::m_outputKeyName
private

Definition at line 132 of file EvtInclusiveDecay.h.

◆ m_pdtFile

std::string EvtInclusiveDecay::m_pdtFile
private

Definition at line 127 of file EvtInclusiveDecay.h.

◆ m_ppSvc

ServiceHandle<IPartPropSvc> GenBase::m_ppSvc {this, "PartPropSvc", "PartPropSvc"}
privateinherited

Handle on the particle property service.

Definition at line 160 of file GenBase.h.

◆ m_printHepMCAfterEvtGen

bool EvtInclusiveDecay::m_printHepMCAfterEvtGen
private

Definition at line 148 of file EvtInclusiveDecay.h.

◆ m_printHepMCBeforeEvtGen

bool EvtInclusiveDecay::m_printHepMCBeforeEvtGen
private

Definition at line 147 of file EvtInclusiveDecay.h.

◆ m_printHepMCHighlighted

bool EvtInclusiveDecay::m_printHepMCHighlighted
private

Definition at line 149 of file EvtInclusiveDecay.h.

◆ m_printHepMCHighLightTopLevelDecays

bool EvtInclusiveDecay::m_printHepMCHighLightTopLevelDecays
private

Definition at line 150 of file EvtInclusiveDecay.h.

◆ m_prohibitFinalStateDecay

bool EvtInclusiveDecay::m_prohibitFinalStateDecay
private

Definition at line 135 of file EvtInclusiveDecay.h.

◆ m_prohibitReDecay

bool EvtInclusiveDecay::m_prohibitReDecay
private

Definition at line 136 of file EvtInclusiveDecay.h.

◆ m_prohibitRemoveSelfDecay

bool EvtInclusiveDecay::m_prohibitRemoveSelfDecay
private

Definition at line 138 of file EvtInclusiveDecay.h.

◆ m_prohibitUnDecay

bool EvtInclusiveDecay::m_prohibitUnDecay
private

Definition at line 137 of file EvtInclusiveDecay.h.

◆ m_randomSeed

IntegerProperty EvtInclusiveDecay::m_randomSeed {this, "RandomSeed", 1234567, "Random seed for the built-in random engine"}
private

Seed for random number engine.

Definition at line 118 of file EvtInclusiveDecay.h.

◆ m_randomStreamName

std::string EvtInclusiveDecay::m_randomStreamName
private

Definition at line 130 of file EvtInclusiveDecay.h.

◆ m_readExisting

bool EvtInclusiveDecay::m_readExisting
private

Definition at line 134 of file EvtInclusiveDecay.h.

◆ m_rndmSvc

ServiceHandle<IAthRNGSvc> EvtInclusiveDecay::m_rndmSvc {this, "RndmSvc", "AthRNGSvc"}
private

Definition at line 112 of file EvtInclusiveDecay.h.

◆ m_setVMtransversePol

bool EvtInclusiveDecay::m_setVMtransversePol
private

Definition at line 169 of file EvtInclusiveDecay.h.

◆ m_userDecayFile

std::string EvtInclusiveDecay::m_userDecayFile
private

Definition at line 129 of file EvtInclusiveDecay.h.

◆ m_userSelMaxDimuMass

double EvtInclusiveDecay::m_userSelMaxDimuMass
private

Definition at line 167 of file EvtInclusiveDecay.h.

◆ m_userSelMinDimuMass

double EvtInclusiveDecay::m_userSelMinDimuMass
private

Definition at line 166 of file EvtInclusiveDecay.h.

◆ m_userSelMu1MaxEta

double EvtInclusiveDecay::m_userSelMu1MaxEta
private

Definition at line 164 of file EvtInclusiveDecay.h.

◆ m_userSelMu1MinPt

double EvtInclusiveDecay::m_userSelMu1MinPt
private

Definition at line 162 of file EvtInclusiveDecay.h.

◆ m_userSelMu2MaxEta

double EvtInclusiveDecay::m_userSelMu2MaxEta
private

Definition at line 165 of file EvtInclusiveDecay.h.

◆ m_userSelMu2MinPt

double EvtInclusiveDecay::m_userSelMu2MinPt
private

Definition at line 163 of file EvtInclusiveDecay.h.

◆ m_userSelRequireOppositeSignedMu

bool EvtInclusiveDecay::m_userSelRequireOppositeSignedMu
private

Definition at line 161 of file EvtInclusiveDecay.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_whiteList

std::vector<int> EvtInclusiveDecay::m_whiteList
private

Definition at line 144 of file EvtInclusiveDecay.h.

◆ m_whiteListSet

std::set<int> EvtInclusiveDecay::m_whiteListSet
private

Definition at line 145 of file EvtInclusiveDecay.h.


The documentation for this class was generated from the following files:
HepMC::GenVertexPtr
HepMC::GenVertex * GenVertexPtr
Definition: GenVertex.h:59
EvtInclusiveDecay::m_checkDecayTree
bool m_checkDecayTree
Definition: EvtInclusiveDecay.h:152
python.PyKernel.retrieve
def retrieve(aClass, aKey=None)
Definition: PyKernel.py:110
LArG4FSStartPointFilter.part
part
Definition: LArG4FSStartPointFilter.py:21
xAOD::iterator
JetConstituentVector::iterator iterator
Definition: JetConstituentVector.cxx:68
AllowedVariables::e
e
Definition: AsgElectronSelectorTool.cxx:37
EvtInclusiveDecay::isDefaultB
bool isDefaultB(const int pId) const
Definition: EvtInclusiveDecay.cxx:635
ATHRNG::RNGWrapper::setSeed
void setSeed(const std::string &algName, const EventContext &ctx)
Set the random seed using a string (e.g.
Definition: RNGWrapper.h:169
EvtInclusiveDecay::m_randomStreamName
std::string m_randomStreamName
Definition: EvtInclusiveDecay.h:130
EvtInclusiveDecay::m_allowDefaultBDecays
bool m_allowDefaultBDecays
Definition: EvtInclusiveDecay.h:143
EvtInclusiveDecay::m_maxNRepeatedDecays
int m_maxNRepeatedDecays
Definition: EvtInclusiveDecay.h:158
TruthTest.itp
itp
Definition: TruthTest.py:46
EvtInclusiveDecay::m_whiteList
std::vector< int > m_whiteList
Definition: EvtInclusiveDecay.h:144
test_pyathena.px
px
Definition: test_pyathena.py:18
PowhegControl_ttHplus_NLO.ss
ss
Definition: PowhegControl_ttHplus_NLO.py:83
EvtInclusiveDecay::m_allowAllKnownDecays
bool m_allowAllKnownDecays
Definition: EvtInclusiveDecay.h:142
TrigCompositeUtils::passed
bool passed(DecisionID id, const DecisionIDContainer &idSet)
checks if required decision ID is in the set of IDs in the container
Definition: TrigCompositeUtilsRoot.cxx:118
ATH_MSG_INFO
#define ATH_MSG_INFO(x)
Definition: AthMsgStreamMacros.h:31
SG::ReadHandle::cptr
const_pointer_type cptr()
Dereference the pointer.
EvtInclusiveDecay::m_blackList
std::vector< int > m_blackList
Definition: EvtInclusiveDecay.h:139
EvtInclusiveDecay::m_userSelMinDimuMass
double m_userSelMinDimuMass
Definition: EvtInclusiveDecay.h:166
EvtInclusiveDecay::m_noDecayChannels
std::map< int, long > m_noDecayChannels
Definition: EvtInclusiveDecay.h:154
GenBase::events_const
const McEventCollection * events_const() const
Access the current event's McEventCollection (const)
Definition: GenBase.h:96
SG::ReadHandle< McEventCollection >
EvtInclusiveDecay::m_blackListSet
std::set< int > m_blackListSet
Definition: EvtInclusiveDecay.h:140
EvtInclusiveDecay::reseedRandomEngine
void reseedRandomEngine(const std::string &streamName, const EventContext &ctx)
Definition: EvtInclusiveDecay.cxx:182
EvtInclusiveDecay::decayParticle
void decayParticle(HepMC::GenEvent *hepMC, HepMC::GenParticlePtr p)
Definition: EvtInclusiveDecay.cxx:482
HepMC::GenParticlePtr
GenParticle * GenParticlePtr
Definition: GenParticle.h:37
TRTCalib_cfilter.p1
p1
Definition: TRTCalib_cfilter.py:130
EvtInclusiveDecay::passesUserSelection
bool passesUserSelection(HepMC::GenEvent *hepMC)
Definition: EvtInclusiveDecay.cxx:657
McEventCollection
McEventCollection
Definition: GeneratorObjectsTPCnv.cxx:60
EvtInclusiveDecay::m_applyUserSelection
bool m_applyUserSelection
Definition: EvtInclusiveDecay.h:160
skel.it
it
Definition: skel.GENtoEVGEN.py:407
EvtInclusiveDecay::getRandomEngineDuringInitialize
CLHEP::HepRandomEngine * getRandomEngineDuringInitialize(const std::string &streamName, unsigned long int randomSeedOffset, unsigned int conditionsRun=1, unsigned int lbn=1) const
Definition: EvtInclusiveDecay.cxx:200
EvtInclusiveDecay::m_userDecayFile
std::string m_userDecayFile
Definition: EvtInclusiveDecay.h:129
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
EvtInclusiveDecay::isToBeDecayed
bool isToBeDecayed(HepMC::ConstGenParticlePtr p, bool doCrossChecks)
Definition: EvtInclusiveDecay.cxx:558
EvtInclusiveDecay::m_printHepMCHighLightTopLevelDecays
bool m_printHepMCHighLightTopLevelDecays
Definition: EvtInclusiveDecay.h:150
EvtInclusiveDecay::m_userSelMu2MaxEta
double m_userSelMu2MaxEta
Definition: EvtInclusiveDecay.h:165
AthCommonMsg< Algorithm >::msgLvl
bool msgLvl(const MSG::Level lvl) const
Definition: AthCommonMsg.h:30
EvtInclusiveDecay::m_decayFile
std::string m_decayFile
Definition: EvtInclusiveDecay.h:128
LArG4FSStartPointFilter.evt
evt
Definition: LArG4FSStartPointFilter.py:42
EvtInclusiveDecay::m_evtAtRndmGen
EvtInclusiveAtRndmGen * m_evtAtRndmGen
Definition: EvtInclusiveDecay.h:123
read_hist_ntuple.t
t
Definition: read_hist_ntuple.py:5
ATH_MSG_VERBOSE
#define ATH_MSG_VERBOSE(x)
Definition: AthMsgStreamMacros.h:28
SG::VarHandleKey::key
const std::string & key() const
Return the StoreGate ID for the referenced object.
Definition: AthToolSupport/AsgDataHandles/Root/VarHandleKey.cxx:141
HepMC::Print::line
void line(std::ostream &os, const GenEvent &e)
Definition: GenEvent.h:677
x
#define x
EvtInclusiveDecay::m_printHepMCHighlighted
bool m_printHepMCHighlighted
Definition: EvtInclusiveDecay.h:149
HepMC::fillBarcodesAttribute
void fillBarcodesAttribute(GenEvent *)
Definition: GenEvent.h:627
python.DataFormatRates.events
events
Definition: DataFormatRates.py:105
EvtInclusiveDecay::m_isfHerwig
bool m_isfHerwig
Definition: EvtInclusiveDecay.h:168
EvtInclusiveAtRndmGen::getEngine
CLHEP::HepRandomEngine * getEngine()
Definition: EvtInclusiveDecay.h:48
EvtInclusiveDecay::m_printHepMCAfterEvtGen
bool m_printHepMCAfterEvtGen
Definition: EvtInclusiveDecay.h:148
EvtInclusiveDecay::addEvtGenDecayTree
void addEvtGenDecayTree(HepMC::GenEvent *hepMC, HepMC::GenParticlePtr part, EvtParticle *evtPart, EvtVector4R treeStart, double momentumScaleFactor=1.0)
Definition: EvtInclusiveDecay.cxx:520
XMLtoHeader.count
count
Definition: XMLtoHeader.py:84
EvtInclusiveDecay::m_readExisting
bool m_readExisting
Definition: EvtInclusiveDecay.h:134
AthenaPoolTestRead.sc
sc
Definition: AthenaPoolTestRead.py:27
python.iconfTool.models.loaders.level
level
Definition: loaders.py:20
SG::VarHandleKeyArray::setOwner
virtual void setOwner(IDataHandleHolder *o)=0
PathResolverFindCalibDirectory
std::string PathResolverFindCalibDirectory(const std::string &logical_file_name)
Definition: PathResolver.cxx:326
IDTPMcnv.htype
htype
Definition: IDTPMcnv.py:29
SG::makeHandle
SG::ReadCondHandle< T > makeHandle(const SG::ReadCondHandleKey< T > &key, const EventContext &ctx=Gaudi::Hive::currentContext())
Definition: ReadCondHandle.h:270
MC::isPhysical
bool isPhysical(const T &p)
Identify if the particle is physical, i.e. is stable or decayed.
Definition: HepMCHelpers.h:51
AthCommonDataStore::declareGaudiProperty
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T, V, H > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition: AthCommonDataStore.h:156
GenBase::m_ppSvc
ServiceHandle< IPartPropSvc > m_ppSvc
Handle on the particle property service.
Definition: GenBase.h:160
AthCommonDataStore< AthCommonMsg< Algorithm > >::evtStore
ServiceHandle< StoreGateSvc > & evtStore()
The standard StoreGateSvc (event store) Returns (kind of) a pointer to the StoreGateSvc.
Definition: AthCommonDataStore.h:85
uint
unsigned int uint
Definition: LArOFPhaseFill.cxx:20
TRTCalib_cfilter.p2
p2
Definition: TRTCalib_cfilter.py:131
python.utils.AtlRunQueryDQUtils.p
p
Definition: AtlRunQueryDQUtils.py:209
AthCommonDataStore
Definition: AthCommonDataStore.h:52
G4StepHelper::particleName
std::string particleName(const G4Step *theStep)
TODO.
Definition: StepHelper.cxx:24
AthAlgorithm::sysInitialize
virtual StatusCode sysInitialize() override
Override sysInitialize.
Definition: AthAlgorithm.cxx:66
ATH_MSG_ERROR
#define ATH_MSG_ERROR(x)
Definition: AthMsgStreamMacros.h:33
AthCommonDataStore< AthCommonMsg< Algorithm > >::outputHandles
virtual std::vector< Gaudi::DataHandle * > outputHandles() const override
Return this algorithm's output handles.
DataModel_detail::iterator
(Non-const) Iterator class for DataVector/DataList.
Definition: DVLIterator.h:184
HepMC::newGenVertexPtr
GenVertexPtr newGenVertexPtr(const HepMC::FourVector &pos=HepMC::FourVector(0.0, 0.0, 0.0, 0.0), const int i=0)
Definition: GenVertex.h:64
EvtInclusiveDecay::invMass
double invMass(HepMC::ConstGenParticlePtr p1, HepMC::ConstGenParticlePtr p2)
Definition: EvtInclusiveDecay.cxx:687
lumiFormat.i
int i
Definition: lumiFormat.py:85
EvtInclusiveDecay::getRandomEngine
CLHEP::HepRandomEngine * getRandomEngine(const std::string &streamName, unsigned long int randomSeedOffset, const EventContext &ctx) const
Definition: EvtInclusiveDecay.cxx:191
z
#define z
python.DecayParser.buf
buf
print ("=> [%s]"cmd)
Definition: DecayParser.py:26
EvtInclusiveDecay::m_pdtFile
std::string m_pdtFile
Definition: EvtInclusiveDecay.h:127
Atlas::ExtendedEventContext
Definition: ExtendedEventContext.h:23
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
ATH_MSG_DEBUG
#define ATH_MSG_DEBUG(x)
Definition: AthMsgStreamMacros.h:29
AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T, V, H > &t)
Definition: AthCommonDataStore.h:145
EvtInclusiveDecay::m_userSelMu1MinPt
double m_userSelMu1MinPt
Definition: EvtInclusiveDecay.h:162
GenBase::m_mcevents_const
SG::ReadHandleKey< McEventCollection > m_mcevents_const
Const handle to the MC event collection.
Definition: GenBase.h:163
HepMC::barcode
int barcode(const T *p)
Definition: Barcode.h:16
EvtInclusiveDecay::m_checkDecayChannels
bool m_checkDecayChannels
Definition: EvtInclusiveDecay.h:153
EvtInclusiveDecay::removeDecayTree
void removeDecayTree(HepMC::GenEvent *hepMC, HepMC::GenParticlePtr p)
Definition: EvtInclusiveDecay.cxx:439
ParticleGun_EoverP_Config.pid
pid
Definition: ParticleGun_EoverP_Config.py:62
Amg::pz
@ pz
Definition: GeoPrimitives.h:40
jobOptions.ParticleID
ParticleID
Definition: jobOptions.decayer.py:85
EvtInclusiveDecay::m_dsid
IntegerProperty m_dsid
Definition: EvtInclusiveDecay.h:115
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
EvtInclusiveDecay::m_userSelMu1MaxEta
double m_userSelMu1MaxEta
Definition: EvtInclusiveDecay.h:164
CHECK
#define CHECK(...)
Evaluate an expression and check for errors.
Definition: Control/AthenaKernel/AthenaKernel/errorcheck.h:422
EvtInclusiveDecay::traverseDecayTree
StatusCode traverseDecayTree(HepMC::GenParticlePtr p, bool isToBeRemoved, std::set< HepMC::GenVertexPtr > &visited, std::set< int > &toBeDecayed)
Definition: EvtInclusiveDecay.cxx:381
EvtInclusiveDecay::m_randomSeed
IntegerProperty m_randomSeed
Seed for random number engine.
Definition: EvtInclusiveDecay.h:118
AthCommonDataStore< AthCommonMsg< Algorithm > >::m_detStore
StoreGateSvc_t m_detStore
Pointer to StoreGate (detector store by default)
Definition: AthCommonDataStore.h:393
EvtInclusiveDecay::printHepMC
void printHepMC(HepMC::GenEvent *hepMC, std::set< int > *barcodeList=nullptr)
Definition: EvtInclusiveDecay.cxx:729
McEventCollection
This defines the McEventCollection, which is really just an ObjectVector of McEvent objects.
Definition: McEventCollection.h:32
SG::ReadHandle::isValid
virtual bool isValid() override final
Can the handle be successfully dereferenced?
calibdata.ct
ct
Definition: calibdata.py:417
EvtInclusiveDecay::m_userSelRequireOppositeSignedMu
bool m_userSelRequireOppositeSignedMu
Definition: EvtInclusiveDecay.h:161
SG::VarHandleKeyArray::renounce
virtual void renounce()=0
GenBase::particleTable
const HepPDT::ParticleDataTable & particleTable() const
Get a particle data table.
Definition: GenBase.h:118
SG::HandleClassifier::type
std::conditional< std::is_base_of< SG::VarHandleKeyArray, T >::value, VarHandleKeyArrayType, type2 >::type type
Definition: HandleClassifier.h:54
Amg::py
@ py
Definition: GeoPrimitives.h:39
WriteHiveWithMetaData.streamName
string streamName
Definition: WriteHiveWithMetaData.py:23
merge_scale_histograms.doc
string doc
Definition: merge_scale_histograms.py:9
id
SG::auxid_t id
Definition: Control/AthContainers/Root/debug.cxx:239
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:240
ATHRNG::RNGWrapper
A wrapper class for event-slot-local random engines.
Definition: RNGWrapper.h:56
VP1PartSpect::E
@ E
Definition: VP1PartSpectFlags.h:21
EvtInclusiveDecay::m_prohibitFinalStateDecay
bool m_prohibitFinalStateDecay
Definition: EvtInclusiveDecay.h:135
EvtInclusiveDecay::pdgName
std::string pdgName(HepMC::ConstGenParticlePtr p, bool statusHighlighting=false, std::set< int > *barcodeList=nullptr)
Definition: EvtInclusiveDecay.cxx:835
EvtInclusiveDecay::m_prohibitRemoveSelfDecay
bool m_prohibitRemoveSelfDecay
Definition: EvtInclusiveDecay.h:138
ReadBchFromCrest.en
en
Definition: ReadBchFromCrest.py:254
ATHRNG::RNGWrapper::getEngine
CLHEP::HepRandomEngine * getEngine(const EventContext &ctx) const
Retrieve the random engine corresponding to the provided EventContext.
Definition: RNGWrapper.h:134
python.LumiBlobConversion.pos
pos
Definition: LumiBlobConversion.py:16
EvtInclusiveDecay::m_rndmSvc
ServiceHandle< IAthRNGSvc > m_rndmSvc
Definition: EvtInclusiveDecay.h:112
EvtInclusiveDecay::printTree
unsigned int printTree(HepMC::GenParticlePtr p, std::set< HepMC::GenVertexPtr > &visited, int level, std::set< int > *barcodeList=nullptr)
Definition: EvtInclusiveDecay.cxx:778
DataVector::end
const_iterator end() const noexcept
Return a const_iterator pointing past the end of the collection.
EvtInclusiveDecay::m_mcEvtColl
McEventCollection * m_mcEvtColl
Definition: EvtInclusiveDecay.h:120
python.PyAthena.v
v
Definition: PyAthena.py:154
EvtInclusiveDecay::m_prohibitUnDecay
bool m_prohibitUnDecay
Definition: EvtInclusiveDecay.h:137
AthAlgorithm::m_extendedExtraObjects
DataObjIDColl m_extendedExtraObjects
Definition: AthAlgorithm.h:79
MC::isStable
bool isStable(const T &p)
Identify if the particle is stable, i.e. has not decayed.
Definition: HepMCHelpers.h:45
EvtInclusiveDecay::m_myEvtGen
EvtGen * m_myEvtGen
Definition: EvtInclusiveDecay.h:124
a
TList * a
Definition: liststreamerinfos.cxx:10
HepMC::newGenParticlePtr
GenParticlePtr newGenParticlePtr(const HepMC::FourVector &mom=HepMC::FourVector(0.0, 0.0, 0.0, 0.0), int pid=0, int status=0)
Definition: GenParticle.h:39
columnar::empty
bool empty() const noexcept
Definition: ObjectRange.h:167
y
#define y
h
EvtInclusiveDecay::m_nRepeatedDecays
int m_nRepeatedDecays
Definition: EvtInclusiveDecay.h:156
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
python.Constants.INFO
int INFO
Definition: Control/AthenaCommon/python/Constants.py:15
EvtInclusiveDecay::xmlpath
std::string xmlpath(void)
Definition: EvtInclusiveDecay.cxx:872
MC::isDecayed
bool isDecayed(const T &p)
Identify if the particle decayed.
Definition: HepMCHelpers.h:42
GenBase::pdt
const HepPDT::ParticleDataTable & pdt() const
Shorter alias to get a particle data table.
Definition: GenBase.h:123
AthCommonMsg< Algorithm >::msg
MsgStream & msg() const
Definition: AthCommonMsg.h:24
get
T * get(TKey *tobj)
get a TObject* from a TKey* (why can't a TObject be a TKey?)
Definition: hcg.cxx:130
SG::VarHandleBase::vhKey
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
Definition: StoreGate/src/VarHandleBase.cxx:629
python.DecayParser.children
children
Definition: DecayParser.py:31
ATHRNG::calculateSeedsMC21
void calculateSeedsMC21(long *seeds, const std::string &algName, uint64_t ev, uint64_t run, uint64_t offset=0)
Set the random seed using a string (e.g.
Definition: RNGWrapper.cxx:37
EvtInclusiveDecay::m_setVMtransversePol
bool m_setVMtransversePol
Definition: EvtInclusiveDecay.h:169
EvtInclusiveDecay::m_printHepMCBeforeEvtGen
bool m_printHepMCBeforeEvtGen
Definition: EvtInclusiveDecay.h:147
EvtInclusiveDecay::m_outputKeyName
std::string m_outputKeyName
Definition: EvtInclusiveDecay.h:132
GenBase::GenBase
GenBase(const std::string &name, ISvcLocator *pSvcLocator)
Constructor.
Definition: GenBase.cxx:11
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:801
merge.status
status
Definition: merge.py:16
EvtInclusiveDecay::m_userSelMaxDimuMass
double m_userSelMaxDimuMass
Definition: EvtInclusiveDecay.h:167
LHEF::Writer
Pythia8::Writer Writer
Definition: Prophecy4fMerger.cxx:12
python.Constants.VERBOSE
int VERBOSE
Definition: Control/AthenaCommon/python/Constants.py:13
EvtInclusiveDecay::m_inputKeyName
std::string m_inputKeyName
Definition: EvtInclusiveDecay.h:131
EvtInclusiveDecay::m_userSelMu2MinPt
double m_userSelMu2MinPt
Definition: EvtInclusiveDecay.h:163
EvtInclusiveDecay::m_prohibitReDecay
bool m_prohibitReDecay
Definition: EvtInclusiveDecay.h:136
python.SystemOfUnits.m2
float m2
Definition: SystemOfUnits.py:107
Atlas::setExtendedEventContext
void setExtendedEventContext(EventContext &ctx, ExtendedEventContext &&ectx)
Move an extended context into a context object.
Definition: ExtendedEventContext.cxx:70
GenBase::initialize
virtual StatusCode initialize() override
Definition: GenBase.cxx:17
EvtInclusiveDecay::m_whiteListSet
std::set< int > m_whiteListSet
Definition: EvtInclusiveDecay.h:145
EvtInclusiveAtRndmGen
Definition: EvtInclusiveDecay.h:43
DataVector::begin
const_iterator begin() const noexcept
Return a const_iterator pointing at the beginning of the collection.
fitman.k
k
Definition: fitman.py:528
GenParticle
@ GenParticle
Definition: TruthClasses.h:30
ServiceHandle< ICondSvc >
mapkey::key
key
Definition: TElectronEfficiencyCorrectionTool.cxx:37