8 #include <tracking/modules/EcmsCollector/EcmsCollectorModule.h> 
   10 #include <analysis/dataobjects/ParticleList.h> 
   11 #include <analysis/variables/ContinuumSuppressionVariables.h> 
   12 #include <analysis/utility/PCmsLabTransform.h> 
   13 #include <mdst/dataobjects/PIDLikelihood.h> 
   14 #include <framework/particledb/EvtGenDatabasePDG.h> 
   34   setDescription(
"Collect data for eCMS calibration algorithm using the momenta of the hadronic events");
 
   40   B2INFO(
"Init of the trees");
 
   41   TString objectName = 
"events";
 
   43   TTree* tree = 
new TTree(objectName, 
"");
 
   45   tree->Branch<
int>(
"event", &
m_evt);
 
   46   tree->Branch<
int>(
"exp", &
m_exp);
 
   47   tree->Branch<
int>(
"run", &
m_run);
 
   48   tree->Branch<
double>(
"time", &
m_time);
 
   50   tree->Branch<std::vector<double>>(
"pBcms", &
m_pBcms);
 
   51   tree->Branch<std::vector<double>>(
"mB", &
m_mB);
 
   53   tree->Branch<std::vector<int>>(
"pdg", &
m_pdg);
 
   54   tree->Branch<std::vector<int>>(
"mode", &
m_mode);
 
   55   tree->Branch<std::vector<double>>(
"Kpid", &
m_Kpid);
 
   56   tree->Branch<std::vector<double>>(
"R2", &
m_R2);
 
   57   tree->Branch<std::vector<double>>(
"mD", &
m_mD);
 
   58   tree->Branch<std::vector<double>>(
"dmDstar", &
m_dmDstar);
 
   64   registerObject<TTree>(objectName.Data(), tree);
 
   96   std::vector<const Particle*> Bparts;
 
   99     for (
unsigned i = 0; i < B0->getListSize(); ++i)
 
  100       if (B0->getParticle(i))
 
  101         Bparts.push_back(B0->getParticle(i));
 
  104     for (
unsigned i = 0; i < Bm->getListSize(); ++i)
 
  105       if (Bm->getParticle(i))
 
  106         Bparts.push_back(Bm->getParticle(i));
 
  109   if (Bparts.size() == 0) 
return;
 
  114   for (
unsigned i = 0; i < Bparts.size(); ++i) {
 
  122     m_R2[i]     = Variable::R2(Bpart);
 
  143       B2INFO(
"No D meson found");
 
  146       m_mD[i] = D->getMass();
 
  147       const Particle* Kaon =  D->getDaughter(0);
 
  160   getObjectPtr<TTree>(
"events")->Fill();
 
Calibration collector module base class.
StoreObjPtr< EventMetaData > m_emd
Current EventMetaData.
static const ChargedStable pion
charged pion particle
static const ChargedStable kaon
charged kaon particle
void prepare() override final
Initialize the module.
std::vector< double > m_dmDstar
D*-D0 mass.
EcmsCollectorModule()
Constructor.
std::vector< double > m_Kpid
Kaon PID.
std::vector< double > m_pBcms
B mesons CMS momentum.
std::vector< int > m_mode
decay mode ID
double m_time
event time [hours]
void resize(int n)
resize the event members to n candidates
std::vector< double > m_mB
B mesons mass.
void collect() override final
Event processor The filling of the tree.
std::vector< double > m_mD
D meson mass.
int m_exp
experiment number
std::vector< double > m_R2
the R2 variable used for the continuum suppression
std::vector< int > m_pdg
B meson PDG code (can neutral or charged)
static EvtGenDatabasePDG * Instance()
Instance method that loads the EvtGen table.
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...
double getProbability(const Const::ChargedStable &p1, const Const::ChargedStable &p2, Const::PIDDetectorSet set=Const::PIDDetectorSet::set()) const
Return combined likelihood probability for a particle being p1 and not p2, assuming equal prior proba...
Class to store reconstructed particles.
const PIDLikelihood * getPIDLikelihood() const
Returns the pointer to the PIDLikelihood object that is related to the Track, which was used to creat...
int getPDGCode(void) const
Returns PDG code.
ROOT::Math::PxPyPzEVector get4Vector() const
Returns Lorentz vector.
const Particle * getDaughter(unsigned i) const
Returns a pointer to the i-th daughter particle.
double getExtraInfo(const std::string &name) const
Return given value if set.
double getMass() const
Returns invariant mass (= nominal for FS particles)
Type-safe access to single objects in the data store.
bool isValid() const
Check whether the object was created.
REG_MODULE(arichBtest)
Register the Module.
Abstract base class for different kinds of events.