11 #include <framework/core/Module.h> 
   13 #include <analysis/DecayDescriptor/DecayDescriptor.h> 
   16 #include <framework/database/DBObjPtr.h> 
   17 #include <framework/datastore/StoreObjPtr.h> 
   19 #include <framework/geometry/B2Vector3.h> 
   22 #include <analysis/dataobjects/ParticleList.h> 
   23 #include <mdst/dbobjects/BeamSpot.h> 
   26 #include <analysis/VertexFitting/KFit/MassFitKFit.h> 
   27 #include <analysis/VertexFitting/KFit/FourCFitKFit.h> 
   28 #include <analysis/VertexFitting/KFit/MassFourCFitKFit.h> 
   29 #include <analysis/VertexFitting/KFit/MassPointingVertexFitKFit.h> 
   30 #include <analysis/VertexFitting/KFit/MassVertexFitKFit.h> 
   31 #include <analysis/VertexFitting/KFit/VertexFitKFit.h> 
   32 #include <analysis/VertexFitting/KFit/MakeMotherKFit.h> 
   33 #include <analysis/VertexFitting/KFit/RecoilMassKFit.h> 
   36 #include <analysis/VertexFitting/RaveInterface/RaveSetup.h> 
   37 #include <analysis/VertexFitting/RaveInterface/RaveVertexFitter.h> 
   38 #include <analysis/VertexFitting/RaveInterface/RaveKinematicVertexFitter.h> 
   75     virtual void event() 
override;
 
  221                                      std::vector<Particle*>&  allparticles, 
const Particle* daughter);
 
  253                           std::vector<const Particle*>& twoPhotonChildren);
 
  259                              const std::vector<const Particle*>& fitChildren);
 
Class for accessing objects in the database.
The DecayDescriptor stores information about a decay tree or parts of a decay tree.
TMatrixDSym m_beamSpotCov
Beam spot covariance matrix.
bool makeKMassMother(analysis::MassFitKFit &kv, Particle *p)
Update mother particle after mass fit using KFit.
std::string m_withConstraint
additional constraint on vertex
bool doKMassPointingVertexFit(Particle *p)
Mass-constrained vertex fit with additional pointing constraint using KFit.
void smearBeamSpot(double width)
smear beam spot covariance
bool makeMassKFourCMother(analysis::MassFourCFitKFit &kv, Particle *p)
Update mother particle after MassFourC fit using KFit.
bool doKVertexFit(Particle *p, bool ipProfileConstraint, bool ipTubeConstraint)
Unconstrained vertex fit using KFit.
bool doKMassVertexFit(Particle *p)
Mass-constrained vertex fit using KFit.
virtual void initialize() override
Initialize the Module.
void addIPTubeToKFit(analysis::VertexFitKFit &kv)
Adds IPTube constraint to the vertex fit using KFit.
bool addChildofParticletoMassKFit(analysis::MassFourCFitKFit &kf, const Particle *particle, std::vector< unsigned > &particleId)
Adds given particle's child to the MassFourCFitKFit.
virtual void event() override
Event processor.
bool makeKMassPointingVertexMother(analysis::MassPointingVertexFitKFit &kv, Particle *p)
Update mother particle after mass-constrained vertex fit with additional pointing constraint using KF...
bool m_updateDaughters
flag for daughters update
ParticleVertexFitterModule()
Constructor.
std::string m_decayString
daughter particles selection
std::vector< std::string > m_massConstraintListParticlename
Name of the particles to be mass constraint (massfourC)
std::string m_listName
particle list name
std::vector< int > m_massConstraintList
PDG codes of the particles to be mass constraint (massfourC)
bool m_hasCovMatrix
flag for mother covariance matrix (PseudoFitter)
bool makeKVertexMother(analysis::VertexFitKFit &kv, Particle *p)
Update mother particle after unconstrained vertex fit using KFit.
bool redoTwoPhotonDaughterMassFit(Particle *postFit, const Particle *preFit, const analysis::VertexFitKFit &kv)
Combines preFit particle and vertex information from vertex fit kv to create new postFit particle.
bool makeKMassVertexMother(analysis::MassVertexFitKFit &kv, Particle *p)
Update mother particle after mass-constrained vertex fit using KFit.
bool makeKFourCMother(analysis::FourCFitKFit &kv, Particle *p)
Update mother particle after FourC fit using KFit.
bool fillFitParticles(const Particle *mother, std::vector< const Particle * > &fitChildren, std::vector< const Particle * > &twoPhotonChildren)
Fills valid particle's children (with valid error matrix) in the vector of Particles that will enter ...
bool doKFourCFit(Particle *p)
FourC fit using KFit.
B2Vector3D m_BeamSpotCenter
Beam spot position.
virtual void beginRun() override
Called when entering a new run.
bool doKRecoilMassFit(Particle *p)
RecoilMass fit using KFit.
void updateMapOfTrackAndDaughter(unsigned &l, std::vector< std::vector< unsigned >> &pars, std::vector< unsigned > &pard, std::vector< Particle * > &allparticles, const Particle *daughter)
update the map of daughter and tracks, find out which tracks belong to each daughter.
DBObjPtr< BeamSpot > m_beamSpotDB
Beam spot database object.
bool doVertexFit(Particle *p)
Main steering routine.
std::string m_vertexFitter
Vertex Fitter name.
bool doRaveFit(Particle *mother)
Fit using Rave.
bool makeKRecoilMassMother(analysis::RecoilMassKFit &kf, Particle *p)
Update mother particle after RecoilMass fit using KFit.
bool doKMassFit(Particle *p)
Mass fit using KFit.
double m_recoilMass
recoil mass for constraint
double m_confidenceLevel
required fit confidence level
bool doKMassFourCFit(Particle *p)
MassFourC fit using KFit.
DecayDescriptor m_decaydescriptor
Decay descriptor of decays to look for.
bool fillNotFitParticles(const Particle *mother, std::vector< const Particle * > ¬FitChildren, const std::vector< const Particle * > &fitChildren)
Fills valid particle's children (with valid error matrix) in the vector of Particles that will not en...
void findConstraintBoost(double cut)
calculate iptube constraint (quasi cylinder along boost direction) for RAVE fit
double m_Bfield
magnetic field from data base
bool addChildofParticletoKFit(analysis::FourCFitKFit &kv, const Particle *particle)
Adds given particle's child to the FourCFitKFit.
double getChi2TracksLBoost(const analysis::VertexFitKFit &kv)
calculate the chi2 using only lboost information of tracks
double m_smearing
smearing width applied to IP tube
std::string m_fitType
type of the kinematic fit
void addIPProfileToKFit(analysis::VertexFitKFit &kv)
Adds IPProfile constraint to the vertex fit using KFit.
StoreObjPtr< ParticleList > m_plist
particle list
bool allSelectedDaughters(const Particle *mother, const std::vector< const Particle * > &tracksVertex)
check if all the Daughters (o grand-daughters) are selected for the vertex fit
Class to store reconstructed particles.
Type-safe access to single objects in the data store.
FourCFitKFit is a derived class from KFitBase to perform 4 momentum-constraint kinematical fit.
MassFitKFit is a derived class from KFitBase to perform mass-constraint kinematical fit.
MassFourCFitKFit is a derived class from KFitBase to perform mass and 4 momentum-constraint kinematic...
MassPointingVertexFitKFit is a derived class from KFitBase It performs a kinematical fit with three c...
MassVertexFitKFit is a derived class from KFitBase to perform mass-vertex-constraint kinematical fit.
RecoilMassKFit is a derived class from KFitBase to perform a kinematical fit with a recoil mass const...
VertexFitKFit is a derived class from KFitBase to perform vertex-constraint kinematical fit.
Abstract base class for different kinds of events.