8 #include <tracking/modules/mcMatcher/MCV0MatcherModule.h> 
   10 #include <framework/gearbox/Const.h> 
   11 #include <framework/gearbox/Unit.h> 
   12 #include <framework/logging/Logger.h> 
   13 #include <mdst/dataobjects/TrackFitResult.h> 
   21   setDescription(
"A module matching the V0s found by the V0Finder with MCParticles");
 
   26            "Belle2::Track collection name (input).  Note that the V0s use " 
   27            "pointers indices into these arrays, so all hell may break loose " 
   28            "if you change this.", std::string(
""));
 
   30            "Belle2::TrackFitResult collection name (input).  Note that the V0s " 
   31            "use pointers indices into these arrays, so all hell may break loose " 
   32            "if you change this.", std::string(
""));
 
   49   B2WARNING(
"This module is supposed to be used only for the debugging\n \ 
   50             of the V0Finder module, not as MC matching during analysis.");
 
   60   B2DEBUG(20, (
m_V0s.getEntries() != 0 ? 
"V0s has entries." : 
" No V0s."));
 
   62   for (
const auto& v0 : 
m_V0s) {
 
   65     const std::pair<Track*, Track*> trackPtrs = v0.getTracks();
 
   70     if (mcV0PartPlus == 
nullptr or mcV0PartMinus == 
nullptr) {
 
   71       B2DEBUG(20, 
"At least one track of the V0 does not have a MC related particle. It will be skipped for matching.");
 
   78     if (!mcV0PartPlus->
getMother() or !mcV0PartMinusMother) {
 
   79       B2DEBUG(20, 
"At least one track of the V0 does not have a mother MCParticle, skipping.");
 
   83     if (mcV0PartPlusMother != mcV0PartMinusMother) {
 
   84       B2DEBUG(20, 
"The V0 is most likely built up from combinatoric background, thus no MC relation can be set.");
 
   89       B2DEBUG(20, 
"V0 successfully matched.");
 
   90       v0.addRelationTo(mcV0PartPlusMother);
 
   92       B2DEBUG(20, 
"V0 did not match anything.");
 
   96   B2DEBUG(20, 
"MC matching finished.");
 
The ParticleType class for identifying different particle types.
A Class to store the Monte Carlo particle information.
int getPDG() const
Return PDG code of particle.
std::string m_TFRColName
Belle2::TrackFitResult collection name (input).
void initialize() override
Use this to initialize resources or memory your module needs.
void event() override
Called once for each event.
void endRun() override
Called once when a run ends.
void terminate() override
Clean up anything you created in initialize().
StoreArray< V0 > m_V0s
V0s StoreArray.
std::string m_TrackColName
Belle2::Track collection name (input).
void beginRun() override
Called once before a new run begins.
MCV0MatcherModule()
Constructor, for setting module description and parameters.
std::string m_MCParticleColName
MCParticle collection name (input).
StoreArray< MCParticle > m_MCParticles
MCParticles StoreArray.
std::string m_V0ColName
V0 collection name (input).
~MCV0MatcherModule()
Destructor (empty).
void setDescription(const std::string &description)
Sets the description of the module.
void setPropertyFlags(unsigned int propertyFlags)
Sets the flags for the module properties.
@ c_ParallelProcessingCertified
This module can be run in parallel processing mode safely (All I/O must be done through the data stor...
TO * getRelatedTo(const std::string &name="", const std::string &namedRelation="") const
Get the object to which this object has a relation.
bool isRequired(const std::string &name="")
Ensure this array/object has been registered previously.
REG_MODULE(arichBtest)
Register the Module.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
MCParticle * getMother() const
Returns a pointer to the mother particle.
Abstract base class for different kinds of events.