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 > &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 > &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

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=0)
 
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 56 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 528 of file EvtInclusiveDecay.cxx.

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

◆ 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 490 of file EvtInclusiveDecay.cxx.

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

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

◆ 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> toBeDecayed;
252  for (auto p: hepMC->particles()) {
253  if ( (!p->production_vertex()) ||
254  (p->production_vertex()->particles_in().size() == 0) ) {
255  StatusCode sc = traverseDecayTree(p,false,visited,toBeDecayed);
256  if (sc.isFailure())
257  return StatusCode::FAILURE;
258  }
259  }
260  // Print HepMC in tree format if desired (before doing anything)
262  msg(MSG::INFO) << "Printing HepMC record at " << hepMC << " BEFORE running EvtGen:" << endmsg;
264  printHepMC(hepMC,&toBeDecayed);
265  else
266  printHepMC(hepMC);
267  }
268 #else
269  std::set<int> toBeDecayed;
270  for (HepMC::GenEvent::particle_iterator itp = hepMC->particles_begin(); itp != hepMC->particles_end(); ++itp) {
272  if ( (!p->production_vertex()) ||
273  (p->production_vertex()->particles_in_size() == 0) ) {
274  StatusCode sc = traverseDecayTree(p,false,visited,toBeDecayed);
275  if (sc.isFailure())
276  return StatusCode::FAILURE;
277  }
278  }
279  // Print HepMC in tree format if desired (before doing anything)
281  msg(MSG::INFO) << "Printing HepMC record at " << hepMC << " BEFORE running EvtGen:" << endmsg;
283  printHepMC(hepMC,&toBeDecayed);
284  else
285  printHepMC(hepMC);
286  }
287 #endif
288 
289  // Decay selected particles
290  bool eventPassesCuts(false);
291  int loopCounter(0);
292  while( !eventPassesCuts && loopCounter < m_maxNRepeatedDecays ) {
293 #ifdef HEPMC3
294  for (auto p: toBeDecayed) {
295  if (p==0) {
296  msg(MSG::ERROR ) << "Overlapping decay tree for particle" << p <<endmsg;
297  return StatusCode::FAILURE;
298  }
299  decayParticle(hepMC,p);
301  }
302 #else
303  for (std::set<int>::iterator itb = toBeDecayed.begin(); itb!=toBeDecayed.end(); ++itb) {
304  auto p = hepMC->barcode_to_particle(*itb);
305  if (p==0) {
306  msg(MSG::ERROR ) << "Overlapping decay tree encountered for barcode " << *itb << endmsg;
307  return StatusCode::FAILURE;
308  }
309  decayParticle(hepMC,p);
311  }
312 #endif
313 
315  eventPassesCuts = passesUserSelection(hepMC);
316  else
317  eventPassesCuts = true;
318 
320  loopCounter++;
321  }
322 
323  // Store the number of decay attempts in event weights std::map, only if repeated decays enabled
324 #ifdef HEPMC3
325  if(m_maxNRepeatedDecays > 1)
326  hepMC->weight("nEvtGenDecayAttempts") = loopCounter;
327 #else
328  if(m_maxNRepeatedDecays > 1)
329  hepMC->weights()["nEvtGenDecayAttempts"] = loopCounter;
330 #endif
331  // Print HepMC in tree format if desired (after finishing all EvtGen decays)
333  msg(MSG::INFO) << "Printing HepMC record at " << hepMC << " AFTER running EvtGen:" << endmsg;
335  printHepMC(hepMC,&toBeDecayed);
336  else
337  printHepMC(hepMC);
338  }
339  }
340 
342  CHECK(evtStore()->overwrite(m_mcEvtColl, m_outputKeyName));
343  }
344 
345  return StatusCode::SUCCESS;
346 }

◆ 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 349 of file EvtInclusiveDecay.cxx.

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

◆ 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 695 of file EvtInclusiveDecay.cxx.

695  {
696  double p1Px = p1->momentum().px();
697  double p1Py = p1->momentum().py();
698  double p1Pz = p1->momentum().pz();
699  double p1E = p1->momentum().e();
700  double p2Px = p2->momentum().px();
701  double p2Py = p2->momentum().py();
702  double p2Pz = p2->momentum().pz();
703  double p2E = p2->momentum().e();
704  double dimuE = p2E + p1E;
705  double dimuPx = p2Px + p1Px;
706  double dimuPy = p2Py + p1Py;
707  double dimuPz = p2Pz + p1Pz;
708  double invMass = std::sqrt(dimuE*dimuE - dimuPx*dimuPx - dimuPy*dimuPy - dimuPz*dimuPz);
709 
710  return invMass;
711 }

◆ isDefaultB()

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

Definition at line 643 of file EvtInclusiveDecay.cxx.

643  {
644  int id = std::abs(pId);
645  if ( id == 511 ||
646  id == 521 ||
647  id == 531 ||
648  id == 541 ||
649  id == 5122 ||
650  id == 5132 ||
651  id == 5232 ||
652  id == 5112 ||
653  id == 5212 ||
654  id == 5222 )
655  return true;
656  else
657  return false;
658 }

◆ isToBeDecayed()

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

Definition at line 566 of file EvtInclusiveDecay.cxx.

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

◆ 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 665 of file EvtInclusiveDecay.cxx.

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

◆ pdgName()

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

Definition at line 845 of file EvtInclusiveDecay.cxx.

845  {
846  std::ostringstream buf;
847  if (statusHighlighting) {
848  if ( ((barcodeList!=0) && (barcodeList->find(HepMC::barcode(p)) != barcodeList->end())) ||
849  ((barcodeList==0) && isToBeDecayed(p,false)) )
850  buf << "\033[7m"; // reverse
851  if (!MC::isStable(p)) {
852  if (MC::isDecayed(p))
853  buf << "\033[33m"; // yellow
854  else
855  buf << "\033[31m"; // red
856  }
857  }
858  buf << p->pdg_id();
859  buf << "/" << HepPID::particleName(p->pdg_id());
860  if (statusHighlighting) {
861  buf << "\033[0m"; // revert color attributes
862  }
863  return buf.str();
864 }

◆ 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 737 of file EvtInclusiveDecay.cxx.

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

◆ printTree()

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

Definition at line 787 of file EvtInclusiveDecay.cxx.

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

◆ removeDecayTree()

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

Definition at line 446 of file EvtInclusiveDecay.cxx.

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

◆ 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 388 of file EvtInclusiveDecay.cxx.

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

◆ 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 882 of file EvtInclusiveDecay.cxx.

882  {
883  return PathResolverFindCalibDirectory( "Pythia8/xmldoc" );
884 }

Member Data Documentation

◆ m_allowAllKnownDecays

bool EvtInclusiveDecay::m_allowAllKnownDecays
private

Definition at line 141 of file EvtInclusiveDecay.h.

◆ m_allowDefaultBDecays

bool EvtInclusiveDecay::m_allowDefaultBDecays
private

Definition at line 142 of file EvtInclusiveDecay.h.

◆ m_applyUserSelection

bool EvtInclusiveDecay::m_applyUserSelection
private

Definition at line 159 of file EvtInclusiveDecay.h.

◆ m_blackList

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

Definition at line 138 of file EvtInclusiveDecay.h.

◆ m_blackListSet

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

Definition at line 139 of file EvtInclusiveDecay.h.

◆ m_checkDecayChannels

bool EvtInclusiveDecay::m_checkDecayChannels
private

Definition at line 152 of file EvtInclusiveDecay.h.

◆ m_checkDecayTree

bool EvtInclusiveDecay::m_checkDecayTree
private

Definition at line 151 of file EvtInclusiveDecay.h.

◆ m_decayFile

std::string EvtInclusiveDecay::m_decayFile
private

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

◆ m_evtAtRndmGen

EvtInclusiveAtRndmGen* EvtInclusiveDecay::m_evtAtRndmGen {}
private

Definition at line 122 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 130 of file EvtInclusiveDecay.h.

◆ m_isfHerwig

bool EvtInclusiveDecay::m_isfHerwig
private

Definition at line 167 of file EvtInclusiveDecay.h.

◆ m_maxNRepeatedDecays

int EvtInclusiveDecay::m_maxNRepeatedDecays
private

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

◆ m_noDecayChannels

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

Definition at line 153 of file EvtInclusiveDecay.h.

◆ m_nRepeatedDecays

int EvtInclusiveDecay::m_nRepeatedDecays
private

Definition at line 155 of file EvtInclusiveDecay.h.

◆ m_outputKeyName

std::string EvtInclusiveDecay::m_outputKeyName
private

Definition at line 131 of file EvtInclusiveDecay.h.

◆ m_pdtFile

std::string EvtInclusiveDecay::m_pdtFile
private

Definition at line 126 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 147 of file EvtInclusiveDecay.h.

◆ m_printHepMCBeforeEvtGen

bool EvtInclusiveDecay::m_printHepMCBeforeEvtGen
private

Definition at line 146 of file EvtInclusiveDecay.h.

◆ m_printHepMCHighlighted

bool EvtInclusiveDecay::m_printHepMCHighlighted
private

Definition at line 148 of file EvtInclusiveDecay.h.

◆ m_printHepMCHighLightTopLevelDecays

bool EvtInclusiveDecay::m_printHepMCHighLightTopLevelDecays
private

Definition at line 149 of file EvtInclusiveDecay.h.

◆ m_prohibitFinalStateDecay

bool EvtInclusiveDecay::m_prohibitFinalStateDecay
private

Definition at line 134 of file EvtInclusiveDecay.h.

◆ m_prohibitReDecay

bool EvtInclusiveDecay::m_prohibitReDecay
private

Definition at line 135 of file EvtInclusiveDecay.h.

◆ m_prohibitRemoveSelfDecay

bool EvtInclusiveDecay::m_prohibitRemoveSelfDecay
private

Definition at line 137 of file EvtInclusiveDecay.h.

◆ m_prohibitUnDecay

bool EvtInclusiveDecay::m_prohibitUnDecay
private

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

◆ m_randomStreamName

std::string EvtInclusiveDecay::m_randomStreamName
private

Definition at line 129 of file EvtInclusiveDecay.h.

◆ m_readExisting

bool EvtInclusiveDecay::m_readExisting
private

Definition at line 133 of file EvtInclusiveDecay.h.

◆ m_rndmSvc

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

Definition at line 111 of file EvtInclusiveDecay.h.

◆ m_setVMtransversePol

bool EvtInclusiveDecay::m_setVMtransversePol
private

Definition at line 168 of file EvtInclusiveDecay.h.

◆ m_userDecayFile

std::string EvtInclusiveDecay::m_userDecayFile
private

Definition at line 128 of file EvtInclusiveDecay.h.

◆ m_userSelMaxDimuMass

double EvtInclusiveDecay::m_userSelMaxDimuMass
private

Definition at line 166 of file EvtInclusiveDecay.h.

◆ m_userSelMinDimuMass

double EvtInclusiveDecay::m_userSelMinDimuMass
private

Definition at line 165 of file EvtInclusiveDecay.h.

◆ m_userSelMu1MaxEta

double EvtInclusiveDecay::m_userSelMu1MaxEta
private

Definition at line 163 of file EvtInclusiveDecay.h.

◆ m_userSelMu1MinPt

double EvtInclusiveDecay::m_userSelMu1MinPt
private

Definition at line 161 of file EvtInclusiveDecay.h.

◆ m_userSelMu2MaxEta

double EvtInclusiveDecay::m_userSelMu2MaxEta
private

Definition at line 164 of file EvtInclusiveDecay.h.

◆ m_userSelMu2MinPt

double EvtInclusiveDecay::m_userSelMu2MinPt
private

Definition at line 162 of file EvtInclusiveDecay.h.

◆ m_userSelRequireOppositeSignedMu

bool EvtInclusiveDecay::m_userSelRequireOppositeSignedMu
private

Definition at line 160 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 143 of file EvtInclusiveDecay.h.

◆ m_whiteListSet

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

Definition at line 144 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:151
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:643
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:129
EvtInclusiveDecay::m_allowDefaultBDecays
bool m_allowDefaultBDecays
Definition: EvtInclusiveDecay.h:142
EvtInclusiveDecay::m_maxNRepeatedDecays
int m_maxNRepeatedDecays
Definition: EvtInclusiveDecay.h:157
TruthTest.itp
itp
Definition: TruthTest.py:46
EvtInclusiveDecay::m_whiteList
std::vector< int > m_whiteList
Definition: EvtInclusiveDecay.h:143
test_pyathena.px
px
Definition: test_pyathena.py:18
python.SystemOfUnits.m2
int m2
Definition: SystemOfUnits.py:92
PowhegControl_ttHplus_NLO.ss
ss
Definition: PowhegControl_ttHplus_NLO.py:83
EvtInclusiveDecay::m_allowAllKnownDecays
bool m_allowAllKnownDecays
Definition: EvtInclusiveDecay.h:141
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:117
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:138
EvtInclusiveDecay::m_userSelMinDimuMass
double m_userSelMinDimuMass
Definition: EvtInclusiveDecay.h:165
EvtInclusiveDecay::m_noDecayChannels
std::map< int, long > m_noDecayChannels
Definition: EvtInclusiveDecay.h:153
GenBase::events_const
const McEventCollection * events_const() const
Access the current event's McEventCollection (const)
Definition: GenBase.h:96
SG::ReadHandle< McEventCollection >
AthCommonDataStore< AthCommonMsg< Algorithm > >::declareProperty
Gaudi::Details::PropertyBase & declareProperty(Gaudi::Property< T > &t)
Definition: AthCommonDataStore.h:145
EvtInclusiveDecay::m_blackListSet
std::set< int > m_blackListSet
Definition: EvtInclusiveDecay.h:139
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:490
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:665
McEventCollection
McEventCollection
Definition: GeneratorObjectsTPCnv.cxx:60
EvtInclusiveDecay::m_applyUserSelection
bool m_applyUserSelection
Definition: EvtInclusiveDecay.h:159
skel.it
it
Definition: skel.GENtoEVGEN.py:396
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:128
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:566
EvtInclusiveDecay::m_printHepMCHighLightTopLevelDecays
bool m_printHepMCHighLightTopLevelDecays
Definition: EvtInclusiveDecay.h:149
EvtInclusiveDecay::m_userSelMu2MaxEta
double m_userSelMu2MaxEta
Definition: EvtInclusiveDecay.h:164
AthCommonMsg< Algorithm >::msgLvl
bool msgLvl(const MSG::Level lvl) const
Definition: AthCommonMsg.h:30
EvtInclusiveDecay::m_decayFile
std::string m_decayFile
Definition: EvtInclusiveDecay.h:127
LArG4FSStartPointFilter.evt
evt
Definition: LArG4FSStartPointFilter.py:42
EvtInclusiveDecay::m_evtAtRndmGen
EvtInclusiveAtRndmGen * m_evtAtRndmGen
Definition: EvtInclusiveDecay.h:122
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:676
x
#define x
EvtInclusiveDecay::m_printHepMCHighlighted
bool m_printHepMCHighlighted
Definition: EvtInclusiveDecay.h:148
HepMC::fillBarcodesAttribute
void fillBarcodesAttribute(GenEvent *)
Definition: GenEvent.h:626
empty
bool empty(TH1 *h)
Definition: computils.cxx:295
python.DataFormatRates.events
events
Definition: DataFormatRates.py:105
EvtInclusiveDecay::m_isfHerwig
bool m_isfHerwig
Definition: EvtInclusiveDecay.h:167
EvtInclusiveAtRndmGen::getEngine
CLHEP::HepRandomEngine * getEngine()
Definition: EvtInclusiveDecay.h:49
EvtInclusiveDecay::m_printHepMCAfterEvtGen
bool m_printHepMCAfterEvtGen
Definition: EvtInclusiveDecay.h:147
EvtInclusiveDecay::addEvtGenDecayTree
void addEvtGenDecayTree(HepMC::GenEvent *hepMC, HepMC::GenParticlePtr part, EvtParticle *evtPart, EvtVector4R treeStart, double momentumScaleFactor=1.0)
Definition: EvtInclusiveDecay.cxx:528
XMLtoHeader.count
count
Definition: XMLtoHeader.py:85
EvtInclusiveDecay::m_readExisting
bool m_readExisting
Definition: EvtInclusiveDecay.h:133
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:432
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
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:210
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:695
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:27
EvtInclusiveDecay::m_pdtFile
std::string m_pdtFile
Definition: EvtInclusiveDecay.h:126
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
EvtInclusiveDecay::m_userSelMu1MinPt
double m_userSelMu1MinPt
Definition: EvtInclusiveDecay.h:161
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:152
EvtInclusiveDecay::removeDecayTree
void removeDecayTree(HepMC::GenEvent *hepMC, HepMC::GenParticlePtr p)
Definition: EvtInclusiveDecay.cxx:446
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:114
ATH_CHECK
#define ATH_CHECK
Definition: AthCheckMacros.h:40
EvtInclusiveDecay::m_userSelMu1MaxEta
double m_userSelMu1MaxEta
Definition: EvtInclusiveDecay.h:163
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:388
EvtInclusiveDecay::m_randomSeed
IntegerProperty m_randomSeed
Seed for random number engine.
Definition: EvtInclusiveDecay.h:117
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:737
McEventCollection
This defines the McEventCollection, which is really just an ObjectVector of McEvent objects.
Definition: McEventCollection.h:33
SG::ReadHandle::isValid
virtual bool isValid() override final
Can the handle be successfully dereferenced?
calibdata.ct
ct
Definition: calibdata.py:418
EvtInclusiveDecay::m_userSelRequireOppositeSignedMu
bool m_userSelRequireOppositeSignedMu
Definition: EvtInclusiveDecay.h:160
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
EvtInclusiveDecay::printTree
unsigned int printTree(HepMC::GenParticlePtr p, std::set< HepMC::GenVertexPtr > &visited, int level, std::set< int > *barcodeList=0)
Definition: EvtInclusiveDecay.cxx:787
Amg::py
@ py
Definition: GeoPrimitives.h:39
merge_scale_histograms.doc
string doc
Definition: merge_scale_histograms.py:9
id
SG::auxid_t id
Definition: Control/AthContainers/Root/debug.cxx:227
name
std::string name
Definition: Control/AthContainers/Root/debug.cxx:228
ATHRNG::RNGWrapper
A wrapper class for event-slot-local random engines.
Definition: RNGWrapper.h:56
VP1PartSpect::E
@ E
Definition: VP1PartSpectFlags.h:21
PlotCalibFromCool.en
en
Definition: PlotCalibFromCool.py:399
EvtInclusiveDecay::m_prohibitFinalStateDecay
bool m_prohibitFinalStateDecay
Definition: EvtInclusiveDecay.h:134
EvtInclusiveDecay::pdgName
std::string pdgName(HepMC::ConstGenParticlePtr p, bool statusHighlighting=false, std::set< int > *barcodeList=nullptr)
Definition: EvtInclusiveDecay.cxx:845
EvtInclusiveDecay::m_prohibitRemoveSelfDecay
bool m_prohibitRemoveSelfDecay
Definition: EvtInclusiveDecay.h:137
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:18
EvtInclusiveDecay::m_rndmSvc
ServiceHandle< IAthRNGSvc > m_rndmSvc
Definition: EvtInclusiveDecay.h:111
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:119
python.PyAthena.v
v
Definition: PyAthena.py:154
EvtInclusiveDecay::m_prohibitUnDecay
bool m_prohibitUnDecay
Definition: EvtInclusiveDecay.h:136
AthAlgorithm::m_extendedExtraObjects
DataObjIDColl m_extendedExtraObjects
Definition: AthAlgorithm.h:79
AthenaPoolExample_Copy.streamName
string streamName
Definition: AthenaPoolExample_Copy.py:39
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:123
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
y
#define y
h
EvtInclusiveDecay::m_nRepeatedDecays
int m_nRepeatedDecays
Definition: EvtInclusiveDecay.h:155
ATH_MSG_WARNING
#define ATH_MSG_WARNING(x)
Definition: AthMsgStreamMacros.h:32
EvtInclusiveDecay::xmlpath
std::string xmlpath(void)
Definition: EvtInclusiveDecay.cxx:882
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:127
SG::VarHandleBase::vhKey
SG::VarHandleKey & vhKey()
Return a non-const reference to the HandleKey.
Definition: StoreGate/src/VarHandleBase.cxx:623
python.DecayParser.children
children
Definition: DecayParser.py:32
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:168
EvtInclusiveDecay::m_printHepMCBeforeEvtGen
bool m_printHepMCBeforeEvtGen
Definition: EvtInclusiveDecay.h:146
EvtInclusiveDecay::m_outputKeyName
std::string m_outputKeyName
Definition: EvtInclusiveDecay.h:131
GenBase::GenBase
GenBase(const std::string &name, ISvcLocator *pSvcLocator)
Constructor.
Definition: GenBase.cxx:11
python.Bindings.keys
keys
Definition: Control/AthenaPython/python/Bindings.py:798
merge.status
status
Definition: merge.py:17
EvtInclusiveDecay::m_userSelMaxDimuMass
double m_userSelMaxDimuMass
Definition: EvtInclusiveDecay.h:166
LHEF::Writer
Pythia8::Writer Writer
Definition: Prophecy4fMerger.cxx:12
python.Constants.VERBOSE
int VERBOSE
Definition: Control/AthenaCommon/python/Constants.py:14
EvtInclusiveDecay::m_inputKeyName
std::string m_inputKeyName
Definition: EvtInclusiveDecay.h:130
EvtInclusiveDecay::m_userSelMu2MinPt
double m_userSelMu2MinPt
Definition: EvtInclusiveDecay.h:162
EvtInclusiveDecay::m_prohibitReDecay
bool m_prohibitReDecay
Definition: EvtInclusiveDecay.h:135
AthCommonDataStore::declareGaudiProperty
Gaudi::Details::PropertyBase & declareGaudiProperty(Gaudi::Property< T > &hndl, const SG::VarHandleKeyType &)
specialization for handling Gaudi::Property<SG::VarHandleKey>
Definition: AthCommonDataStore.h:156
Atlas::setExtendedEventContext
void setExtendedEventContext(EventContext &ctx, ExtendedEventContext &&ectx)
Move an extended context into a context object.
Definition: ExtendedEventContext.cxx:50
GenBase::initialize
virtual StatusCode initialize() override
Definition: GenBase.cxx:17
EvtInclusiveDecay::m_whiteListSet
std::set< int > m_whiteListSet
Definition: EvtInclusiveDecay.h:144
EvtInclusiveAtRndmGen
Definition: EvtInclusiveDecay.h:44
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