Belle II Software development
Particle Class Reference

Class to store reconstructed particles. More...

#include <Particle.h>

Inheritance diagram for Particle:
RelationsInterface< BASE >

Public Types

enum  EParticleSourceObject {
  c_Undefined = 0 ,
  c_Track = 1 ,
  c_ECLCluster = 2 ,
  c_KLMCluster = 3 ,
  c_V0 = 4 ,
  c_MCParticle = 5 ,
  c_Composite = 6 ,
  c_NoMDSTSource = 7 ,
  c_Kink = 8
}
 particle source enumerators More...
 
enum  EFlavorType {
  c_Unflavored = 0 ,
  c_Flavored = 1
}
 describes flavor type, see getFlavorType(). More...
 
enum  {
  c_DimPosition = 3 ,
  c_DimMomentum = 4 ,
  c_DimMatrix = 7 ,
  c_SizeMatrix = c_DimMatrix * (c_DimMatrix + 1) / 2
}
 error matrix dimensions and size of 1D representation More...
 
enum  {
  c_Px ,
  c_Py ,
  c_Pz ,
  c_E ,
  c_X ,
  c_Y ,
  c_Z
}
 enumerator used for error matrix handling, shows also in which order the rows (columns) are defined More...
 
enum  PropertyFlags {
  c_Ordinary = 0 ,
  c_IsUnspecified = 1 ,
  c_IsIgnoreRadiatedPhotons = 2 ,
  c_IsIgnoreIntermediate = 4 ,
  c_IsIgnoreMassive = 8 ,
  c_IsIgnoreNeutrino = 16 ,
  c_IsIgnoreGamma = 32 ,
  c_IsIgnoreBrems = 64 ,
  c_IsIgnoreMisID = 128 ,
  c_IsIgnoreDecayInFlight = 256
}
 Flags that describe the particle property, which are used in the MC matching. More...
 

Public Member Functions

 Particle ()
 Default constructor.
 
 Particle (const ROOT::Math::PxPyPzEVector &momentum, const int pdgCode)
 Constructor from a Lorentz vector and PDG code.
 
 Particle (const ROOT::Math::PxPyPzEVector &momentum, const int pdgCode, EFlavorType flavorType, const EParticleSourceObject particleType, const unsigned mdstIndex)
 Constructor for final state particles.
 
 Particle (const ROOT::Math::PxPyPzEVector &momentum, const int pdgCode, EFlavorType flavorType, const std::vector< int > &daughterIndices, TClonesArray *arrayPointer=nullptr)
 Constructor for composite particles.
 
 Particle (const ROOT::Math::PxPyPzEVector &momentum, const int pdgCode, EFlavorType flavorType, const std::vector< int > &daughterIndices, int properties, TClonesArray *arrayPointer=nullptr)
 Constructor for composite particles.
 
 Particle (const ROOT::Math::PxPyPzEVector &momentum, const int pdgCode, EFlavorType flavorType, const std::vector< int > &daughterIndices, int properties, const std::vector< int > &daughterProperties, TClonesArray *arrayPointer=nullptr)
 Constructor for composite particles.
 
 Particle (const Track *track, const Const::ChargedStable &chargedStable)
 Constructor from a reconstructed track (mdst object Track);.
 
 Particle (int trackArrayIndex, const TrackFitResult *trackFit, const Const::ChargedStable &chargedStable)
 Constructor from a reconstructed Track given as TrackFitResult.
 
 Particle (const Kink *kink, const Const::ChargedStable &chargedStable, const unsigned trackFitResultIndex)
 Constructor from a kink object.
 
 Particle (const ECLCluster *eclCluster, const Const::ParticleType &type=Const::photon)
 Constructor of a photon from a reconstructed ECL cluster that is not matched to any charged track.
 
 Particle (const KLMCluster *klmCluster, const int pdgCode=Const::Klong.getPDGCode())
 Constructor from a reconstructed KLM cluster.
 
 Particle (const MCParticle *MCparticle)
 Constructor from MC particle (mdst object MCParticle)
 
 ~Particle ()
 Destructor.
 
void setPDGCode (const int pdg)
 Sets PDG code.
 
void set4Vector (const ROOT::Math::PxPyPzEVector &p4)
 Sets Lorentz vector.
 
void set4VectorDividingByMomentumScaling (const ROOT::Math::PxPyPzEVector &p4)
 Sets Lorentz vector dividing by the momentum scaling factor.
 
void setVertex (const ROOT::Math::XYZVector &vertex)
 Sets position (decay vertex)
 
void setEnergyLossCorrection (double energyLossCorrection)
 Sets Energy loss correction.
 
double getMomentumLossCorrectionFactor () const
 Returns effect of energy correction on the particle momentum.
 
void setMomentumScalingFactor (double momentumScalingFactor)
 Sets momentum scaling.
 
void setMomentumSmearingFactor (double momentumSmearingFactor)
 Sets momentum smearing.
 
void setJacobiMatrix (const TMatrixF &jacobiMatrix)
 Sets 4x6 jacobi matrix.
 
void setMomentumVertexErrorMatrix (const TMatrixFSym &errMatrix)
 Sets 7x7 error matrix.
 
void setPValue (double pValue)
 Sets chi^2 probability of fit.
 
void setProperty (const int properties)
 sets m_properties
 
void updateMomentum (const ROOT::Math::PxPyPzEVector &p4, const ROOT::Math::XYZVector &vertex, const TMatrixFSym &errMatrix, double pValue)
 Sets Lorentz vector, position, 7x7 error matrix and p-value.
 
void updateMass (const int pdgCode)
 Updates particle mass with the mass of the particle corresponding to the given PDG.
 
void appendDaughter (const Particle *daughter, const bool updateType=true, const int daughterProperty=c_Ordinary)
 Appends index of daughter to daughters index array.
 
void appendDaughter (int particleIndex, const bool updateType=true)
 Appends index of daughter to daughters index array.
 
void removeDaughter (const Particle *daughter, const bool updateType=true)
 Removes index of daughter from daughters index array.
 
bool replaceDaughter (const Particle *oldDaughter, Particle *newDaughter)
 Replace index of given daughter with new daughter, return true if a replacement is made.
 
bool replaceDaughterRecursively (const Particle *oldDaughter, Particle *newDaughter)
 Apply replaceDaughter to all Particles in the decay tree by looping recursively through it, return true if a replacement is made.
 
int getPDGCode (void) const
 Returns PDG code.
 
double getCharge (void) const
 Returns particle charge.
 
EFlavorType getFlavorType () const
 Returns flavor type of the decay (for FS particles: flavor type of particle)
 
EParticleSourceObject getParticleSource () const
 Returns particle source as defined with enum EParticleSourceObject.
 
unsigned getMdstArrayIndex (void) const
 Returns 0-based index of MDST store array object (0 for composite particles)
 
unsigned getTrackFitResultIndex (void) const
 Returns 0-based index of the TrackFitResult that should be associated with the Particle.
 
int getProperty () const
 Returns particle property as a bit pattern The values are defined in the PropertyFlags enum and described in detail there.
 
double getMass () const
 Returns invariant mass (= nominal for FS particles)
 
double getPDGMass (void) const
 Returns uncertainty on the invariant mass (requires valid momentum error matrix)
 
double getPDGLifetime () const
 Returns particle nominal lifetime.
 
double getEnergy () const
 Returns total energy.
 
ROOT::Math::PxPyPzEVector get4Vector () const
 Returns Lorentz vector.
 
ROOT::Math::XYZVector getMomentum () const
 Returns momentum vector.
 
double getMomentumMagnitude () const
 Returns momentum magnitude.
 
double getP () const
 Returns momentum magnitude (same as getMomentumMagnitude but with shorter name)
 
double getPx () const
 Returns x component of momentum.
 
double getPy () const
 Returns y component of momentum.
 
double getPz () const
 Returns z component of momentum.
 
double getEffectiveMomentumScale () const
 Returns effective momentum scale which is the product of the momentum scaling and smearing factors.
 
double getEnergyLossCorrection () const
 Returns Energy Loss Correction.
 
ROOT::Math::XYZVector getVertex () const
 Returns vertex position (POCA for charged, IP for neutral FS particles)
 
double getX () const
 Returns x component of vertex position.
 
double getY () const
 Returns y component of vertex position.
 
double getZ () const
 Returns z component of vertex position.
 
double getPValue () const
 Returns chi^2 probability of fit if done or -1.
 
TMatrixFSym getMomentumVertexErrorMatrix () const
 Returns 7x7 error matrix.
 
TMatrixFSym getMomentumErrorMatrix () const
 Returns the 4x4 momentum error matrix.
 
TMatrixFSym getVertexErrorMatrix () const
 Returns the 3x3 position error sub-matrix.
 
double getCosHelicity (const Particle *mother=nullptr) const
 Returns cosine of the helicity angle The helicity angle is defined in the rest frame of the particle as the angle between the negative momentum of the mother and.
 
double getCosHelicityDaughter (unsigned iDaughter, unsigned iGrandDaughter=0) const
 Returns cosine of the helicity angle of the given daughter defined by given grand daughter.
 
double getAcoplanarity () const
 Returns acoplanarity angle defined as the angle between the decay planes of the grand daughters in the particle's rest frame This assumes that the particle and its daughters have two daughters each.
 
int getMdstSource () const
 Returns unique identifier of final state particle (needed in particle combiner)
 
unsigned getNDaughters (void) const
 Returns number of daughter particles.
 
const std::vector< int > & getDaughterIndices () const
 Returns a vector of store array indices of daughter particles.
 
const std::vector< int > & getDaughterProperties () const
 Returns a vector of properties of daughter particles.
 
const ParticlegetDaughter (unsigned i) const
 Returns a pointer to the i-th daughter particle.
 
bool forEachDaughter (const std::function< bool(const Particle *)> &function, bool recursive=true, bool includeSelf=true) const
 Apply a function to all daughters of this particle.
 
std::vector< Belle2::Particle * > getDaughters () const
 Returns a vector of pointers to daughter particles.
 
std::vector< const Belle2::Particle * > getFinalStateDaughters () const
 Returns a vector of pointers to Final State daughter particles.
 
std::vector< const Belle2::Particle * > getAllDaughters () const
 Returns a vector of pointers to all generations' daughter particles.
 
std::vector< int > getMdstArrayIndices (EParticleSourceObject type) const
 Returns a vector of StoreArray indices of given MDST dataobjects.
 
bool overlapsWith (const Particle *oParticle) const
 Returns true if final state ancestors of oParticle overlap.
 
bool isCopyOf (const Particle *oParticle, bool doDetailedComparison=false) const
 Returns true if this Particle and oParticle are copies of each other.
 
const TrackgetTrack () const
 Returns the pointer to the Track object that was used to create this Particle (ParticleType == c_Track).
 
const TrackFitResultgetTrackFitResult () const
 Returns the pointer to the TrackFitResult that was used to create this Particle (ParticleType == c_Track).
 
const V0getV0 () const
 Returns the pointer to the V0 object that was used to create this Particle (if ParticleType == c_V0).
 
const KinkgetKink () const
 Returns the pointer to the Kink object that was used to create this Particle (if ParticleType == c_Kink).
 
const PIDLikelihoodgetPIDLikelihood () const
 Returns the pointer to the PIDLikelihood object that is related to the Track, which was used to create this Particle (ParticleType == c_Track).
 
const ECLClustergetECLCluster () const
 Returns the pointer to the ECLCluster object that was used to create this Particle (if ParticleType == c_ECLCluster).
 
double getECLClusterEnergy () const
 Returns the energy of the ECLCluster for the particle.
 
const KLMClustergetKLMCluster () const
 Returns the pointer to the KLMCluster object that was used to create this Particle (ParticleType == c_KLMCluster).
 
const MCParticlegetMCParticle () const
 Returns the pointer to the MCParticle object that was used to create this Particle (ParticleType == c_MCParticle).
 
std::string getName () const override
 Return name of this particle.
 
std::string getInfoHTML () const override
 Return a short summary of this object's contents in HTML format.
 
void print () const
 Prints the contents of a Particle object to standard output.
 
std::vector< std::string > getExtraInfoNames () const
 get a list of the extra info names
 
void removeExtraInfo ()
 Remove all stored extra info fields.
 
double getExtraInfo (const std::string &name) const
 Return given value if set.
 
bool hasExtraInfo (const std::string &name) const
 Return whether the extra info with the given name is set.
 
int getExtraInfoMap () const
 Return the id of the associated ParticleExtraInfoMap or -1 if no map is set.
 
unsigned int getExtraInfoSize () const
 Return the size of the extra info array.
 
void writeExtraInfo (const std::string &name, const double value)
 Sets the user defined extraInfo.
 
void setExtraInfo (const std::string &name, double value)
 Sets the user-defined data of given name to the given value.
 
void addExtraInfo (const std::string &name, double value)
 Sets the user-defined data of given name to the given value.
 
TClonesArray * getArrayPointer () const
 Returns the pointer to the store array which holds the daughter particles.
 
int getPDGCodeUsedForFit () const
 Return the always positive PDG code which was used for the track fit (if there was a track fit) of this particle.
 
bool wasExactFitHypothesisUsed () const
 Returns true if the type represented by this Particle object was used use as a mass hypothesis during the track of this Particle's parameters.
 
bool isMostLikely () const
 Returns true if the (track-based) particle is created with its most likely mass hypothesis based on PID likelihood.
 
std::pair< Const::ChargedStable, const TrackFitResult * > getMostLikelyTrackFitResult () const
 For a (track-based) particle, returns the charged stable mass hypothesis associated to the most probable TrackFitResult, and the TrackFitResult itself.
 
bool isMostLikelyTrackFitResult () const
 Returns true if the (track-based) particle is created with its most likely mass hypothesis based on TrackFitResult.
 
ECLCluster::EHypothesisBit getECLClusterEHypothesisBit () const
 Returns the ECLCluster EHypothesisBit for this Particle.
 
const ParticlegetParticleFromGeneralizedIndexString (const std::string &generalizedIndex) const
 Explores the decay tree of the particle and returns the (grand^n)daughter identified by a generalized index.
 
void updateJacobiMatrix ()
 Propagate the photon energy scaling to jacobian elements that were calculated using energy.
 
void fillFSPDaughters (std::vector< const Belle2::Particle * > &fspDaughters) const
 Fill final state particle daughters into a vector.
 
void fillAllDaughters (std::vector< const Belle2::Particle * > &allDaughters) const
 Fill all generations' daughters into a vector.
 
void addRelationTo (const RelationsInterface< BASE > *object, float weight=1.0, const std::string &namedRelation="") const
 Add a relation from this object to another object (with caching).
 
void addRelationTo (const TObject *object, float weight=1.0, const std::string &namedRelation="") const
 Add a relation from this object to another object (no caching, can be quite slow).
 
void copyRelations (const RelationsInterface< BASE > *sourceObj)
 Copies all relations of sourceObj (pointing from or to sourceObj) to this object (including weights).
 
template<class TO >
RelationVector< TO > getRelationsTo (const std::string &name="", const std::string &namedRelation="") const
 Get the relations that point from this object to another store array.
 
template<class FROM >
RelationVector< FROM > getRelationsFrom (const std::string &name="", const std::string &namedRelation="") const
 Get the relations that point from another store array to this object.
 
template<class T >
RelationVector< T > getRelationsWith (const std::string &name="", const std::string &namedRelation="") const
 Get the relations between this object and another store array.
 
template<class TO >
TO * getRelatedTo (const std::string &name="", const std::string &namedRelation="") const
 Get the object to which this object has a relation.
 
template<class FROM >
FROM * getRelatedFrom (const std::string &name="", const std::string &namedRelation="") const
 Get the object from which this object has a relation.
 
template<class T >
T * getRelated (const std::string &name="", const std::string &namedRelation="") const
 Get the object to or from which this object has a relation.
 
template<class TO >
std::pair< TO *, float > getRelatedToWithWeight (const std::string &name="", const std::string &namedRelation="") const
 Get first related object & weight of relation pointing to an array.
 
template<class FROM >
std::pair< FROM *, float > getRelatedFromWithWeight (const std::string &name="", const std::string &namedRelation="") const
 Get first related object & weight of relation pointing from an array.
 
template<class T >
std::pair< T *, float > getRelatedWithWeight (const std::string &name="", const std::string &namedRelation="") const
 Get first related object & weight of relation pointing from/to an array.
 
std::string getInfo () const
 Return a short summary of this object's contents in raw text format.
 
std::string getArrayName () const
 Get name of array this object is stored in, or "" if not found.
 
int getArrayIndex () const
 Returns this object's array index (in StoreArray), or -1 if not found.
 

Private Member Functions

void setMomentumPositionErrorMatrix (const TrackFitResult *trackFit)
 Sets the momentum, position and error matrix for this particle (created from charged Track)
 
void resetErrorMatrix ()
 Resets 7x7 error matrix All elements are set to 0.0.
 
void resetJacobiMatrix ()
 Resets 4x6 error matrix All elements are set to 0.0.
 
void storeErrorMatrix (const TMatrixFSym &errMatrix)
 Stores 7x7 error matrix into private member m_errMatrix.
 
void storeJacobiMatrix (const TMatrixF &jacobiMatrix)
 Stores 4x6 Jacobi matrix into private member m_jacobiMatrix.
 
void fillDecayChain (std::vector< int > &decayChain) const
 Fill vector with (PDGCode, MdstSource) pairs for the entire decay chain.
 
void setFlavorType ()
 sets m_flavorType using m_pdgCode
 
void setMdstArrayIndex (const int arrayIndex)
 set mdst array index
 
int generatePDGCodeFromCharge (const int chargedSign, const Const::ChargedStable &chargedStable)
 Generate the PDG code with correct sign, using the charge.
 
 ClassDefOverride (Particle, 18)
 Class to store reconstructed particles.
 
 ClassDef (RelationsInterface, 0)
 defines interface for accessing relations of objects in StoreArray.
 

Private Attributes

int m_pdgCode
 PDG code.
 
int m_pdgCodeUsedForFit = 0
 PDG code used for the track fit.
 
double m_mass
 particle (invariant) mass
 
double m_px
 momentum component x
 
double m_py
 momentum component y
 
double m_pz
 momentum component z
 
double m_momentumScale = 1.0
 effective momentum scale factor
 
double m_momentumScalingFactor = 1.0
 momentum scaling factor
 
double m_momentumSmearingFactor = 1.0
 momentum smearing factor
 
double m_energyLossCorrection = 0.0
 energy loss correction.
 
double m_x
 position component x
 
double m_y
 position component y
 
double m_z
 position component z
 
double m_errMatrix [c_SizeMatrix] = {}
 error matrix (1D representation)
 
double m_jacobiMatrix [c_SizeMatrix] = {}
 error matrix (1D representation)
 
double m_pValue
 chi^2 probability of the fit.
 
std::vector< int > m_daughterIndices
 daughter particle indices
 
EFlavorType m_flavorType
 flavor type.
 
EParticleSourceObject m_particleSource
 (mdst) source of particle
 
unsigned m_mdstIndex
 0-based index of MDST store array object
 
unsigned m_trackFitResultIndex
 0-based index of related TrackFitResult, relevant for kinks
 
int m_properties
 particle property
 
std::vector< int > m_daughterProperties
 daughter particle properties
 
int m_identifier = -1
 Identifier that can be used to identify whether the particle is unique or is a copy or representation of another.
 
std::vector< double > m_extraInfo
 Stores associated user defined values.
 
TClonesArray * m_arrayPointer
 Internal pointer to DataStore array containing the daughters of this particle.
 
DataStore::StoreEntrym_cacheDataStoreEntry
 Cache of the data store entry to which this object belongs.
 
int m_cacheArrayIndex
 Cache of the index in the TClonesArray to which this object belongs.
 

Friends

class ParticleSubset
 

Detailed Description

Class to store reconstructed particles.

This class is a common representation of all particle types, e.g.:

  • final state particles (FS particles):
    • charged kaons/pions/electrons/muons/protons reconstructed as Track
    • photons reconstructed as ECLCluster (without associated Track)
    • long lived neutral kaons reconstructed in KLM (as KLMCluster without associated Track)
  • composite particles:
    • pre-reconstructed V0 particles: Kshort, Lambda baryon, converted photon, ...
    • reconstructed in decays (via combinations)

Private members are limited to those which completely define the particle and that are common to all particle types. These are:

  • particle mass
    • nominal for FS particles
    • invariant for composite particles
  • momentum vector (px, py, pz)
  • position (x, y, z)
    • POCA for charged FS particles
    • IP for photons, Klong and pi0
    • decay vertex for composite particles
  • 7x7 error matrix (order is: px, py, pz, E, x, y, z)
  • chi^2 probability of the fit (track fit, pi0 mass-constr. fit or vertex fit)
  • PDG code
  • vector of StoreArray<Particle> indices of daughter particles

Additional private members are needed in order to make composite particles (via combinations):

  • mdst index of an object from which the FS particle is created
  • source of the object from which the particle is created (see EParticleSourceObject)
  • flavor type (unflavored/flavored) of a decay or flavor type of FS particle

Finally, it is possible to store user-defined floating-point values using addExtraInfo() and getExtraInfo(), identified by a string key. These are general purpose functions for collecting additional information about reconstructed particles that can not be included into any existing data object. Different Particle objects can store different sets of values, and there are no hard-coded limitations on the number of values stored.

Definition at line 76 of file Particle.h.

Member Enumeration Documentation

◆ anonymous enum

anonymous enum

error matrix dimensions and size of 1D representation

Definition at line 104 of file Particle.h.

104 {c_DimPosition = 3, c_DimMomentum = 4, c_DimMatrix = 7,
105 c_SizeMatrix = c_DimMatrix * (c_DimMatrix + 1) / 2
106 };

◆ anonymous enum

anonymous enum

enumerator used for error matrix handling, shows also in which order the rows (columns) are defined

Definition at line 112 of file Particle.h.

112{c_Px, c_Py, c_Pz, c_E, c_X, c_Y, c_Z};

◆ EFlavorType

describes flavor type, see getFlavorType().

Enumerator
c_Unflavored 

Is its own antiparticle or we don't know whether it is a particle/antiparticle.

c_Flavored 

Is either particle or antiparticle.

Definition at line 96 of file Particle.h.

96 {
97 c_Unflavored = 0,
98 c_Flavored = 1,
99 };
@ c_Unflavored
Is its own antiparticle or we don't know whether it is a particle/antiparticle.
Definition: Particle.h:97
@ c_Flavored
Is either particle or antiparticle.
Definition: Particle.h:98

◆ EParticleSourceObject

particle source enumerators

Definition at line 83 of file Particle.h.

83 {
84 c_Undefined = 0,
85 c_Track = 1,
86 c_ECLCluster = 2,
87 c_KLMCluster = 3,
88 c_V0 = 4,
89 c_MCParticle = 5,
90 c_Composite = 6,
91 c_NoMDSTSource = 7,
92 c_Kink = 8
93 };

◆ PropertyFlags

Flags that describe the particle property, which are used in the MC matching.

Enumerator
c_IsUnspecified 

Ordinary particles.

Is the particle unspecified by marking @ ?

c_IsIgnoreRadiatedPhotons 

Is the particle MC matched with the ignore radiated photon flag set?

c_IsIgnoreIntermediate 

Is the particle MC matched with the ignore intermediate resonances flag set?

c_IsIgnoreMassive 

Is the particle MC matched with the ignore missing massive particle flag set?

c_IsIgnoreNeutrino 

Is the particle MC matched with the ignore missing neutrino flag set?

c_IsIgnoreGamma 

Is the particle MC matched with the ignore missing gamma flag set?

c_IsIgnoreBrems 

Is the particle MC matched with the ignore added Brems gamma flag set?

c_IsIgnoreMisID 

Is the particle MC matched with the ignore MisID flag set?

c_IsIgnoreDecayInFlight 

Is the particle MC matched with the ignore DecayInFlight flag set?

Definition at line 118 of file Particle.h.

118 {
119 c_Ordinary = 0,
120 c_IsUnspecified = 1,
124 c_IsIgnoreNeutrino = 16,
125 c_IsIgnoreGamma = 32,
126 c_IsIgnoreBrems = 64,
127 c_IsIgnoreMisID = 128,
129 };
@ c_IsIgnoreNeutrino
Is the particle MC matched with the ignore missing neutrino flag set?
Definition: Particle.h:124
@ c_IsIgnoreRadiatedPhotons
Is the particle MC matched with the ignore radiated photon flag set?
Definition: Particle.h:121
@ c_IsIgnoreGamma
Is the particle MC matched with the ignore missing gamma flag set?
Definition: Particle.h:125
@ c_IsUnspecified
Ordinary particles.
Definition: Particle.h:120
@ c_IsIgnoreBrems
Is the particle MC matched with the ignore added Brems gamma flag set?
Definition: Particle.h:126
@ c_IsIgnoreDecayInFlight
Is the particle MC matched with the ignore DecayInFlight flag set?
Definition: Particle.h:128
@ c_IsIgnoreMisID
Is the particle MC matched with the ignore MisID flag set?
Definition: Particle.h:127
@ c_IsIgnoreIntermediate
Is the particle MC matched with the ignore intermediate resonances flag set?
Definition: Particle.h:122
@ c_IsIgnoreMassive
Is the particle MC matched with the ignore missing massive particle flag set?
Definition: Particle.h:123

Constructor & Destructor Documentation

◆ Particle() [1/12]

Particle ( )

Default constructor.

All private members are set to 0. Particle type is set to c_Undefined.

Definition at line 45 of file Particle.cc.

45 :
46 m_pdgCode(0), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
48 m_properties(0),
49 m_arrayPointer(nullptr)
50{
52}
double m_pValue
chi^2 probability of the fit.
Definition: Particle.h:1097
double m_pz
momentum component z
Definition: Particle.h:1087
unsigned m_mdstIndex
0-based index of MDST store array object
Definition: Particle.h:1101
double m_py
momentum component y
Definition: Particle.h:1086
double m_x
position component x
Definition: Particle.h:1092
double m_px
momentum component x
Definition: Particle.h:1085
TClonesArray * m_arrayPointer
Internal pointer to DataStore array containing the daughters of this particle.
Definition: Particle.h:1129
EParticleSourceObject m_particleSource
(mdst) source of particle
Definition: Particle.h:1100
void resetErrorMatrix()
Resets 7x7 error matrix All elements are set to 0.0.
Definition: Particle.cc:1163
EFlavorType m_flavorType
flavor type.
Definition: Particle.h:1099
double m_mass
particle (invariant) mass
Definition: Particle.h:1084
unsigned m_trackFitResultIndex
0-based index of related TrackFitResult, relevant for kinks
Definition: Particle.h:1102
double m_z
position component z
Definition: Particle.h:1094
int m_pdgCode
PDG code.
Definition: Particle.h:1082
double m_y
position component y
Definition: Particle.h:1093
int m_properties
particle property
Definition: Particle.h:1103

◆ Particle() [2/12]

Particle ( const ROOT::Math::PxPyPzEVector &  momentum,
const int  pdgCode 
)

Constructor from a Lorentz vector and PDG code.

All other private members are set to their default values (0).

Parameters
momentumLorentz vector
pdgCodePDG code

Definition at line 55 of file Particle.cc.

55 :
56 m_pdgCode(pdgCode), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
58 m_arrayPointer(nullptr)
59{
61 set4Vector(momentum);
63 // set mass of stable charged particle to its nominal value
66 }
67}
The ParticleType class for identifying different particle types.
Definition: Const.h:408
static const ParticleSet chargedStableSet
set of charged stable particles
Definition: Const.h:618
void setFlavorType()
sets m_flavorType using m_pdgCode
Definition: Particle.cc:1234
void set4Vector(const ROOT::Math::PxPyPzEVector &p4)
Sets Lorentz vector.
Definition: Particle.h:282
void updateMass(const int pdgCode)
Updates particle mass with the mass of the particle corresponding to the given PDG.
Definition: Particle.cc:627

◆ Particle() [3/12]

Particle ( const ROOT::Math::PxPyPzEVector &  momentum,
const int  pdgCode,
EFlavorType  flavorType,
const EParticleSourceObject  particleType,
const unsigned  mdstIndex 
)

Constructor for final state particles.

All other private members are set to their default values (0).

Parameters
momentumLorentz vector
pdgCodePDG code
flavorTypeflavor type
particleTypeparticle source
mdstIndexmdst index

Definition at line 70 of file Particle.cc.

74 :
75 m_pdgCode(pdgCode), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
77{
78 if (flavorType == c_Unflavored and pdgCode < 0)
79 m_pdgCode = -pdgCode;
80
81 setMdstArrayIndex(mdstIndex);
82 set4Vector(momentum);
84 // set mass of stable charged particle to its nominal value
87 }
88}
void setMdstArrayIndex(const int arrayIndex)
set mdst array index
Definition: Particle.cc:380

◆ Particle() [4/12]

Particle ( const ROOT::Math::PxPyPzEVector &  momentum,
const int  pdgCode,
EFlavorType  flavorType,
const std::vector< int > &  daughterIndices,
TClonesArray *  arrayPointer = nullptr 
)

Constructor for composite particles.

All other private members are set to their default values (0).

Parameters
momentumLorentz vector
pdgCodePDG code
flavorTypedecay flavor type
daughterIndicesindices of daughters in StoreArray<Particle>
arrayPointerpointer to store array which stores the daughters, if the particle itself is stored in the same array the pointer can be automatically determined

Definition at line 91 of file Particle.cc.

95 :
96 m_pdgCode(0), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
97 m_pValue(-1),
98 m_daughterIndices(daughterIndices),
100 m_properties(0), m_arrayPointer(arrayPointer)
101{
102 m_pdgCode = pdgCode;
103 m_flavorType = flavorType;
104 if (flavorType == c_Unflavored and pdgCode < 0)
105 m_pdgCode = -pdgCode;
106 set4Vector(momentum);
108 // set mass of stable charged particle to its nominal value
111 }
112
113 if (!daughterIndices.empty()) {
114 m_particleSource = c_Composite;
115 if (getArrayPointer() == nullptr) {
116 B2FATAL("Composite Particle (with daughters) was constructed outside StoreArray without specifying daughter array!");
117 }
118 for (unsigned int i = 0; i < m_daughterIndices.size(); i++) {
119 m_daughterProperties.push_back(Particle::PropertyFlags::c_Ordinary);
120 }
121 }
122}
TClonesArray * getArrayPointer() const
Returns the pointer to the store array which holds the daughter particles.
Definition: Particle.h:981
std::vector< int > m_daughterProperties
daughter particle properties
Definition: Particle.h:1104
std::vector< int > m_daughterIndices
daughter particle indices
Definition: Particle.h:1098

◆ Particle() [5/12]

Particle ( const ROOT::Math::PxPyPzEVector &  momentum,
const int  pdgCode,
EFlavorType  flavorType,
const std::vector< int > &  daughterIndices,
int  properties,
TClonesArray *  arrayPointer = nullptr 
)

Constructor for composite particles.

All other private members are set to their default values (0).

Parameters
momentumLorentz vector
pdgCodePDG code
flavorTypedecay flavor type
daughterIndicesindices of daughters in StoreArray<Particle>
propertiesparticle property
arrayPointerpointer to store array which stores the daughters, if the particle itself is stored in the same array the pointer can be automatically determined

Definition at line 124 of file Particle.cc.

129 :
130 m_pdgCode(0), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
131 m_pValue(-1),
132 m_daughterIndices(daughterIndices),
134 m_arrayPointer(arrayPointer)
135{
136 m_pdgCode = pdgCode;
137 m_flavorType = flavorType;
138 if (flavorType == c_Unflavored and pdgCode < 0)
139 m_pdgCode = -pdgCode;
140 set4Vector(momentum);
142 // set mass of stable charged particle to its nominal value
145 }
146 m_properties = properties;
147
148 if (!daughterIndices.empty()) {
149 m_particleSource = c_Composite;
150 if (getArrayPointer() == nullptr) {
151 B2FATAL("Composite Particle (with daughters) was constructed outside StoreArray without specifying daughter array!");
152 }
153 for (unsigned int i = 0; i < m_daughterIndices.size(); i++) {
154 m_daughterProperties.push_back(Particle::PropertyFlags::c_Ordinary);
155 }
156 }
157}

◆ Particle() [6/12]

Particle ( const ROOT::Math::PxPyPzEVector &  momentum,
const int  pdgCode,
EFlavorType  flavorType,
const std::vector< int > &  daughterIndices,
int  properties,
const std::vector< int > &  daughterProperties,
TClonesArray *  arrayPointer = nullptr 
)

Constructor for composite particles.

All other private members are set to their default values (0).

Parameters
momentumLorentz vector
pdgCodePDG code
flavorTypedecay flavor type
daughterIndicesindices of daughters in StoreArray<Particle>
propertiesparticle property
daughterPropertiesdaughter particle properties
arrayPointerpointer to store array which stores the daughters, if the particle itself is stored in the same array the pointer can be automatically determined

Definition at line 160 of file Particle.cc.

166 :
167 m_pdgCode(0), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
168 m_pValue(-1),
169 m_daughterIndices(daughterIndices),
171 m_daughterProperties(daughterProperties),
172 m_arrayPointer(arrayPointer)
173{
174 m_pdgCode = pdgCode;
175 m_flavorType = flavorType;
176 if (flavorType == c_Unflavored and pdgCode < 0)
177 m_pdgCode = -pdgCode;
178 set4Vector(momentum);
180 // set mass of stable charged particle to its nominal value
183 }
184 m_properties = properties;
185
186 if (!daughterIndices.empty()) {
187 m_particleSource = c_Composite;
188 if (getArrayPointer() == nullptr) {
189 B2FATAL("Composite Particle (with daughters) was constructed outside StoreArray without specifying daughter array!");
190 }
191 }
192}

◆ Particle() [7/12]

Particle ( const Track track,
const Const::ChargedStable chargedStable 
)

Constructor from a reconstructed track (mdst object Track);.

Parameters
trackpointer to Track object
chargedStableType of charged particle

Definition at line 195 of file Particle.cc.

196 :
197 Particle(track ? track->getArrayIndex() : 0, track ? track->getTrackFitResultWithClosestMass(chargedStable) : nullptr,
198 chargedStable)
199{
200}
Particle()
Default constructor.
Definition: Particle.cc:45

◆ Particle() [8/12]

Particle ( int  trackArrayIndex,
const TrackFitResult trackFit,
const Const::ChargedStable chargedStable 
)

Constructor from a reconstructed Track given as TrackFitResult.

To be used to create Particle objects from tracks with full control over the hypothesis (e.g. V0 daughters).

Parameters
trackArrayIndextrack StoreArray index
trackFitpointer to TrackFitResult object
chargedStableType of charged particle

Definition at line 202 of file Particle.cc.

204 :
205 m_pdgCode(0), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
207 m_arrayPointer(nullptr)
208{
209 if (!trackFit) return;
210
211 m_flavorType = c_Flavored; //tracks are charged
212 m_particleSource = c_Track;
213
214 setMdstArrayIndex(trackArrayIndex);
215
217 m_pdgCode = generatePDGCodeFromCharge(trackFit->getChargeSign(), chargedStable);
218
219 // set mass
220 if (TDatabasePDG::Instance()->GetParticle(m_pdgCode) == nullptr)
221 B2FATAL("PDG=" << m_pdgCode << " ***code unknown to TDatabasePDG");
222 m_mass = TDatabasePDG::Instance()->GetParticle(m_pdgCode)->Mass() ;
223
224 // set momentum, position and error matrix
226}
int getPDGCode() const
PDG code.
Definition: Const.h:473
void setMomentumPositionErrorMatrix(const TrackFitResult *trackFit)
Sets the momentum, position and error matrix for this particle (created from charged Track)
Definition: Particle.cc:1085
int m_pdgCodeUsedForFit
PDG code used for the track fit.
Definition: Particle.h:1083
int generatePDGCodeFromCharge(const int chargedSign, const Const::ChargedStable &chargedStable)
Generate the PDG code with correct sign, using the charge.
Definition: Particle.cc:1466
short getChargeSign() const
Return track charge (1 or -1).
Const::ParticleType getParticleType() const
Getter for ParticleType of the mass hypothesis of the track fit.

◆ Particle() [9/12]

Particle ( const Kink kink,
const Const::ChargedStable chargedStable,
const unsigned  trackFitResultIndex 
)

Constructor from a kink object.

Parameters
kinkpointer to Kink object
chargedStableType of charged particle
trackFitResultIndexindex of TrackFitResult to be associated with Particle

Definition at line 228 of file Particle.cc.

228 :
229 m_pdgCode(0), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
231 m_arrayPointer(nullptr)
232{
233 if (!kink) return;
234
236 m_particleSource = c_Kink;
237
239 m_trackFitResultIndex = trackFitResultIndex;
240
241 StoreArray<TrackFitResult> trackFitResults{};
242 const TrackFitResult* particleTrackFitResult = trackFitResults[m_trackFitResultIndex];
243
244 m_pdgCode = generatePDGCodeFromCharge(particleTrackFitResult->getChargeSign(), chargedStable);
245
246 // set mass
247 if (TDatabasePDG::Instance()->GetParticle(m_pdgCode) == nullptr)
248 B2FATAL("PDG=" << m_pdgCode << " ***code unknown to TDatabasePDG");
249 m_mass = TDatabasePDG::Instance()->GetParticle(m_pdgCode)->Mass() ;
250
251 // set momentum, position and error matrix
252 setMomentumPositionErrorMatrix(particleTrackFitResult);
253}
int getArrayIndex() const
Returns this object's array index (in StoreArray), or -1 if not found.
Accessor to arrays stored in the data store.
Definition: StoreArray.h:113
Values of the result of a track fit with a given particle hypothesis.

◆ Particle() [10/12]

Particle ( const ECLCluster eclCluster,
const Const::ParticleType type = Const::photon 
)
explicit

Constructor of a photon from a reconstructed ECL cluster that is not matched to any charged track.

Parameters
eclClusterpointer to ECLCluster object
typethe kind of ParticleType we want (photon by default)

Definition at line 255 of file Particle.cc.

255 :
256 m_pdgCode(type.getPDGCode()), m_mass(type.getMass()), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
258{
259 if (!eclCluster) return;
260
262
263 // returns default vertex from clusterutils (from beam parameters if available)
264 // leave it like that for the moment to make it transparent
265 ClusterUtils C;
266 const XYZVector clustervertex = C.GetIPPosition();
267 setVertex(clustervertex);
268
269 const PxPyPzEVector clustermom = C.Get4MomentumFromCluster(eclCluster, clustervertex, getECLClusterEHypothesisBit());
270 m_px = clustermom.Px();
271 m_py = clustermom.Py();
272 m_pz = clustermom.Pz();
273
274 m_particleSource = c_ECLCluster;
275 setMdstArrayIndex(eclCluster->getArrayIndex());
276
277 // set Chi^2 probability:
278 //TODO: gamma quality can be written here
279 m_pValue = 1;
280
281 // get error matrix.
283
284}
Class to provide momentum-related information from ECLClusters.
Definition: ClusterUtils.h:38
const ROOT::Math::PxPyPzEVector Get4MomentumFromCluster(const ECLCluster *cluster, ECLCluster::EHypothesisBit hypo)
Returns four momentum vector.
Definition: ClusterUtils.cc:25
const ROOT::Math::XYZVector GetIPPosition()
Returns default IP position from beam parameters.
void updateJacobiMatrix()
Propagate the photon energy scaling to jacobian elements that were calculated using energy.
Definition: Particle.cc:287
void setVertex(const ROOT::Math::XYZVector &vertex)
Sets position (decay vertex)
Definition: Particle.h:306
ECLCluster::EHypothesisBit getECLClusterEHypothesisBit() const
Returns the ECLCluster EHypothesisBit for this Particle.
Definition: Particle.h:1029

◆ Particle() [11/12]

Particle ( const KLMCluster klmCluster,
const int  pdgCode = Const::Klong.getPDGCode() 
)
explicit

Constructor from a reconstructed KLM cluster.

Parameters
klmClusterpointer to KLMCluster object
pdgCodePDG code (Klong by default)

Definition at line 325 of file Particle.cc.

325 :
326 m_pdgCode(0), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
328{
329 if (!klmCluster) return;
330
331 m_pdgCode = pdgCode;
333
334 set4Vector(klmCluster->getMomentum());
335 setVertex(XYZVector(0, 0, 0)); // so far KLMCluster don't provide reliable / usable position information
336 updateMass(m_pdgCode); // KLMCluster internally use Klong mass, overwrite here to allow neutrons
337
338 m_particleSource = c_KLMCluster;
339 setMdstArrayIndex(klmCluster->getArrayIndex());
340
341 // set Chi^2 probability:
342 //TODO: KL quality can be written here
343 m_pValue = -1;
344
345 // TODO: set error matrix
347 //storeErrorMatrix(klmCluster->getErrorMatrix());
348}
ROOT::Math::PxPyPzEVector getMomentum() const
Get momentum.
Definition: KLMCluster.cc:49

◆ Particle() [12/12]

Particle ( const MCParticle MCparticle)
explicit

Constructor from MC particle (mdst object MCParticle)

Parameters
MCparticlepointer to MCParticle object

Definition at line 351 of file Particle.cc.

351 :
352 m_pdgCode(0), m_mass(0), m_px(0), m_py(0), m_pz(0), m_x(0), m_y(0), m_z(0),
354{
355 if (!mcParticle) return;
356
357 m_pdgCode = mcParticle->getPDG();
358 m_particleSource = c_MCParticle; // TODO: what about daughters if not FS particle?
359
360 setMdstArrayIndex(mcParticle->getArrayIndex());
361
362
364
365 // mass and momentum
366 m_mass = mcParticle->getMass();
367 m_px = mcParticle->getMomentum().X();
368 m_py = mcParticle->getMomentum().Y();
369 m_pz = mcParticle->getMomentum().Z();
370 // production vertex
371 // TODO: good only for FS particles, for composite we must use decay vertex
372 setVertex(mcParticle->getVertex());
373
375}

Member Function Documentation

◆ addExtraInfo()

void addExtraInfo ( const std::string &  name,
double  value 
)

Sets the user-defined data of given name to the given value.

throws std::runtime_error if variable is already set.

Definition at line 1420 of file Particle.cc.

1421{
1422 if (hasExtraInfo(name))
1423 throw std::runtime_error(std::string("addExtraInfo: Value '") + name + "' already set!");
1424
1426 if (!extraInfoMap)
1427 extraInfoMap.create();
1428 if (m_extraInfo.empty()) {
1429 unsigned int mapID = extraInfoMap->getMapForNewVar(name);
1430 m_extraInfo.push_back(mapID);
1431 m_extraInfo.push_back(value);
1432 } else {
1433 unsigned int oldMapID = m_extraInfo[0];
1434 unsigned int insertIndex = m_extraInfo.size();
1435 unsigned int mapID = extraInfoMap->getMapForNewVar(name, oldMapID, insertIndex);
1436
1437 m_extraInfo[0] = mapID; //update map
1438 m_extraInfo.push_back(value); //add value
1439 }
1440}
std::vector< double > m_extraInfo
Stores associated user defined values.
Definition: Particle.h:1120
bool hasExtraInfo(const std::string &name) const
Return whether the extra info with the given name is set.
Definition: Particle.cc:1350
bool create(bool replace=false)
Create a default object in the data store.
Type-safe access to single objects in the data store.
Definition: StoreObjPtr.h:95

◆ addRelationTo() [1/2]

void addRelationTo ( const RelationsInterface< BASE > *  object,
float  weight = 1.0,
const std::string &  namedRelation = "" 
) const
inlineinherited

Add a relation from this object to another object (with caching).

Parameters
objectThe object to which the relation should point.
weightThe weight of the relation.
namedRelationAdditional name for the relation, or "" for the default naming

Definition at line 142 of file RelationsObject.h.

143 {
144 if (object)
146 object, object->m_cacheDataStoreEntry, object->m_cacheArrayIndex, weight, namedRelation);
147 }
void addRelation(const TObject *fromObject, StoreEntry *&fromEntry, int &fromIndex, const TObject *toObject, StoreEntry *&toEntry, int &toIndex, float weight, const std::string &namedRelation)
Add a relation from an object in a store array to another object in a store array.
Definition: DataStore.cc:491
static DataStore & Instance()
Instance of singleton Store.
Definition: DataStore.cc:53
DataStore::StoreEntry * m_cacheDataStoreEntry
Cache of the data store entry to which this object belongs.
int m_cacheArrayIndex
Cache of the index in the TClonesArray to which this object belongs.

◆ addRelationTo() [2/2]

void addRelationTo ( const TObject *  object,
float  weight = 1.0,
const std::string &  namedRelation = "" 
) const
inlineinherited

Add a relation from this object to another object (no caching, can be quite slow).

Parameters
objectThe object to which the relation should point.
weightThe weight of the relation.
namedRelationAdditional name for the relation, or "" for the default naming

Definition at line 155 of file RelationsObject.h.

156 {
157 StoreEntry* toEntry = nullptr;
158 int toIndex = -1;
159 DataStore::Instance().addRelation(this, m_cacheDataStoreEntry, m_cacheArrayIndex, object, toEntry, toIndex, weight, namedRelation);
160 }

◆ appendDaughter() [1/2]

void appendDaughter ( const Particle daughter,
const bool  updateType = true,
const int  daughterProperty = c_Ordinary 
)

Appends index of daughter to daughters index array.

Parameters
daughterpointer to the daughter particle
updateTypebool to set whether particle type should be updated
daughterPropertyproperty of the daughter particle

Definition at line 706 of file Particle.cc.

707{
708 if (updateType) {
709 // is it a composite particle or fsr corrected?
710 m_particleSource = c_Composite;
711 }
712
713 // add daughter index
714 m_daughterIndices.push_back(daughter->getArrayIndex());
715 m_daughterProperties.push_back(daughterProperty);
716}

◆ appendDaughter() [2/2]

void appendDaughter ( int  particleIndex,
const bool  updateType = true 
)
inline

Appends index of daughter to daughters index array.

Parameters
particleIndexindex of daughter in StoreArray<Particle>
updateTypebool to set whether particle type should be updated

Definition at line 427 of file Particle.h.

428 {
429 if (updateType) {
430 // is it a composite particle or fsr corrected?
431 m_particleSource = c_Composite;
432 }
433 m_daughterIndices.push_back(particleIndex);
434 m_daughterProperties.push_back(c_Ordinary);
435 }

◆ copyRelations()

void copyRelations ( const RelationsInterface< BASE > *  sourceObj)
inlineinherited

Copies all relations of sourceObj (pointing from or to sourceObj) to this object (including weights).

Useful if you want to make a complete copy of a StoreArray object to make modifications to it, but retain all information on linked objects.

Note: this only works if sourceObj inherits from the same base (e.g. RelationsObject), and only for related objects that also inherit from the same base.

Definition at line 170 of file RelationsObject.h.

171 {
172 if (!sourceObj)
173 return;
174 auto fromRels = sourceObj->getRelationsFrom<RelationsInterface<BASE>>("ALL");
175 for (unsigned int iRel = 0; iRel < fromRels.size(); iRel++) {
176 fromRels.object(iRel)->addRelationTo(this, fromRels.weight(iRel));
177 }
178
179 auto toRels = sourceObj->getRelationsTo<RelationsInterface<BASE>>("ALL");
180 for (unsigned int iRel = 0; iRel < toRels.size(); iRel++) {
181 this->addRelationTo(toRels.object(iRel), toRels.weight(iRel));
182 }
183 }
void addRelationTo(const RelationsInterface< BASE > *object, float weight=1.0, const std::string &namedRelation="") const
Add a relation from this object to another object (with caching).

◆ fillAllDaughters()

void fillAllDaughters ( std::vector< const Belle2::Particle * > &  allDaughters) const

Fill all generations' daughters into a vector.

Function is called recursively

Parameters
allDaughtersvector of daughter particles

Definition at line 1211 of file Particle.cc.

1212{
1213 // this is FSP
1214 if (getNDaughters() == 0)
1215 return;
1216
1217 // this is not FSP (fill it and go one level down)
1218 for (unsigned i = 0; i < getNDaughters(); i++) {
1219 allDaughters.push_back(getDaughter(i));
1220 getDaughter(i)->fillAllDaughters(allDaughters);
1221 }
1222}
void fillAllDaughters(std::vector< const Belle2::Particle * > &allDaughters) const
Fill all generations' daughters into a vector.
Definition: Particle.cc:1211
unsigned getNDaughters(void) const
Returns number of daughter particles.
Definition: Particle.h:747
const Particle * getDaughter(unsigned i) const
Returns a pointer to the i-th daughter particle.
Definition: Particle.cc:661

◆ fillDecayChain()

void fillDecayChain ( std::vector< int > &  decayChain) const
private

Fill vector with (PDGCode, MdstSource) pairs for the entire decay chain.

Used to determine if two Particles are copies or not.

Function is called recursively

Parameters
decayChainvector of (PDGCode, MdstSource) pairs for each particle in the decay chain of this particle

Definition at line 1224 of file Particle.cc.

1225{
1226 decayChain.push_back(m_pdgCode);
1227 decayChain.push_back(getMdstSource());
1228
1229 for (unsigned i = 0; i < getNDaughters(); i++)
1230 getDaughter(i)->fillDecayChain(decayChain);
1231}
int getMdstSource() const
Returns unique identifier of final state particle (needed in particle combiner)
Definition: Particle.cc:399
void fillDecayChain(std::vector< int > &decayChain) const
Fill vector with (PDGCode, MdstSource) pairs for the entire decay chain.
Definition: Particle.cc:1224

◆ fillFSPDaughters()

void fillFSPDaughters ( std::vector< const Belle2::Particle * > &  fspDaughters) const

Fill final state particle daughters into a vector.

Function is called recursively

Parameters
fspDaughtersvector of daughter particles

Definition at line 1198 of file Particle.cc.

1199{
1200 // this is FSP
1201 if (getNDaughters() == 0) {
1202 fspDaughters.push_back(this);
1203 return;
1204 }
1205
1206 // this is not FSP (go one level down)
1207 for (unsigned i = 0; i < getNDaughters(); i++)
1208 getDaughter(i)->fillFSPDaughters(fspDaughters);
1209}
void fillFSPDaughters(std::vector< const Belle2::Particle * > &fspDaughters) const
Fill final state particle daughters into a vector.
Definition: Particle.cc:1198

◆ forEachDaughter()

bool forEachDaughter ( const std::function< bool(const Particle *)> &  function,
bool  recursive = true,
bool  includeSelf = true 
) const

Apply a function to all daughters of this particle.

Parameters
functionfunction object to run on each daughter. If this function returns true the processing will be stopped immediately.
recursiveif true go through all daughters of daughters as well
includeSelfif true also apply the function to this particle
Returns
true if the function returned true for any of the particles it was applied to

Definition at line 1442 of file Particle.cc.

1444{
1445 std::queue<const Particle*> qq;
1446 // If we include ourselves add only this, otherwise directly all children
1447 if (includeSelf) {
1448 qq.push(this);
1449 } else {
1450 for (size_t i = 0; i < getNDaughters(); ++i) qq.push(getDaughter(i));
1451 }
1452 // Now just repeat until done: take the child, run the functor, remove the
1453 // child, add all children if needed
1454 while (!qq.empty()) {
1455 const Particle* p = qq.front();
1456 if (function(p)) return true;
1457 qq.pop();
1458 // Add children if we go through all children recursively or if we look at
1459 // the current particle: we always want the direct children.
1460 if (recursive || p == this)
1461 for (size_t i = 0; i < p->getNDaughters(); ++i) qq.push(p->getDaughter(i));
1462 }
1463 return false;
1464}
Class to store reconstructed particles.
Definition: Particle.h:76

◆ generatePDGCodeFromCharge()

int generatePDGCodeFromCharge ( const int  chargedSign,
const Const::ChargedStable chargedStable 
)
private

Generate the PDG code with correct sign, using the charge.

Parameters
chargedSigncharge of the particle
chargedStableType of charged particle

Definition at line 1466 of file Particle.cc.

1467{
1468 int absPDGCode = chargedStable.getPDGCode();
1469 int PDGCode = absPDGCode * chargeSign;
1470 // flip sign of PDG code for leptons: their PDG code is positive if the lepton charge is negative and vice versa
1471 if (chargedStable == Const::muon || chargedStable == Const::electron) PDGCode = -PDGCode;
1472 return PDGCode;
1473}
static const ChargedStable muon
muon particle
Definition: Const.h:660
static const ChargedStable electron
electron particle
Definition: Const.h:659

◆ get4Vector()

ROOT::Math::PxPyPzEVector get4Vector ( ) const
inline

Returns Lorentz vector.

Returns
Lorentz vector

Definition at line 567 of file Particle.h.

568 {
569 double correction = getMomentumLossCorrectionFactor();
570 return ROOT::Math::PxPyPzEVector(m_momentumScale * correction * m_px,
571 m_momentumScale * correction * m_py,
572 m_momentumScale * correction * m_pz,
573 getEnergy());
574 }
double m_momentumScale
effective momentum scale factor
Definition: Particle.h:1088
double getEnergy() const
Returns total energy.
Definition: Particle.h:555
double getMomentumLossCorrectionFactor() const
Returns effect of energy correction on the particle momentum.
Definition: Particle.h:326

◆ getAcoplanarity()

double getAcoplanarity ( ) const

Returns acoplanarity angle defined as the angle between the decay planes of the grand daughters in the particle's rest frame This assumes that the particle and its daughters have two daughters each.

Returns
acoplanarity angle

Definition at line 563 of file Particle.cc.

564{
565 // check that we have a decay to two daughters and then two grand daughters each
566 if (getNDaughters() != 2) {
567 B2ERROR("Cannot calculate acoplanarity of particle 'name' because the number of daughters is not 2"
568 << LogVar("name", getName()) << LogVar("# of daughters", getNDaughters()));
569 return std::numeric_limits<double>::quiet_NaN();
570 }
571 const Particle* daughter0 = getDaughter(0);
572 const Particle* daughter1 = getDaughter(1);
573 if ((daughter0->getNDaughters() != 2) || (daughter1->getNDaughters() != 2)) {
574 B2ERROR("Cannot calculate acoplanarity of particle 'name' because the number of grand daughters is not 2"
575 << LogVar("name", getName()) << LogVar("# of grand daughters of first daughter", daughter0->getNDaughters())
576 << LogVar("# of grand daughters of second daughter", daughter1->getNDaughters()));
577 return std::numeric_limits<double>::quiet_NaN();
578 }
579
580 // boost vector to the rest frame of the particle
581 Boost boost(get4Vector().BoostToCM());
582
583 // momenta of the daughters and grand daughters in the particle's rest frame
584 PxPyPzEVector pDaughter0 = boost * daughter0->get4Vector();
585 PxPyPzEVector pGrandDaughter0 = boost * daughter0->getDaughter(0)->get4Vector();
586 PxPyPzEVector pDaughter1 = boost * daughter1->get4Vector();
587 PxPyPzEVector pGrandDaughter1 = boost * daughter1->getDaughter(0)->get4Vector();
588
589 // calculate angle between normal vectors
590 XYZVector normal0 = pDaughter0.Vect().Cross(pGrandDaughter0.Vect());
591 XYZVector normal1 = -pDaughter1.Vect().Cross(pGrandDaughter1.Vect());
592 double result = acos(normal0.Unit().Dot(normal1.Unit()));
593 if (normal0.Cross(normal1).Dot(pDaughter0.Vect()) < 0) result = -result;
594
595 return result;
596}
std::string getName() const override
Return name of this particle.
Definition: Particle.cc:1249
ROOT::Math::PxPyPzEVector get4Vector() const
Returns Lorentz vector.
Definition: Particle.h:567
Class to store variables with their name which were sent to the logging service.

◆ getAllDaughters()

std::vector< const Belle2::Particle * > getAllDaughters ( ) const

Returns a vector of pointers to all generations' daughter particles.

Returns
vector of pointers to all generations' daughter particles

Definition at line 687 of file Particle.cc.

688{
689 std::vector<const Particle*> allDaughters;
690 fillAllDaughters(allDaughters);
691
692 return allDaughters;
693}

◆ getArrayIndex()

int getArrayIndex ( ) const
inlineinherited

Returns this object's array index (in StoreArray), or -1 if not found.

Definition at line 385 of file RelationsObject.h.

386 {
388 return m_cacheArrayIndex;
389 }
bool findStoreEntry(const TObject *object, StoreEntry *&entry, int &index)
Find an object in an array in the data store.
Definition: DataStore.cc:397

◆ getArrayName()

std::string getArrayName ( ) const
inlineinherited

Get name of array this object is stored in, or "" if not found.

Definition at line 377 of file RelationsObject.h.

◆ getArrayPointer()

TClonesArray * getArrayPointer ( ) const
inline

Returns the pointer to the store array which holds the daughter particles.

Warning
TClonesArray is dangerously easy to misuse, please avoid.

Definition at line 981 of file Particle.h.

982 {
983 if (!m_arrayPointer)
985 return m_arrayPointer;
986 }
TClonesArray * getArrayPointer() const
Returns the pointer to the raw DataStore array holding this object (protected since these arrays are ...

◆ getCharge()

double getCharge ( void  ) const

Returns particle charge.

Returns
particle charge in units of elementary charge

Definition at line 652 of file Particle.cc.

653{
654 if (TDatabasePDG::Instance()->GetParticle(m_pdgCode) == nullptr) {
655 B2ERROR("PDG=" << m_pdgCode << " ***code unknown to TDatabasePDG");
656 return 0.0;
657 }
658 return TDatabasePDG::Instance()->GetParticle(m_pdgCode)->Charge() / 3.0;
659}

◆ getCosHelicity()

double getCosHelicity ( const Particle mother = nullptr) const

Returns cosine of the helicity angle The helicity angle is defined in the rest frame of the particle as the angle between the negative momentum of the mother and.

  • the momentum of the first daughter for two body decays
  • the momentum of the photon for pi0 Dalitz decays
  • the direction perpendicular to the daughter momenta for three body decays
    Parameters
    mothermother particle, if not given the center of mass system is taken as mother frame
    Returns
    cosine of the helicity angle

Definition at line 489 of file Particle.cc.

490{
491 // boost vector to the rest frame of the particle
492 Boost boost(get4Vector().BoostToCM());
493
494 // momentum of the mother in the particle's rest frame
495 PxPyPzEVector pMother;
496 if (mother) {
497 pMother = mother->get4Vector();
498 } else {
499 static DBObjPtr<CollisionBoostVector> cmsBoost;
501 pMother.SetE(cmsMass->getMass());
502 pMother = Boost(cmsBoost->getBoost()) * pMother;
503 }
504 pMother = boost * pMother;
505
506 // momentum of the daughter (or normal vector) in the particle's rest frame
507 PxPyPzEVector pDaughter;
508 if (getNDaughters() == 2) { // two body decay
509 pDaughter = boost * getDaughter(0)->get4Vector();
510 } else if (getNDaughters() == 3) {
511 if (getPDGCode() == Const::pi0.getPDGCode()) { // pi0 Dalitz decay
512 for (auto& daughter : getDaughters()) {
513 if (daughter->getPDGCode() == Const::photon.getPDGCode()) {
514 pDaughter = daughter->get4Vector();
515 }
516 }
517 pDaughter = boost * pDaughter;
518 } else { // three body decay
519 PxPyPzEVector pDaughter0 = boost * getDaughter(0)->get4Vector();
520 PxPyPzEVector pDaughter1 = boost * getDaughter(1)->get4Vector();
521
522 XYZVector pDaughterNormal(pDaughter0.Vect().Cross(pDaughter1.Vect()));
523 pDaughter.SetPxPyPzE(pDaughterNormal.X(), pDaughterNormal.Y(), pDaughterNormal.Z(), 0); // energy doesn't matter
524 }
525 }
526
527 double mag2 = pMother.P2() * pDaughter.P2();
528 if (mag2 <= 0) return std::numeric_limits<double>::quiet_NaN();
529 return -pMother.Vect().Dot(pDaughter.Vect()) / sqrt(mag2);
530}
static const ParticleType pi0
neutral pion particle
Definition: Const.h:674
static const ParticleType photon
photon particle
Definition: Const.h:673
Class for accessing objects in the database.
Definition: DBObjPtr.h:21
int getPDGCode(void) const
Returns PDG code.
Definition: Particle.h:465
std::vector< Belle2::Particle * > getDaughters() const
Returns a vector of pointers to daughter particles.
Definition: Particle.cc:667
double sqrt(double a)
sqrt for double
Definition: beamHelpers.h:28

◆ getCosHelicityDaughter()

double getCosHelicityDaughter ( unsigned  iDaughter,
unsigned  iGrandDaughter = 0 
) const

Returns cosine of the helicity angle of the given daughter defined by given grand daughter.

Parameters
iDaughter0-based index of daughter particle
iGrandDaughter0-based index of grand daughter particle
Returns
cosine of the helicity angle

Definition at line 532 of file Particle.cc.

533{
534 // check existence of daughter
535 if (getNDaughters() <= iDaughter) {
536 B2ERROR("No daughter of particle 'name' with index 'iDaughter' for calculation of helicity angle"
537 << LogVar("name", getName()) << LogVar("iDaughter", iDaughter));
538 return std::numeric_limits<double>::quiet_NaN();
539 }
540
541 // boost vector to the rest frame of the daughter particle
542 const Particle* daughter = getDaughter(iDaughter);
543 Boost boost(daughter->get4Vector().BoostToCM());
544
545 // momentum of the this particle in the daughter's rest frame
546 PxPyPzEVector pMother = boost * get4Vector();
547
548 // check existence of grand daughter
549 if (daughter->getNDaughters() <= iGrandDaughter) {
550 B2ERROR("No grand daughter of daughter 'iDaughter' of particle 'name' with index 'iGrandDaughter' for calculation of helicity angle"
551 << LogVar("name", getName()) << LogVar("iDaughter", iDaughter) << LogVar("iGrandDaughter", iGrandDaughter));
552 return std::numeric_limits<double>::quiet_NaN();
553 }
554
555 // momentum of the grand daughter in the daughter's rest frame
556 PxPyPzEVector pGrandDaughter = boost * daughter->getDaughter(iGrandDaughter)->get4Vector();
557
558 double mag2 = pMother.P2() * pGrandDaughter.P2();
559 if (mag2 <= 0) return std::numeric_limits<double>::quiet_NaN();
560 return -pMother.Vect().Dot(pGrandDaughter.Vect()) / sqrt(mag2);
561}

◆ getDaughter()

const Particle * getDaughter ( unsigned  i) const

Returns a pointer to the i-th daughter particle.

Parameters
i0-based index of daughter particle
Returns
Pointer to i-th daughter particles

Definition at line 661 of file Particle.cc.

662{
663 if (i >= getNDaughters()) return nullptr;
664 return static_cast<Particle*>(getArrayPointer()->At(m_daughterIndices[i]));
665}

◆ getDaughterIndices()

const std::vector< int > & getDaughterIndices ( ) const
inline

Returns a vector of store array indices of daughter particles.

Returns
vector of store array indices of daughter particle

Definition at line 756 of file Particle.h.

757 {
758 return m_daughterIndices;
759 }

◆ getDaughterProperties()

const std::vector< int > & getDaughterProperties ( ) const
inline

Returns a vector of properties of daughter particles.

Returns
vector of daughter properties

Definition at line 765 of file Particle.h.

766 {
768 }

◆ getDaughters()

std::vector< Belle2::Particle * > getDaughters ( ) const

Returns a vector of pointers to daughter particles.

Returns
vector of pointers to daughter particles

Definition at line 667 of file Particle.cc.

668{
669 const unsigned int nDaughters = getNDaughters();
670 std::vector<Particle*> daughters(nDaughters);
671
672 const TClonesArray* array = getArrayPointer();
673 for (unsigned i = 0; i < nDaughters; i++)
674 daughters[i] = static_cast<Particle*>(array->At(m_daughterIndices[i]));
675
676 return daughters;
677}

◆ getECLCluster()

const ECLCluster * getECLCluster ( ) const

Returns the pointer to the ECLCluster object that was used to create this Particle (if ParticleType == c_ECLCluster).

Returns the pointer to the most energetic ECLCluster matched to the track (if ParticleType == c_Track). NULL pointer is returned, if the Particle has no relation to an ECLCluster (either the particle is a different type or there was no track match).

Returns
const pointer to the ECLCluster

Definition at line 975 of file Particle.cc.

976{
977 if (m_particleSource == c_ECLCluster) {
978 StoreArray<ECLCluster> eclClusters{};
979 return eclClusters[m_mdstIndex];
980 } else if (m_particleSource == c_Track) {
981 // a track may be matched to several clusters under different hypotheses
982 // take the most energetic of the c_nPhotons hypothesis as "the" cluster
983 StoreArray<Track> tracks{};
984 const ECLCluster* bestTrackMatchedCluster = nullptr;
985 double highestEnergy = -1.0;
986 // loop over all clusters matched to this track
987 for (const ECLCluster& cluster : tracks[m_mdstIndex]->getRelationsTo<ECLCluster>()) {
988 // ignore everything except the nPhotons hypothesis
989 if (!cluster.hasHypothesis(ECLCluster::EHypothesisBit::c_nPhotons))
990 continue;
991 // check if we're most energetic thus far
992 if (cluster.getEnergy(ECLCluster::EHypothesisBit::c_nPhotons) > highestEnergy) {
993 highestEnergy = cluster.getEnergy(ECLCluster::EHypothesisBit::c_nPhotons);
994 bestTrackMatchedCluster = &cluster;
995 }
996 }
997 return bestTrackMatchedCluster;
998 } else {
999 return nullptr;
1000 }
1001}
ECL cluster data.
Definition: ECLCluster.h:27
@ c_nPhotons
CR is split into n photons (N1)

◆ getECLClusterEHypothesisBit()

ECLCluster::EHypothesisBit getECLClusterEHypothesisBit ( ) const
inline

Returns the ECLCluster EHypothesisBit for this Particle.

Definition at line 1029 of file Particle.h.

1030 {
1031 const int pdg = abs(getPDGCode());
1032 if ((pdg == Const::photon.getPDGCode())
1033 or (pdg == Const::electron.getPDGCode())
1034 or (pdg == Const::muon.getPDGCode())
1035 or (pdg == Const::pion.getPDGCode())
1036 or (pdg == Const::kaon.getPDGCode())
1037 or (pdg == Const::proton.getPDGCode())
1038 or (pdg == Const::deuteron.getPDGCode())) {
1040 } else if ((pdg == Const::Klong.getPDGCode())
1041 or (pdg == Const::neutron.getPDGCode())) {
1043 } else {
1045 }
1046 }
static const ParticleType neutron
neutron particle
Definition: Const.h:675
static const ChargedStable pion
charged pion particle
Definition: Const.h:661
static const ParticleType Klong
K^0_L particle.
Definition: Const.h:678
static const ChargedStable proton
proton particle
Definition: Const.h:663
static const ChargedStable kaon
charged kaon particle
Definition: Const.h:662
static const ChargedStable deuteron
deuteron particle
Definition: Const.h:664
@ c_neutralHadron
CR is reconstructed as a neutral hadron (N2)
@ c_none
None as initializer.

◆ getECLClusterEnergy()

double getECLClusterEnergy ( ) const

Returns the energy of the ECLCluster for the particle.

The return value depends on the ECLCluster hypothesis.

Returns
energy of the ECLCluster

Definition at line 1003 of file Particle.cc.

1004{
1005 const ECLCluster* cluster = this->getECLCluster();
1006 if (!cluster) return 0;
1007 return cluster->getEnergy(this->getECLClusterEHypothesisBit());
1008}
const ECLCluster * getECLCluster() const
Returns the pointer to the ECLCluster object that was used to create this Particle (if ParticleType =...
Definition: Particle.cc:975

◆ getEffectiveMomentumScale()

double getEffectiveMomentumScale ( ) const
inline

Returns effective momentum scale which is the product of the momentum scaling and smearing factors.

Returns
momentum scaling factor

Definition at line 634 of file Particle.h.

635 {
636 return m_momentumScale;
637 }

◆ getEnergy()

double getEnergy ( ) const
inline

Returns total energy.

Returns
total energy

Definition at line 555 of file Particle.h.

556 {
561 }
double m_energyLossCorrection
energy loss correction.
Definition: Particle.h:1091

◆ getEnergyLossCorrection()

double getEnergyLossCorrection ( ) const
inline

Returns Energy Loss Correction.

Returns
Energy Loss Correction

Definition at line 643 of file Particle.h.

644 {
646 }

◆ getExtraInfo()

double getExtraInfo ( const std::string &  name) const

Return given value if set.

throws std::runtime_error if variable is not set.

Definition at line 1373 of file Particle.cc.

1374{
1375 if (m_extraInfo.empty())
1376 throw std::runtime_error(std::string("getExtraInfo: Value '") + name + "' not found in Particle!");
1377
1378 //get index for name
1379 const auto mapID = (unsigned int)m_extraInfo[0];
1381 if (!extraInfoMap) {
1382 B2FATAL("ParticleExtraInfoMap not available, but needed for storing extra info in Particle!");
1383 }
1384 unsigned int index = extraInfoMap->getIndex(mapID, name);
1385 if (index == 0 or index >= m_extraInfo.size()) //actually indices start at 1
1386 throw std::runtime_error(std::string("getExtraInfo: Value '") + name + "' not found in Particle!");
1387
1388 return m_extraInfo[index];
1389
1390}

◆ getExtraInfoMap()

int getExtraInfoMap ( ) const
inline

Return the id of the associated ParticleExtraInfoMap or -1 if no map is set.

Definition at line 949 of file Particle.h.

950 {
951 return !m_extraInfo.empty() ? m_extraInfo[0] : -1;
952 }

◆ getExtraInfoNames()

std::vector< std::string > getExtraInfoNames ( ) const

get a list of the extra info names

Definition at line 1259 of file Particle.cc.

1260{
1261 std::vector<std::string> out;
1262 if (!m_extraInfo.empty()) {
1264 if (!extraInfoMap)
1265 B2FATAL("ParticleExtraInfoMap not available, but needed for storing extra info in Particle!");
1266 const ParticleExtraInfoMap::IndexMap& map = extraInfoMap->getMap(m_extraInfo[0]);
1267 for (auto const& ee : map) out.push_back(ee.first);
1268 }
1269 return out;
1270}
std::map< std::string, unsigned int > IndexMap
string -> index map.

◆ getExtraInfoSize()

unsigned int getExtraInfoSize ( ) const
inline

Return the size of the extra info array.

Definition at line 955 of file Particle.h.

956 {
957 return m_extraInfo.size();
958 }

◆ getFinalStateDaughters()

std::vector< const Belle2::Particle * > getFinalStateDaughters ( ) const

Returns a vector of pointers to Final State daughter particles.

Returns
vector of pointers to final state daughter particles

Definition at line 679 of file Particle.cc.

680{
681 std::vector<const Particle*> fspDaughters;
682 fillFSPDaughters(fspDaughters);
683
684 return fspDaughters;
685}

◆ getFlavorType()

EFlavorType getFlavorType ( ) const
inline

Returns flavor type of the decay (for FS particles: flavor type of particle)

Returns
flavor type (0=unflavored, 1=flavored)

Definition at line 480 of file Particle.h.

481 {
482 return m_flavorType;
483 }

◆ getInfo()

std::string getInfo ( ) const
inlineinherited

Return a short summary of this object's contents in raw text format.

Returns the contents of getInfoHTML() while translating line-breaks etc.

Note
: You don't need to implement this function (it's not virtual), getInfoHTML() is enough.

Definition at line 370 of file RelationsObject.h.

371 {
373 }
virtual std::string getInfoHTML() const
Return a short summary of this object's contents in HTML format.
std::string htmlToPlainText(const std::string &html)
See RelationsObject::getInfo()

◆ getInfoHTML()

std::string getInfoHTML ( ) const
overridevirtual

Return a short summary of this object's contents in HTML format.

Reimplemented from RelationsInterface< BASE >.

Definition at line 1272 of file Particle.cc.

1273{
1274 std::stringstream stream;
1275 stream << std::setprecision(4);
1276 stream << "<b>collection</b>=" << getArrayName();
1277 stream << "<br>";
1278 stream << " <b>PDGCode</b>=" << m_pdgCode;
1279 stream << " <b>Charge</b>=" << getCharge();
1280 stream << " <b>PDGMass</b>=" << getPDGMass();
1281 stream << "<br>";
1282 stream << " <b>flavorType</b>=" << m_flavorType;
1283 stream << " <b>particleSource</b>=" << m_particleSource;
1284 stream << " <b>particleTypeUsedForFit</b>=" << m_pdgCodeUsedForFit;
1285 stream << "<br>";
1286
1287 stream << " <b>mdstIndex</b>=" << m_mdstIndex;
1288 stream << " <b>arrayIndex</b>=" << getArrayIndex();
1289 stream << " <b>identifier</b>=" << m_identifier;
1290 stream << " <b>daughterIndices</b>: ";
1291 for (int daughterIndex : m_daughterIndices) {
1292 stream << daughterIndex << ", ";
1293 }
1294 if (m_daughterIndices.empty()) stream << " (none)";
1295 stream << "<br>";
1296
1297 if (!m_daughterIndices.empty()) {
1298 stream << " <b>daughter PDGCodes</b>: ";
1299 for (unsigned i = 0; i < m_daughterIndices.size(); i++) {
1300 const Particle* p = getDaughter(i);
1301 if (p) {stream << p->getPDGCode() << ", ";}
1302 else {stream << "?, ";}
1303 }
1304 stream << "<br>";
1305 }
1306
1307 stream << " <b>mass</b>=" << m_mass;
1308 stream << "<br>";
1309
1310 stream << " <b>momentum</b>=" << HTML::getString(ROOT::Math::XYZVector(getPx(), getPy(), getPz()));
1311 stream << " <b>p</b>=" << getP();
1312 stream << "<br>";
1313
1314 stream << " <b>momentum scaling factor</b>=" << m_momentumScale;
1315 stream << "<br>";
1316
1317 stream << " <b>Energy loss correction</b>=" << m_energyLossCorrection;
1318 stream << "<br>";
1319
1320 stream << " <b>position</b>=" << HTML::getString(ROOT::Math::XYZVector(m_x, m_y, m_z));
1321 stream << "<br>";
1322
1323 stream << " <b>p-value of fit</b> (if done): ";
1324 stream << m_pValue;
1325 stream << "<br>";
1326
1327 stream << " <b>error matrix</b> (px, py, pz, E, x, y ,z):<br>";
1329
1330 stream << " <b>extra info</b>=( ";
1331 if (!m_extraInfo.empty()) {
1333 if (!extraInfoMap) {
1334 B2FATAL("ParticleExtraInfoMap not available, but needed for storing extra info in Particle!");
1335 }
1336 const ParticleExtraInfoMap::IndexMap& map = extraInfoMap->getMap(m_extraInfo[0]);
1337 const unsigned int nVars = m_extraInfo.size();
1338 for (const auto& pair : map) {
1339 if (pair.second < nVars) {
1340 stream << pair.first << "=" << m_extraInfo[pair.second] << " ";
1341 }
1342 }
1343
1344 }
1345 stream << ") " << "<br>";
1346
1347 return stream.str();
1348}
double getPx() const
Returns x component of momentum.
Definition: Particle.h:607
double getPz() const
Returns z component of momentum.
Definition: Particle.h:625
double getPy() const
Returns y component of momentum.
Definition: Particle.h:616
double getPDGMass(void) const
Returns uncertainty on the invariant mass (requires valid momentum error matrix)
Definition: Particle.cc:634
double getCharge(void) const
Returns particle charge.
Definition: Particle.cc:652
TMatrixFSym getMomentumVertexErrorMatrix() const
Returns 7x7 error matrix.
Definition: Particle.cc:450
double getP() const
Returns momentum magnitude (same as getMomentumMagnitude but with shorter name)
Definition: Particle.h:598
int m_identifier
Identifier that can be used to identify whether the particle is unique or is a copy or representation...
Definition: Particle.h:1113
std::string getArrayName() const
Get name of array this object is stored in, or "" if not found.
std::string getString(const TMatrixFBase &matrix, int precision=2, bool color=true)
get HTML table representing a matrix.
Definition: HTML.cc:24

◆ getKink()

const Kink * getKink ( ) const

Returns the pointer to the Kink object that was used to create this Particle (if ParticleType == c_Kink).

NULL pointer is returned if the Particle was not made from a Kink.

Returns
const pointer to the Kink

Definition at line 965 of file Particle.cc.

966{
967 if (m_particleSource == c_Kink) {
968 StoreArray<Kink> kinks{};
969 return kinks[m_mdstIndex];
970 } else {
971 return nullptr;
972 }
973}

◆ getKLMCluster()

const KLMCluster * getKLMCluster ( ) const

Returns the pointer to the KLMCluster object that was used to create this Particle (ParticleType == c_KLMCluster).

Returns the pointer to the KLMCluster object associated to this Particle if ParticleType == c_Track. NULL pointer is returned, if the Particle has no relation to the KLMCluster.

Returns
const pointer to the KLMCluster

Definition at line 1010 of file Particle.cc.

1011{
1012 if (m_particleSource == c_KLMCluster) {
1013 StoreArray<KLMCluster> klmClusters{};
1014 return klmClusters[m_mdstIndex];
1015 } else if (m_particleSource == c_Track) {
1016 // If there is an associated KLMCluster, it's the closest one
1017 StoreArray<Track> tracks{};
1018 const KLMCluster* klmCluster = tracks[m_mdstIndex]->getRelatedTo<KLMCluster>();
1019 return klmCluster;
1020 } else {
1021 return nullptr;
1022 }
1023}
KLM cluster data.
Definition: KLMCluster.h:28

◆ getMass()

double getMass ( ) const
inline

Returns invariant mass (= nominal for FS particles)

Returns
invariant mass

Definition at line 527 of file Particle.h.

528 {
529 return m_mass;
530 }

◆ getMCParticle()

const MCParticle * getMCParticle ( ) const

Returns the pointer to the MCParticle object that was used to create this Particle (ParticleType == c_MCParticle).

Returns the best MC match for this particle (if ParticleType == c_Track or c_ECLCluster or c_KLMCluster) NULL pointer is returned, if the Particle was not made from MCParticle or not matched.

Returns
const pointer to the MCParticle

Definition at line 1026 of file Particle.cc.

1027{
1028 if (m_particleSource == c_MCParticle) {
1029 StoreArray<MCParticle> mcParticles{};
1030 return mcParticles[m_mdstIndex];
1031 } else {
1032 const MCParticle* related = this->getRelated<MCParticle>();
1033 if (related)
1034 return related;
1035 }
1036 return nullptr;
1037}
A Class to store the Monte Carlo particle information.
Definition: MCParticle.h:32

◆ getMdstArrayIndex()

unsigned getMdstArrayIndex ( void  ) const
inline

Returns 0-based index of MDST store array object (0 for composite particles)

Returns
index of MDST store array object

Definition at line 498 of file Particle.h.

499 {
500 return m_mdstIndex;
501 }

◆ getMdstArrayIndices()

std::vector< int > getMdstArrayIndices ( EParticleSourceObject  type) const

Returns a vector of StoreArray indices of given MDST dataobjects.

Parameters
typeEParticleSourceObject corresponding to a given MDST dataobject
Returns
vector of StoreArray indices of a given MDST dataobjects

Definition at line 695 of file Particle.cc.

696{
697 std::vector<int> mdstIndices;
698 for (const Particle* fsp : getFinalStateDaughters()) {
699 // is this FSP daughter constructed from given MDST source
700 if (fsp->getParticleSource() == source)
701 mdstIndices.push_back(fsp->getMdstArrayIndex());
702 }
703 return mdstIndices;
704}
std::vector< const Belle2::Particle * > getFinalStateDaughters() const
Returns a vector of pointers to Final State daughter particles.
Definition: Particle.cc:679

◆ getMdstSource()

int getMdstSource ( ) const

Returns unique identifier of final state particle (needed in particle combiner)

Returns
unique identifier of final state particle

Definition at line 399 of file Particle.cc.

400{
401 // Is identifier already set
402 if (m_identifier > -1)
403 return m_identifier + (m_particleSource << 24);
404
405 // Identifier is not set.
406 int identifier = 0;
407 if (m_particleSource == c_ECLCluster) {
408 const ECLCluster* cluster = this->getECLCluster();
409 if (cluster) {
410 identifier = cluster->getUniqueClusterId();
411 } else {
412 B2ERROR("Particle is of type = ECLCluster has identifier not set and no relation to ECLCluster.\n"
413 "This has happen because old microDST is analysed with newer version of software.");
414 }
415 } else {
416 identifier = m_mdstIndex;
417 }
418
419 return identifier + (m_particleSource << 24);
420}

◆ getMomentum()

ROOT::Math::XYZVector getMomentum ( ) const
inline

Returns momentum vector.

Returns
momentum vector

Definition at line 580 of file Particle.h.

581 {
582 return m_momentumScale * getMomentumLossCorrectionFactor() * ROOT::Math::XYZVector(m_px, m_py, m_pz);
583 };

◆ getMomentumErrorMatrix()

TMatrixFSym getMomentumErrorMatrix ( ) const

Returns the 4x4 momentum error matrix.

Returns
The 4x4 momentum error matrix (order: px,py,pz,E)

Definition at line 465 of file Particle.cc.

466{
467 TMatrixFSym mom;
468 const TMatrixFSym& full = getMomentumVertexErrorMatrix();
469
470 // get 4x4 (momentum) submatrix from the full error matrix
471 // momentum related elements are in [0,...,3]x[0,...,3] block
472 full.GetSub(0, 3, mom, "S");
473
474 return mom;
475}

◆ getMomentumLossCorrectionFactor()

double getMomentumLossCorrectionFactor ( ) const
inline

Returns effect of energy correction on the particle momentum.

Returns
momentum change

Definition at line 326 of file Particle.h.

327 {
328 if (m_energyLossCorrection == 0.0) {
329 return 1.0;
330 }
331 double origP = m_momentumScale * sqrt(m_px * m_px + m_py * m_py + m_pz * m_pz);
332 if (origP == 0.0) {
333 return 1.0;
334 }
335 double origE = sqrt(origP * origP + m_mass * m_mass);
336
337 double newP = sqrt((origE - m_energyLossCorrection) * (origE - m_energyLossCorrection) - m_mass * m_mass);
338 return newP / origP;
339 }

◆ getMomentumMagnitude()

double getMomentumMagnitude ( ) const
inline

Returns momentum magnitude.

Returns
momentum magnitude

Definition at line 589 of file Particle.h.

590 {
591 return getP();
592 };

◆ getMomentumVertexErrorMatrix()

TMatrixFSym getMomentumVertexErrorMatrix ( ) const

Returns 7x7 error matrix.

Returns
7x7 error matrix (order: px,py,pz,E,x,y,z)

Definition at line 450 of file Particle.cc.

451{
452 TMatrixFSym m(c_DimMatrix);
453
454 int element = 0;
455 for (int irow = 0; irow < c_DimMatrix; irow++) {
456 for (int icol = irow; icol < c_DimMatrix; icol++) {
457 m(irow, icol) = m(icol, irow) = m_errMatrix[element];
458 element++;
459 }
460 }
461 return m;
462}
double m_errMatrix[c_SizeMatrix]
error matrix (1D representation)
Definition: Particle.h:1095

◆ getMostLikelyTrackFitResult()

std::pair< Const::ChargedStable, const TrackFitResult * > getMostLikelyTrackFitResult ( ) const

For a (track-based) particle, returns the charged stable mass hypothesis associated to the most probable TrackFitResult, and the TrackFitResult itself.

Definition at line 1482 of file Particle.cc.

1483{
1484
1485 const auto track = this->getTrack();
1486
1487 if (!track) {
1488 return std::make_pair(Const::ChargedStable(std::abs(this->getPDGCode())), nullptr);
1489 }
1490
1491 // Find the track fit with the highest pValue
1492 auto trackFitResults = track->getTrackFitResults();
1493 auto it_maxPValue = std::max_element(std::begin(trackFitResults), std::end(trackFitResults),
1494 [](auto tfrAndM1, auto tfrAndM2) {return tfrAndM1.second->getPValue() < tfrAndM2.second->getPValue();});
1495
1496 return trackFitResults[std::distance(std::begin(trackFitResults), it_maxPValue)];
1497
1498}
Provides a type-safe way to pass members of the chargedStableSet set.
Definition: Const.h:589
const Track * getTrack() const
Returns the pointer to the Track object that was used to create this Particle (ParticleType == c_Trac...
Definition: Particle.cc:915

◆ getName()

std::string getName ( ) const
overridevirtual

Return name of this particle.

Reimplemented from RelationsInterface< BASE >.

Definition at line 1249 of file Particle.cc.

1250{
1251 return TDatabasePDG::Instance()->GetParticle(m_pdgCode)->GetName();
1252}

◆ getNDaughters()

unsigned getNDaughters ( void  ) const
inline

Returns number of daughter particles.

Returns
number of daughter particles

Definition at line 747 of file Particle.h.

748 {
749 return m_daughterIndices.size();
750 }

◆ getP()

double getP ( ) const
inline

Returns momentum magnitude (same as getMomentumMagnitude but with shorter name)

Returns
momentum magnitude

Definition at line 598 of file Particle.h.

599 {
601 };

◆ getParticleFromGeneralizedIndexString()

const Particle * getParticleFromGeneralizedIndexString ( const std::string &  generalizedIndex) const

Explores the decay tree of the particle and returns the (grand^n)daughter identified by a generalized index.

The generalized index consists of a colon-separated list of daughter indexes, starting from the root particle: 0:1:3 identifies the fourth daughter (3) of the second daughter (1) of the first daughter (0) of the mother particle.

Parameters
generalizedIndexthe generalized index of the particle to be returned
Returns
a particle in the decay tree of the root particle.

Definition at line 1040 of file Particle.cc.

1041{
1042 // Split the generalizedIndex string in a vector of strings.
1043 std::vector<std::string> generalizedIndexes;
1044 boost::split(generalizedIndexes, generalizedIndex, boost::is_any_of(":"));
1045
1046 if (generalizedIndexes.empty()) {
1047 B2WARNING("Generalized index of daughter particle is empty. Skipping.");
1048 return nullptr;
1049 }
1050
1051 // To explore a decay tree of unknown depth, we need a place to store
1052 // both the root particle and the daughter particle at each iteration
1053 const Particle* dauPart =
1054 nullptr; // This will be eventually returned
1055 const Particle* currentPart = this; // This is the root particle of the next iteration
1056
1057 // Loop over the generalizedIndexes until you get to the particle you want
1058 for (auto& indexString : generalizedIndexes) {
1059 // indexString is a string. First try to convert it into an int
1060 int dauIndex = 0;
1061 try {
1062 dauIndex = Belle2::convertString<int>(indexString);
1063 } catch (std::invalid_argument&) {
1064 B2WARNING("Found the string " << indexString << "instead of a daughter index.");
1065 return nullptr;
1066 }
1067
1068 // Check that the daughter index is smaller than the number of daughters of the current root particle
1069 if (dauIndex >= int(currentPart->getNDaughters()) or dauIndex < 0) {
1070 B2WARNING("Daughter index out of range" << LogVar("Daughter index", dauIndex));
1071 B2WARNING("Trying to access non-existing particle.");
1072 return nullptr;
1073 } else {
1074 dauPart = currentPart->getDaughter(dauIndex); // Pick the particle indicated by the generalizedIndex
1075 currentPart = dauPart;
1076 }
1077 }
1078 return dauPart;
1079}

◆ getParticleSource()

EParticleSourceObject getParticleSource ( ) const
inline

Returns particle source as defined with enum EParticleSourceObject.

Returns
particle type

Definition at line 489 of file Particle.h.

490 {
491 return m_particleSource;
492 }

◆ getPDGCode()

int getPDGCode ( void  ) const
inline

Returns PDG code.

Returns
PDG code

Definition at line 465 of file Particle.h.

466 {
467 return m_pdgCode;
468 }

◆ getPDGCodeUsedForFit()

int getPDGCodeUsedForFit ( ) const
inline

Return the always positive PDG code which was used for the track fit (if there was a track fit) of this particle.

This can be different than the Particle's PDG id as not all mass hypothesis are fitted during the reconstruction.

Definition at line 993 of file Particle.h.

994 {
995 return std::abs(m_pdgCodeUsedForFit);
996 }

◆ getPDGLifetime()

double getPDGLifetime ( ) const

Returns particle nominal lifetime.

Returns
nominal lifetime [sec]

Definition at line 643 of file Particle.cc.

644{
645 if (TDatabasePDG::Instance()->GetParticle(m_pdgCode) == nullptr) {
646 B2ERROR("PDG=" << m_pdgCode << " ***code unknown to TDatabasePDG");
647 return 0.0;
648 }
649 return TDatabasePDG::Instance()->GetParticle(m_pdgCode)->Lifetime();
650}

◆ getPDGMass()

double getPDGMass ( void  ) const

Returns uncertainty on the invariant mass (requires valid momentum error matrix)

Returns
mass error Returns particle nominal mass
nominal mass

Definition at line 634 of file Particle.cc.

635{
636 if (TDatabasePDG::Instance()->GetParticle(m_pdgCode) == nullptr) {
637 B2ERROR("PDG=" << m_pdgCode << " ***code unknown to TDatabasePDG");
638 return 0.0;
639 }
640 return TDatabasePDG::Instance()->GetParticle(m_pdgCode)->Mass();
641}

◆ getPIDLikelihood()

const PIDLikelihood * getPIDLikelihood ( ) const

Returns the pointer to the PIDLikelihood object that is related to the Track, which was used to create this Particle (ParticleType == c_Track).

NULL pointer is returned, if the Particle was not made from Track or if the Track has no relation to the PIDLikelihood

Returns
const pointer to the Track

Definition at line 946 of file Particle.cc.

947{
948 if (m_particleSource == c_Track) {
949 StoreArray<Track> tracks{};
950 return tracks[m_mdstIndex]->getRelated<PIDLikelihood>();
951 } else
952 return nullptr;
953}
Class to collect log likelihoods from TOP, ARICH, dEdx, ECL and KLM aimed for output to mdst includes...
Definition: PIDLikelihood.h:29

◆ getProperty()

int getProperty ( ) const
inline

Returns particle property as a bit pattern The values are defined in the PropertyFlags enum and described in detail there.

Returns
Combination of Properties describing the particle property

Definition at line 518 of file Particle.h.

519 {
520 return m_properties;
521 }

◆ getPValue()

double getPValue ( ) const
inline

Returns chi^2 probability of fit if done or -1.

Returns
p-value of fit (nan means no fit done)

Definition at line 687 of file Particle.h.

688 {
689 return m_pValue;
690 }

◆ getPx()

double getPx ( ) const
inline

Returns x component of momentum.

Returns
x component of momentum

Definition at line 607 of file Particle.h.

608 {
610 }

◆ getPy()

double getPy ( ) const
inline

Returns y component of momentum.

Returns
y component of momentum

Definition at line 616 of file Particle.h.

617 {
619 }

◆ getPz()

double getPz ( ) const
inline

Returns z component of momentum.

Returns
z component of momentum

Definition at line 625 of file Particle.h.

626 {
628 }

◆ getRelated()

T * getRelated ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the object to or from which this object has a relation.

Template Parameters
TThe class of objects to or from which the relation points.
Parameters
nameThe name of the store array to or from which the relation points. If empty the default store array name for class T will be used. If the special name "ALL" is given all store arrays containing objects of type T are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
The first related object or a null pointer.

Definition at line 278 of file RelationsObject.h.

279 {
281 T::Class(), name, namedRelation).object);
282 }
@ c_BothSides
Combination of c_FromSide and c_ToSide.
Definition: DataStore.h:79
Belle2::RelationEntry getRelationWith(ESearchSide searchSide, const TObject *object, StoreEntry *&entry, int &index, const TClass *withClass, const std::string &withName, const std::string &namedRelation)
Get the first relation between an object and another object in a store array.
Definition: DataStore.cc:596
TObject * object
Pointer to the object.
Definition: RelationEntry.h:32

◆ getRelatedFrom()

FROM * getRelatedFrom ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the object from which this object has a relation.

Template Parameters
FROMThe class of objects from which the relation points.
Parameters
nameThe name of the store array from which the relation points. If empty the default store array name for class FROM will be used. If the special name "ALL" is given all store arrays containing objects of type FROM are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
The first related object or a null pointer.

Definition at line 263 of file RelationsObject.h.

264 {
266 m_cacheArrayIndex, FROM::Class(), name, namedRelation).object);
267 }
@ c_FromSide
Return relations/objects pointed from (to a given object).
Definition: DataStore.h:77

◆ getRelatedFromWithWeight()

std::pair< FROM *, float > getRelatedFromWithWeight ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get first related object & weight of relation pointing from an array.

Template Parameters
FROMThe class of objects from which the relation points.
Parameters
nameThe name of the store array from which the relation points. If empty the default store array name for class FROM will be used. If the special name "ALL" is given all store arrays containing objects of type FROM are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
Pair of first related object and the relation weight, or (NULL, 1.0) if none found.

Definition at line 314 of file RelationsObject.h.

316 {
318 FROM::Class(), name, namedRelation);
319 return std::make_pair(static_cast<FROM*>(entry.object), entry.weight);
320 }

◆ getRelatedTo()

TO * getRelatedTo ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the object to which this object has a relation.

Template Parameters
TOThe class of objects to which the relation points.
Parameters
nameThe name of the store array to which the relation points. If empty the default store array name for class TO will be used. If the special name "ALL" is given all store arrays containing objects of type TO are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
The first related object or a null pointer.

Definition at line 248 of file RelationsObject.h.

249 {
251 TO::Class(), name, namedRelation).object);
252 }
@ c_ToSide
Return relations/objects pointed to (from a given object).
Definition: DataStore.h:78

◆ getRelatedToWithWeight()

std::pair< TO *, float > getRelatedToWithWeight ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get first related object & weight of relation pointing to an array.

Template Parameters
TOThe class of objects to which the relation points.
Parameters
nameThe name of the store array to which the relation points. If empty the default store array name for class TO will be used. If the special name "ALL" is given all store arrays containing objects of type TO are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
Pair of first related object and the relation weight, or (NULL, 1.0) if none found.

Definition at line 297 of file RelationsObject.h.

299 {
301 TO::Class(), name, namedRelation);
302 return std::make_pair(static_cast<TO*>(entry.object), entry.weight);
303 }

◆ getRelatedWithWeight()

std::pair< T *, float > getRelatedWithWeight ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get first related object & weight of relation pointing from/to an array.

Template Parameters
TThe class of objects to or from which the relation points.
Parameters
nameThe name of the store array to or from which the relation points. If empty the default store array name for class T will be used. If the special name "ALL" is given all store arrays containing objects of type T are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
Pair of first related object and the relation weight, or (NULL, 1.0) if none found.

Definition at line 331 of file RelationsObject.h.

333 {
335 T::Class(), name, namedRelation);
336 return std::make_pair(static_cast<T*>(entry.object), entry.weight);
337 }

◆ getRelationsFrom()

RelationVector< FROM > getRelationsFrom ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the relations that point from another store array to this object.

Template Parameters
FROMThe class of objects from which the relations point.
Parameters
nameThe name of the store array from which the relations point. If empty the default store array name for class FROM will be used. If the special name "ALL" is given all store arrays containing objects of type FROM are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
A vector of relations.

Definition at line 212 of file RelationsObject.h.

214 {
216 m_cacheArrayIndex, FROM::Class(), name, namedRelation));
217 }
RelationVector< T > getRelationsWith(const std::string &name="", const std::string &namedRelation="") const
Get the relations between this object and another store array.

◆ getRelationsTo()

RelationVector< TO > getRelationsTo ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the relations that point from this object to another store array.

Template Parameters
TOThe class of objects to which the relations point.
Parameters
nameThe name of the store array to which the relations point. If empty the default store array name for class TO will be used. If the special name "ALL" is given all store arrays containing objects of type TO are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
A vector of relations.

Definition at line 197 of file RelationsObject.h.

198 {
200 m_cacheArrayIndex, TO::Class(), name, namedRelation));
201 }

◆ getRelationsWith()

RelationVector< T > getRelationsWith ( const std::string &  name = "",
const std::string &  namedRelation = "" 
) const
inlineinherited

Get the relations between this object and another store array.

Relations in both directions are returned.

Template Parameters
TThe class of objects to or from which the relations point.
Parameters
nameThe name of the store array to or from which the relations point. If empty the default store array name for class T will be used. If the special name "ALL" is given all store arrays containing objects of type T are considered.
namedRelationAdditional name for the relation, or "" for the default naming
Returns
A vector of relations.

Definition at line 230 of file RelationsObject.h.

231 {
233 m_cacheArrayIndex, T::Class(), name, namedRelation));
234 }

◆ getTrack()

const Track * getTrack ( ) const

Returns the pointer to the Track object that was used to create this Particle (ParticleType == c_Track).

NULL pointer is returned, if the Particle was not made from Track.

Returns
const pointer to the Track

Definition at line 915 of file Particle.cc.

916{
917 if (m_particleSource == c_Track) {
918 StoreArray<Track> tracks{};
919 return tracks[m_mdstIndex];
920 } else
921 return nullptr;
922}

◆ getTrackFitResult()

const TrackFitResult * getTrackFitResult ( ) const

Returns the pointer to the TrackFitResult that was used to create this Particle (ParticleType == c_Track).

NULL pointer is returned, if the Particle was not made from Track.

Returns
const pointer to the TrackFitResult

Definition at line 924 of file Particle.cc.

925{
926 // if the particle is related to a TrackFitResult then return this
927 auto* selfrelated = this->getRelatedTo<TrackFitResult>();
928 if (selfrelated && !isnan(selfrelated->getPValue()))
929 return selfrelated;
930
931 if (m_particleSource == c_Kink) {
932 StoreArray<TrackFitResult> trackFitResults{};
933 return trackFitResults[m_trackFitResultIndex];
934 }
935
936 // if not get the TFR with closest mass to this particle
937 auto* selftrack = this->getTrack();
938 if (selftrack)
939 return selftrack->getTrackFitResultWithClosestMass(
940 Belle2::Const::ChargedStable(std::abs(this->getPDGCode())));
941
942 // otherwise we're probably not a track based particle
943 return nullptr;
944}

◆ getTrackFitResultIndex()

unsigned getTrackFitResultIndex ( void  ) const
inline

Returns 0-based index of the TrackFitResult that should be associated with the Particle.

Returns
index of TrackFitResult

Definition at line 507 of file Particle.h.

508 {
510 }

◆ getV0()

const V0 * getV0 ( ) const

Returns the pointer to the V0 object that was used to create this Particle (if ParticleType == c_V0).

NULL pointer is returned if the Particle was not made from a V0.

Returns
const pointer to the V0

Definition at line 955 of file Particle.cc.

956{
957 if (m_particleSource == c_V0) {
958 StoreArray<V0> v0s{};
959 return v0s[m_mdstIndex];
960 } else {
961 return nullptr;
962 }
963}

◆ getVertex()

ROOT::Math::XYZVector getVertex ( ) const
inline

Returns vertex position (POCA for charged, IP for neutral FS particles)

Returns
vertex position

Definition at line 651 of file Particle.h.

652 {
653 return ROOT::Math::XYZVector(m_x, m_y, m_z);
654 };

◆ getVertexErrorMatrix()

TMatrixFSym getVertexErrorMatrix ( ) const

Returns the 3x3 position error sub-matrix.

Returns
The 3x3 position error matrix (order: x,y,z)

Definition at line 477 of file Particle.cc.

478{
479 TMatrixFSym pos;
480 const TMatrixFSym& full = getMomentumVertexErrorMatrix();
481
482 // get 3x3 (position) submatrix from the full error matrix
483 // vertex related elements are in [4,5,6]x[4,5,6] block
484 full.GetSub(4, 6, pos, "S");
485
486 return pos;
487}

◆ getX()

double getX ( ) const
inline

Returns x component of vertex position.

Returns
x component of vertex position

Definition at line 660 of file Particle.h.

661 {
662 return m_x;
663 }

◆ getY()

double getY ( ) const
inline

Returns y component of vertex position.

Returns
y component of vertex position

Definition at line 669 of file Particle.h.

670 {
671 return m_y;
672 }

◆ getZ()

double getZ ( ) const
inline

Returns z component of vertex position.

Returns
z component of vertex position

Definition at line 678 of file Particle.h.

679 {
680 return m_z;
681 }

◆ hasExtraInfo()

bool hasExtraInfo ( const std::string &  name) const

Return whether the extra info with the given name is set.

Definition at line 1350 of file Particle.cc.

1351{
1352 if (m_extraInfo.empty())
1353 return false;
1354
1355 //get index for name
1356 const auto mapID = (unsigned int)m_extraInfo[0];
1358 if (!extraInfoMap) {
1359 B2FATAL("ParticleExtraInfoMap not available, but needed for storing extra info in Particle!");
1360 }
1361 unsigned int index = extraInfoMap->getIndex(mapID, name);
1362 if (index == 0 or index >= m_extraInfo.size()) //actually indices start at 1
1363 return false;
1364
1365 return true;
1366}

◆ isCopyOf()

bool isCopyOf ( const Particle oParticle,
bool  doDetailedComparison = false 
) const

Returns true if this Particle and oParticle are copies of each other.

Copies are defined as: o) The decay chain of both Particles is exactly the same o) Both Particles are constructed from exactly the same final state particles

  • Examples: M1 -> (C1 -> F1 F2) (C2 -> F3 F4) M2 -> (C1 -> F1 F2) (C2 -> F3 F5) M3 -> (C1 -> F1 F2) F3 F4 M4 -> (C1 -> F1 F2) (C2 -> F3 F4) and M4 is kinematically fitted (its momentum updated)

M1 and M2 are not copies since condition 2 is not fulfilled. M1 and M3 are not copies since condition 1 is not fulfilled. M1 and M4 are copies since both conditions are fulfilled.

Parameters
oParticlepointer to other particle
doDetailedComparisonif true, this means that particles of different PDG codes, but created from the same track or cluster will be indicated as copies. Returns B2FATAL in case of comparison of c_MCParticle type to a non c_MCParticle.
Returns
true if particles are copies of each-other, otherwise false

Definition at line 782 of file Particle.cc.

783{
784 // the name of the game is to as quickly as possible determine
785 // that the Particles are not copies
786 if (this->getPDGCode() != oParticle->getPDGCode() and !doDetailedComparison)
787 return false;
788
789 unsigned nDaughters = this->getNDaughters();
790 if (nDaughters != oParticle->getNDaughters())
791 return false;
792
793 if (nDaughters) {
794 // has daughters: check if the decay chain is the same and it ends with
795 // the same FSPs
796 std::vector<int> thisDecayChain(nDaughters * 2);
797 std::vector<int> othrDecayChain(nDaughters * 2);
798
799 for (unsigned i = 0; i < nDaughters; i++) {
800 this->getDaughter(i)->fillDecayChain(thisDecayChain);
801 oParticle->getDaughter(i)->fillDecayChain(othrDecayChain);
802 }
803
804 // Even if the daughters have been provided in a different order in the
805 // decay string the particles should be identified as copies / duplicates.
806 // Therefore, the decay chain vectors, which contain both the pdg codes and
807 // the mdst sources, are sorted here before comparing them.
808 sort(thisDecayChain.begin(), thisDecayChain.end());
809 sort(othrDecayChain.begin(), othrDecayChain.end());
810
811 for (unsigned i = 0; i < thisDecayChain.size(); i++)
812 if (thisDecayChain[i] != othrDecayChain[i])
813 return false;
814
815 } else if (this->getMdstSource() != oParticle->getMdstSource() and !doDetailedComparison) {
816 // has no daughters: it's a FSP, compare MDST source and index
817 // Check if this or compared particle is a kink. If so, check that the particle is not a copy of daughter or mother.
818 // For consistency, return true if the daughter or mother is a copy of the target particle.
819 if (this->getParticleSource() == EParticleSourceObject::c_Kink &&
820 oParticle->getParticleSource() == EParticleSourceObject::c_Track) {
821 const Kink* kink = this->getKink();
822 const short motherTrackIndex = kink->getMotherTrackIndex();
823 const short daughterTrackIndex = kink->getDaughterTrackIndex();
824 const short trackIndex = oParticle->getTrack()->getArrayIndex();
825 if (trackIndex == motherTrackIndex || trackIndex == daughterTrackIndex)
826 return true;
827 }
828 if (this->getParticleSource() == EParticleSourceObject::c_Track &&
829 oParticle->getParticleSource() == EParticleSourceObject::c_Kink) {
830 const Kink* kink = oParticle->getKink();
831 const short motherTrackIndex = kink->getMotherTrackIndex();
832 const short daughterTrackIndex = kink->getDaughterTrackIndex();
833 const short trackIndex = this->getTrack()->getArrayIndex();
834 if (trackIndex == motherTrackIndex || trackIndex == daughterTrackIndex)
835 return true;
836 }
837 return false;
838 }
839 // Stop here if we do not want a detailed comparison
840 if (!doDetailedComparison)
841 return true;
842 //If we compare here a reconstructed Particle to a generated MCParticle
843 //it means that something went horribly wrong and we must stop
844 if ((this->getParticleSource() == EParticleSourceObject::c_MCParticle
845 and oParticle->getParticleSource() != EParticleSourceObject::c_MCParticle)
846 or (this->getParticleSource() != EParticleSourceObject::c_MCParticle
847 and oParticle->getParticleSource() == EParticleSourceObject::c_MCParticle)) {
848 B2WARNING("Something went wrong: MCParticle is being compared to a non MC Particle. Please check your script!\n"
849 " If the MCParticle <-> Particle comparison happens in the RestOfEventBuilder,\n"
850 " the Rest Of Event may contain signal side particles.");
851 return false;
852 }
853 if (this->getParticleSource() == EParticleSourceObject::c_MCParticle
854 and oParticle->getParticleSource() == EParticleSourceObject::c_MCParticle) {
855 return this->getMCParticle() == oParticle->getMCParticle();
856 }
857 if (this->getParticleSource() != oParticle->getParticleSource()) {
858 // Check if this or compared particle is a kink. If so, check that the particle is not a copy of daughter or mother.
859 // For consistency, return true if the daughter or mother is a copy of the target particle.
860 if (this->getParticleSource() == EParticleSourceObject::c_Kink &&
861 oParticle->getParticleSource() == EParticleSourceObject::c_Track) {
862 const Kink* kink = this->getKink();
863 const short motherTrackIndex = kink->getMotherTrackIndex();
864 const short daughterTrackIndex = kink->getDaughterTrackIndex();
865 const short trackIndex = oParticle->getTrack()->getArrayIndex();
866 if (trackIndex == motherTrackIndex || trackIndex == daughterTrackIndex)
867 return true;
868 }
869 if (this->getParticleSource() == EParticleSourceObject::c_Track &&
870 oParticle->getParticleSource() == EParticleSourceObject::c_Kink) {
871 const Kink* kink = oParticle->getKink();
872 const short motherTrackIndex = kink->getMotherTrackIndex();
873 const short daughterTrackIndex = kink->getDaughterTrackIndex();
874 const short trackIndex = this->getTrack()->getArrayIndex();
875 if (trackIndex == motherTrackIndex || trackIndex == daughterTrackIndex)
876 return true;
877 }
878 return false;
879 }
880 if (this->getMdstSource() == oParticle->getMdstSource()) {
881 return true;
882 }
883 if (this->getTrack() && oParticle->getTrack() &&
884 this->getTrack()->getArrayIndex() != oParticle->getTrack()->getArrayIndex()) {
885 return false;
886 }
887 if (this->getKLMCluster() && oParticle->getKLMCluster()
888 && this->getKLMCluster()->getArrayIndex() != oParticle->getKLMCluster()->getArrayIndex()) {
889 return false;
890 }
891
892 // It can be a bit more complicated for ECLClusters as we might also have to ensure they are connected-region unique
893 if (this->getECLCluster() && oParticle->getECLCluster()
894 && this->getECLCluster()->getArrayIndex() != oParticle->getECLCluster()->getArrayIndex()) {
895
896 // if either is a track then they must be different
897 if (this->getECLCluster()->isTrack() or oParticle->getECLCluster()->isTrack())
898 return false;
899
900 // we cannot combine two particles of different hypotheses from the same
901 // connected region (as their energies overlap)
903 return false;
904
905 // in the rare case that both are neutral and the hypotheses are different,
906 // we must also check that they are from different connected regions
907 // otherwise they come from the "same" underlying ECLShower
908 if (this->getECLCluster()->getConnectedRegionId() != oParticle->getECLCluster()->getConnectedRegionId())
909 return false;
910 }
911 return true;
912
913}
bool isTrack() const
Return true if the cluster matches with track.
Definition: ECLCluster.h:235
int getConnectedRegionId() const
Return connected region id.
Definition: ECLCluster.h:250
Object holding information for Kinks.
Definition: Kink.h:32
short getDaughterTrackIndex() const
Get index of the daughter Track (it is the same as mother's in case of track splitting).
Definition: Kink.h:73
short getMotherTrackIndex() const
Get index of the mother Track.
Definition: Kink.h:67
const KLMCluster * getKLMCluster() const
Returns the pointer to the KLMCluster object that was used to create this Particle (ParticleType == c...
Definition: Particle.cc:1010
const MCParticle * getMCParticle() const
Returns the pointer to the MCParticle object that was used to create this Particle (ParticleType == c...
Definition: Particle.cc:1026
const Kink * getKink() const
Returns the pointer to the Kink object that was used to create this Particle (if ParticleType == c_Ki...
Definition: Particle.cc:965
EParticleSourceObject getParticleSource() const
Returns particle source as defined with enum EParticleSourceObject.
Definition: Particle.h:489

◆ isMostLikely()

bool isMostLikely ( ) const

Returns true if the (track-based) particle is created with its most likely mass hypothesis based on PID likelihood.

Definition at line 1475 of file Particle.cc.

1476{
1477 const PIDLikelihood* likelihood = Particle::getPIDLikelihood();
1478 if (likelihood) return likelihood->getMostLikely().getPDGCode() == std::abs(m_pdgCode);
1479 else return false;
1480}
Const::ChargedStable getMostLikely(const double *fractions=nullptr, Const::PIDDetectorSet set=Const::PIDDetectorSet::set()) const
Return most likely particle among chargedStableSet; if prior fractions not given equal prior probabil...
const PIDLikelihood * getPIDLikelihood() const
Returns the pointer to the PIDLikelihood object that is related to the Track, which was used to creat...
Definition: Particle.cc:946

◆ isMostLikelyTrackFitResult()

bool isMostLikelyTrackFitResult ( ) const

Returns true if the (track-based) particle is created with its most likely mass hypothesis based on TrackFitResult.

Definition at line 1500 of file Particle.cc.

1501{
1502 const auto trackFit = this->getTrackFitResult();
1503 if (!trackFit) return false;
1504
1505 return (trackFit == this->getMostLikelyTrackFitResult().second);
1506}
std::pair< Const::ChargedStable, const TrackFitResult * > getMostLikelyTrackFitResult() const
For a (track-based) particle, returns the charged stable mass hypothesis associated to the most proba...
Definition: Particle.cc:1482
const TrackFitResult * getTrackFitResult() const
Returns the pointer to the TrackFitResult that was used to create this Particle (ParticleType == c_Tr...
Definition: Particle.cc:924

◆ overlapsWith()

bool overlapsWith ( const Particle oParticle) const

Returns true if final state ancestors of oParticle overlap.

Parameters
oParticlepointer to particle
Returns
true if overlap, otherwise false

Definition at line 767 of file Particle.cc.

768{
769 // obtain vectors of daughter final state particles
770 std::vector<const Particle*> thisFSPs = this->getFinalStateDaughters();
771 std::vector<const Particle*> otherFSPs = oParticle->getFinalStateDaughters();
772
773 // check if they share any of the FSPs
774 for (auto& thisFSP : thisFSPs)
775 for (auto& otherFSP : otherFSPs)
776 if (thisFSP->getMdstSource() == otherFSP->getMdstSource())
777 return true;
778
779 return false;
780}

◆ print()

void print ( ) const

Prints the contents of a Particle object to standard output.

Definition at line 1254 of file Particle.cc.

1255{
1256 B2INFO(getInfo());
1257}
std::string getInfo() const
Return a short summary of this object's contents in raw text format.

◆ removeDaughter()

void removeDaughter ( const Particle daughter,
const bool  updateType = true 
)

Removes index of daughter from daughters index array.

Parameters
daughterpointer to the daughter particle
updateTypebool whether particle type should be updated if last daughter was removed

Definition at line 718 of file Particle.cc.

719{
720 if (getNDaughters() == 0)
721 return;
722
723 for (unsigned i = 0; i < getNDaughters(); i++) {
724 if (m_daughterIndices[i] == daughter->getArrayIndex()) {
725 m_daughterIndices.erase(m_daughterIndices.begin() + i);
727 i--;
728 }
729 }
730
731 if (getNDaughters() == 0 and updateType)
732 m_particleSource = c_Undefined;
733}

◆ removeExtraInfo()

void removeExtraInfo ( )

Remove all stored extra info fields.

Definition at line 1368 of file Particle.cc.

1369{
1370 m_extraInfo.clear();
1371}

◆ replaceDaughter()

bool replaceDaughter ( const Particle oldDaughter,
Particle newDaughter 
)

Replace index of given daughter with new daughter, return true if a replacement is made.

Parameters
oldDaughterpointer to the daughter that will be removed
newDaughterpointer to the particle that will be added as a daughter

Definition at line 735 of file Particle.cc.

736{
737 int index = oldDaughter->getArrayIndex();
738
739 for (unsigned i = 0; i < getNDaughters(); i++) {
740 if (m_daughterIndices[i] == index) {
741 auto ite_index = m_daughterIndices.erase(m_daughterIndices.begin() + i);
742 m_daughterIndices.insert(ite_index, newDaughter->getArrayIndex());
743 auto ite_property = m_daughterProperties.erase(m_daughterProperties.begin() + i);
744 m_daughterProperties.insert(ite_property, Particle::PropertyFlags::c_Ordinary);
745
746 newDaughter->writeExtraInfo("original_index", index);
747 return true;
748 }
749 }
750 return false;
751}
void writeExtraInfo(const std::string &name, const double value)
Sets the user defined extraInfo.
Definition: Particle.cc:1392

◆ replaceDaughterRecursively()

bool replaceDaughterRecursively ( const Particle oldDaughter,
Particle newDaughter 
)

Apply replaceDaughter to all Particles in the decay tree by looping recursively through it, return true if a replacement is made.

Parameters
oldDaughterpointer to the daughter that will be removed
newDaughterpointer to the particle that will be added as a daughter

Definition at line 753 of file Particle.cc.

754{
755 bool isReplaced = this->replaceDaughter(oldDaughter, newDaughter);
756 if (isReplaced)
757 return true;
758 for (auto& daughter : this->getDaughters()) {
759 isReplaced = daughter->replaceDaughterRecursively(oldDaughter, newDaughter);
760 if (isReplaced)
761 return true;
762 }
763 return false;
764}
bool replaceDaughter(const Particle *oldDaughter, Particle *newDaughter)
Replace index of given daughter with new daughter, return true if a replacement is made.
Definition: Particle.cc:735

◆ resetErrorMatrix()

void resetErrorMatrix ( )
private

Resets 7x7 error matrix All elements are set to 0.0.

Definition at line 1163 of file Particle.cc.

1164{
1165 for (double& i : m_errMatrix)
1166 i = 0.0;
1167}

◆ resetJacobiMatrix()

void resetJacobiMatrix ( )
private

Resets 4x6 error matrix All elements are set to 0.0.

Definition at line 1169 of file Particle.cc.

1170{
1171 for (double& i : m_jacobiMatrix)
1172 i = 0.0;
1173}
double m_jacobiMatrix[c_SizeMatrix]
error matrix (1D representation)
Definition: Particle.h:1096

◆ set4Vector()

void set4Vector ( const ROOT::Math::PxPyPzEVector &  p4)
inline

Sets Lorentz vector.

Parameters
p4Lorentz vector

Definition at line 282 of file Particle.h.

283 {
284 m_px = p4.Px();
285 m_py = p4.Py();
286 m_pz = p4.Pz();
287 m_mass = p4.M();
288 }

◆ set4VectorDividingByMomentumScaling()

void set4VectorDividingByMomentumScaling ( const ROOT::Math::PxPyPzEVector &  p4)
inline

Sets Lorentz vector dividing by the momentum scaling factor.

Parameters
p4Lorentz vector

Definition at line 294 of file Particle.h.

295 {
296 m_px = p4.Px() / m_momentumScale;
297 m_py = p4.Py() / m_momentumScale;
298 m_pz = p4.Pz() / m_momentumScale;
299 m_mass = p4.M();
300 }

◆ setEnergyLossCorrection()

void setEnergyLossCorrection ( double  energyLossCorrection)
inline

Sets Energy loss correction.

Parameters
energyLossCorrectionCorrection factor

Definition at line 317 of file Particle.h.

318 {
319 m_energyLossCorrection = energyLossCorrection;
320 }

◆ setExtraInfo()

void setExtraInfo ( const std::string &  name,
double  value 
)

Sets the user-defined data of given name to the given value.

throws std::runtime_error if variable isn't set.

Definition at line 1401 of file Particle.cc.

1402{
1403 if (m_extraInfo.empty())
1404 throw std::runtime_error(std::string("setExtraInfo: Value '") + name + "' not found in Particle!");
1405
1406 //get index for name
1407 const auto mapID = (unsigned int)m_extraInfo[0];
1409 if (!extraInfoMap) {
1410 B2FATAL("ParticleExtraInfoMap not available, but needed for storing extra info in Particle!");
1411 }
1412 unsigned int index = extraInfoMap->getIndex(mapID, name);
1413 if (index == 0 or index >= m_extraInfo.size()) //actually indices start at 1
1414 throw std::runtime_error(std::string("setExtraInfo: Value '") + name + "' not found in Particle!");
1415
1416 m_extraInfo[index] = value;
1417
1418}

◆ setFlavorType()

void setFlavorType ( )
private

sets m_flavorType using m_pdgCode

Definition at line 1234 of file Particle.cc.

1235{
1237 if (m_pdgCode < 0) return;
1238 if (m_pdgCode == Const::photon.getPDGCode()) {m_flavorType = c_Unflavored; return;} // gamma
1239 if (m_pdgCode == Const::Kshort.getPDGCode()) {m_flavorType = c_Unflavored; return;} // K_s
1240 if (m_pdgCode == Const::Klong.getPDGCode()) {m_flavorType = c_Unflavored; return;} // K_L
1241 if (m_pdgCode == 43) {m_flavorType = c_Unflavored; return;} // Xu0
1242 int nnn = m_pdgCode / 10;
1243 int q3 = nnn % 10; nnn /= 10;
1244 int q2 = nnn % 10; nnn /= 10;
1245 int q1 = nnn % 10;
1246 if (q1 == 0 && q2 == q3) m_flavorType = c_Unflavored; // unflavored meson
1247}
static const ParticleType Kshort
K^0_S particle.
Definition: Const.h:677

◆ setJacobiMatrix()

void setJacobiMatrix ( const TMatrixF &  jacobiMatrix)

Sets 4x6 jacobi matrix.

Parameters
jacobiMatrix4x6 momentum and vertex error matrix (order: px,py,pz,E,x,y,z)

Definition at line 437 of file Particle.cc.

438{
439 // check if provided Jacobi Matrix is of dimension 4x6
440 // if not, reset the error matrix and print warning
441 if (m.GetNrows() != 4 || m.GetNcols() != 6) {
443 B2WARNING("Jacobi Matrix is not 4x6 ");
444 return;
445 }
447}
void resetJacobiMatrix()
Resets 4x6 error matrix All elements are set to 0.0.
Definition: Particle.cc:1169
void storeJacobiMatrix(const TMatrixF &jacobiMatrix)
Stores 4x6 Jacobi matrix into private member m_jacobiMatrix.
Definition: Particle.cc:1186

◆ setMdstArrayIndex()

void setMdstArrayIndex ( const int  arrayIndex)
private

set mdst array index

Definition at line 380 of file Particle.cc.

381{
382 m_mdstIndex = arrayIndex;
383
384 // set the identifier
385 if (m_particleSource == c_ECLCluster) {
386 const ECLCluster* cluster = this->getECLCluster();
387 if (cluster) {
388 m_identifier = cluster->getUniqueClusterId();
389 } else {
390 B2ERROR("Particle is of type = ECLCluster has identifier not set and no relation to ECLCluster.\n"
391 "This has happen because old microDST is analysed with newer version of software.");
392 }
393 } else {
395 }
396}

◆ setMomentumPositionErrorMatrix()

void setMomentumPositionErrorMatrix ( const TrackFitResult trackFit)
private

Sets the momentum, position and error matrix for this particle (created from charged Track)

Definition at line 1085 of file Particle.cc.

1086{
1087 // set momentum
1088 m_px = trackFit->getMomentum().X();
1089 m_py = trackFit->getMomentum().Y();
1090 m_pz = trackFit->getMomentum().Z();
1091
1092 // set position at which the momentum is given (= POCA)
1093 setVertex(trackFit->getPosition());
1094
1095 // set Chi^2 probability
1096 m_pValue = trackFit->getPValue();
1097
1098 // set error matrix
1099 const auto cov6 = trackFit->getCovariance6();
1100 constexpr unsigned order[] = {c_X, c_Y, c_Z, c_Px, c_Py, c_Pz};
1101
1102 TMatrixFSym errMatrix(c_DimMatrix);
1103 for (int i = 0; i < 6; i++) {
1104 for (int j = i; j < 6; j++) {
1105 // although it seems to make no sense to fill all elements of the
1106 // symmetric matrix, it has to be (do not touch this code)
1107 errMatrix(order[j], order[i]) = errMatrix(order[i], order[j]) = cov6(i, j);
1108 }
1109 }
1110
1111 /*
1112 E = sqrt(px^2 + py^2 + pz^2 + m^2) thus:
1113 cov(x,E) = cov(px,x) *dE/dpx + cov(py,x) *dE/dpy + cov(pz,x) *dE/dpz
1114 cov(y,E) = cov(px,y) *dE/dpx + cov(py,y) *dE/dpy + cov(pz,y) *dE/dpz
1115 cov(z,E) = cov(px,z) *dE/dpx + cov(py,z) *dE/dpy + cov(pz,z) *dE/dpz
1116 cov(px,E) = cov(px,px)*dE/dpx + cov(px,py)*dE/dpy + cov(px,pz)*dE/dpz
1117 cov(py,E) = cov(py,px)*dE/dpx + cov(py,py)*dE/dpy + cov(py,pz)*dE/dpz
1118 cov(pz,E) = cov(pz,px)*dE/dpx + cov(pz,py)*dE/dpy + cov(pz,pz)*dE/dpz
1119 cov(E,E) = cov(px,px)*(dE/dpx)^2 + cov(py,py)*(dE/dpy)^2 + cov(pz,pz)*(dE/dpz)^2
1120 + 2*cov(px,py)*dE/dpx*dE/dpy
1121 + 2*cov(py,pz)*dE/dpy*dE/dpz
1122 + 2*cov(pz,px)*dE/dpz*dE/dpx
1123 dE/dpx = px/E etc.
1124 */
1125
1126 const double E = getEnergy();
1127 const double dEdp[] = {m_px / E, m_py / E, m_pz / E};
1128 constexpr unsigned compMom[] = {c_Px, c_Py, c_Pz};
1129 constexpr unsigned compPos[] = {c_X, c_Y, c_Z};
1130
1131 // covariances (p,E)
1132 for (unsigned int i : compMom) {
1133 double Cov = 0;
1134 for (int k = 0; k < 3; k++) {
1135 Cov += errMatrix(i, compMom[k]) * dEdp[k];
1136 }
1137 errMatrix(i, c_E) = Cov;
1138 }
1139
1140 // covariances (x,E)
1141 for (unsigned int comp : compPos) {
1142 double Cov = 0;
1143 for (int k = 0; k < 3; k++) {
1144 Cov += errMatrix(comp, compMom[k]) * dEdp[k];
1145 }
1146 errMatrix(c_E, comp) = Cov;
1147 }
1148
1149 // variance (E,E)
1150 double Cov = 0;
1151 for (int i = 0; i < 3; i++) {
1152 Cov += errMatrix(compMom[i], compMom[i]) * dEdp[i] * dEdp[i];
1153 }
1154 for (int i = 0; i < 3; i++) {
1155 int k = (i + 1) % 3;
1156 Cov += 2 * errMatrix(compMom[i], compMom[k]) * dEdp[i] * dEdp[k];
1157 }
1158 errMatrix(c_E, c_E) = Cov;
1159
1160 storeErrorMatrix(errMatrix);
1161}
R E
internal precision of FFTW codelets
void storeErrorMatrix(const TMatrixFSym &errMatrix)
Stores 7x7 error matrix into private member m_errMatrix.
Definition: Particle.cc:1175
double getPValue() const
Getter for Chi2 Probability of the track fit.
TMatrixDSym getCovariance6() const
Position and Momentum Covariance Matrix.
ROOT::Math::XYZVector getMomentum() const
Getter for vector of momentum at closest approach of track in r/phi projection.
ROOT::Math::XYZVector getPosition() const
Getter for vector of position at closest approach of track in r/phi projection.

◆ setMomentumScalingFactor()

void setMomentumScalingFactor ( double  momentumScalingFactor)
inline

Sets momentum scaling.

Parameters
momentumScalingFactorscaling factor

Definition at line 345 of file Particle.h.

346 {
347 m_momentumScalingFactor = momentumScalingFactor;
349 }
double m_momentumSmearingFactor
momentum smearing factor
Definition: Particle.h:1090
double m_momentumScalingFactor
momentum scaling factor
Definition: Particle.h:1089

◆ setMomentumSmearingFactor()

void setMomentumSmearingFactor ( double  momentumSmearingFactor)
inline

Sets momentum smearing.

Parameters
momentumSmearingFactorscaling factor

Definition at line 355 of file Particle.h.

◆ setMomentumVertexErrorMatrix()

void setMomentumVertexErrorMatrix ( const TMatrixFSym &  errMatrix)

Sets 7x7 error matrix.

Parameters
errMatrix7x7 momentum and vertex error matrix (order: px,py,pz,E,x,y,z)

Definition at line 423 of file Particle.cc.

424{
425 // check if provided Error Matrix is of dimension 7x7
426 // if not, reset the error matrix and print warning
427 if (m.GetNrows() != c_DimMatrix || m.GetNcols() != c_DimMatrix) {
429 B2WARNING("Error Matrix is not 7x7 ");
430 return;
431 }
433
434}

◆ setPDGCode()

void setPDGCode ( const int  pdg)
inline

Sets PDG code.

Parameters
pdgPDG code

Definition at line 273 of file Particle.h.

274 {
275 m_pdgCode = pdg;
276 }

◆ setProperty()

void setProperty ( const int  properties)
inline

sets m_properties

Definition at line 385 of file Particle.h.

386 {
387 m_properties = properties;
388 }

◆ setPValue()

void setPValue ( double  pValue)
inline

Sets chi^2 probability of fit.

Parameters
pValuep-value of fit

Definition at line 377 of file Particle.h.

378 {
379 m_pValue = pValue;
380 }

◆ setVertex()

void setVertex ( const ROOT::Math::XYZVector &  vertex)
inline

Sets position (decay vertex)

Parameters
vertexposition

Definition at line 306 of file Particle.h.

307 {
308 m_x = vertex.X();
309 m_y = vertex.Y();
310 m_z = vertex.Z();
311 };

◆ storeErrorMatrix()

void storeErrorMatrix ( const TMatrixFSym &  errMatrix)
private

Stores 7x7 error matrix into private member m_errMatrix.

Parameters
errMatrix7x7 error matrix

Definition at line 1175 of file Particle.cc.

1176{
1177 int element = 0;
1178 for (int irow = 0; irow < c_DimMatrix; irow++) {
1179 for (int icol = irow; icol < c_DimMatrix; icol++) {
1180 m_errMatrix[element] = m(irow, icol);
1181 element++;
1182 }
1183 }
1184}

◆ storeJacobiMatrix()

void storeJacobiMatrix ( const TMatrixF &  jacobiMatrix)
private

Stores 4x6 Jacobi matrix into private member m_jacobiMatrix.

Parameters
jacobiMatrix4x6 error matrix

Definition at line 1186 of file Particle.cc.

1187{
1188 int element = 0;
1189 for (int irow = 0; irow < 4; irow++) {
1190 for (int icol = 0; icol < 6; icol++) {
1191 m_jacobiMatrix[element] = m(irow, icol);
1192 element++;
1193 }
1194 }
1195}

◆ updateJacobiMatrix()

void updateJacobiMatrix ( )

Propagate the photon energy scaling to jacobian elements that were calculated using energy.

Definition at line 287 of file Particle.cc.

288{
289 ClusterUtils C;
290
291 const ECLCluster* cluster = this->getECLCluster();
292
293 const XYZVector clustervertex = C.GetIPPosition();
294
295 // Get Jacobi matrix.
296 TMatrixD jacobi = C.GetJacobiMatrix4x6FromCluster(cluster, clustervertex, getECLClusterEHypothesisBit());
297 storeJacobiMatrix(jacobi);
298
299 // Propagate the photon energy scaling to jacobian elements that were calculated using energy.
300 TMatrixD scaledJacobi(4, 6);
301
302 int element = 0;
303
304 for (int irow = 0; irow < 4; irow++) {
305 for (int icol = 0; icol < 6; icol++) {
306 if (icol != 0 && irow != 3) {
307 scaledJacobi(irow, icol) = m_jacobiMatrix[element] * m_momentumScale;
308 } else {
309 scaledJacobi(irow, icol) = m_jacobiMatrix[element];
310 }
311 element++;
312 }
313 }
314
315 storeJacobiMatrix(scaledJacobi);
316
317 // Get covariance matrix of IP distribution.
318 const TMatrixDSym clustervertexcovmat = C.GetIPPositionCovarianceMatrix();
319
320 // Set error matrix.
321 TMatrixDSym clustercovmat = C.GetCovarianceMatrix7x7FromCluster(cluster, clustervertexcovmat, scaledJacobi);
322 storeErrorMatrix(clustercovmat);
323}
const TMatrixDSym GetCovarianceMatrix7x7FromCluster(const ECLCluster *cluster, const TMatrixD &jacobiMatrix)
Returns 7x7 covariance matrix (px, py, pz, E, x, y, z)
const TMatrixD GetJacobiMatrix4x6FromCluster(const ECLCluster *cluster, ECLCluster::EHypothesisBit hypo)
Returns 4x6 Jacobi matrix (px, py, pz, E)
Definition: ClusterUtils.cc:54
const TMatrixDSym GetIPPositionCovarianceMatrix()
Returns default IP position covariance matrix from beam parameters.

◆ updateMass()

void updateMass ( const int  pdgCode)

Updates particle mass with the mass of the particle corresponding to the given PDG.

Parameters
pdgCodePDG code of the particle with the desired mass

Definition at line 627 of file Particle.cc.

628{
629 if (TDatabasePDG::Instance()->GetParticle(pdgCode) == nullptr)
630 B2FATAL("PDG=" << pdgCode << " ***code unknown to TDatabasePDG");
631 m_mass = TDatabasePDG::Instance()->GetParticle(pdgCode)->Mass() ;
632}

◆ updateMomentum()

void updateMomentum ( const ROOT::Math::PxPyPzEVector &  p4,
const ROOT::Math::XYZVector &  vertex,
const TMatrixFSym &  errMatrix,
double  pValue 
)
inline

Sets Lorentz vector, position, 7x7 error matrix and p-value.

Parameters
p4Lorentz vector
vertexpoint (position or vertex)
errMatrix7x7 momentum and vertex error matrix (order: px,py,pz,E,x,y,z)
pValuechi^2 probability of the fit

Definition at line 397 of file Particle.h.

401 {
402 set4Vector(p4);
403 setVertex(vertex);
405 m_pValue = pValue;
406 }
void setMomentumVertexErrorMatrix(const TMatrixFSym &errMatrix)
Sets 7x7 error matrix.
Definition: Particle.cc:423

◆ wasExactFitHypothesisUsed()

bool wasExactFitHypothesisUsed ( ) const
inline

Returns true if the type represented by this Particle object was used use as a mass hypothesis during the track of this Particle's parameters.

Definition at line 1003 of file Particle.h.

1004 {
1005 return std::abs(m_pdgCodeUsedForFit) == std::abs(m_pdgCode);
1006 }

◆ writeExtraInfo()

void writeExtraInfo ( const std::string &  name,
const double  value 
)

Sets the user defined extraInfo.

Adds it if necessary, overwrites existing ones if they share the same name.

Definition at line 1392 of file Particle.cc.

1393{
1394 if (this->hasExtraInfo(name)) {
1395 this->setExtraInfo(name, value);
1396 } else {
1397 this->addExtraInfo(name, value);
1398 }
1399}
void setExtraInfo(const std::string &name, double value)
Sets the user-defined data of given name to the given value.
Definition: Particle.cc:1401
void addExtraInfo(const std::string &name, double value)
Sets the user-defined data of given name to the given value.
Definition: Particle.cc:1420

Friends And Related Function Documentation

◆ ParticleSubset

friend class ParticleSubset
friend

Definition at line 1200 of file Particle.h.

Member Data Documentation

◆ m_arrayPointer

TClonesArray* m_arrayPointer
mutableprivate

Internal pointer to DataStore array containing the daughters of this particle.

This is a transient member and will not be written to file. The pointer is set by getArrayPointer() when first called.

Definition at line 1129 of file Particle.h.

◆ m_cacheArrayIndex

int m_cacheArrayIndex
mutableprivateinherited

Cache of the index in the TClonesArray to which this object belongs.

Definition at line 432 of file RelationsObject.h.

◆ m_cacheDataStoreEntry

DataStore::StoreEntry* m_cacheDataStoreEntry
mutableprivateinherited

Cache of the data store entry to which this object belongs.

Definition at line 429 of file RelationsObject.h.

◆ m_daughterIndices

std::vector<int> m_daughterIndices
private

daughter particle indices

Definition at line 1098 of file Particle.h.

◆ m_daughterProperties

std::vector<int> m_daughterProperties
private

daughter particle properties

Definition at line 1104 of file Particle.h.

◆ m_energyLossCorrection

double m_energyLossCorrection = 0.0
private

energy loss correction.

defined as 'm_energyLossCorrection = E_measured - E_true'

Definition at line 1091 of file Particle.h.

◆ m_errMatrix

double m_errMatrix[c_SizeMatrix] = {}
private

error matrix (1D representation)

Definition at line 1095 of file Particle.h.

◆ m_extraInfo

std::vector<double> m_extraInfo
private

Stores associated user defined values.

Order is given by string -> index mapping in ParticleExtraInfoMap. entry 0 is reserved specifies which map to use.

Definition at line 1120 of file Particle.h.

◆ m_flavorType

EFlavorType m_flavorType
private

flavor type.

Definition at line 1099 of file Particle.h.

◆ m_identifier

int m_identifier = -1
private

Identifier that can be used to identify whether the particle is unique or is a copy or representation of another.

For example a kaon and pion particles constructed from the same Track are representations of the same physical object in the detector and cannot be used in the reconstruction of the same decay chain

Definition at line 1113 of file Particle.h.

◆ m_jacobiMatrix

double m_jacobiMatrix[c_SizeMatrix] = {}
private

error matrix (1D representation)

Definition at line 1096 of file Particle.h.

◆ m_mass

double m_mass
private

particle (invariant) mass

Definition at line 1084 of file Particle.h.

◆ m_mdstIndex

unsigned m_mdstIndex
private

0-based index of MDST store array object

Definition at line 1101 of file Particle.h.

◆ m_momentumScale

double m_momentumScale = 1.0
private

effective momentum scale factor

Definition at line 1088 of file Particle.h.

◆ m_momentumScalingFactor

double m_momentumScalingFactor = 1.0
private

momentum scaling factor

Definition at line 1089 of file Particle.h.

◆ m_momentumSmearingFactor

double m_momentumSmearingFactor = 1.0
private

momentum smearing factor

Definition at line 1090 of file Particle.h.

◆ m_particleSource

EParticleSourceObject m_particleSource
private

(mdst) source of particle

Definition at line 1100 of file Particle.h.

◆ m_pdgCode

int m_pdgCode
private

PDG code.

Definition at line 1082 of file Particle.h.

◆ m_pdgCodeUsedForFit

int m_pdgCodeUsedForFit = 0
private

PDG code used for the track fit.

Definition at line 1083 of file Particle.h.

◆ m_properties

int m_properties
private

particle property

Definition at line 1103 of file Particle.h.

◆ m_pValue

double m_pValue
private

chi^2 probability of the fit.

Default is nan

Definition at line 1097 of file Particle.h.

◆ m_px

double m_px
private

momentum component x

Definition at line 1085 of file Particle.h.

◆ m_py

double m_py
private

momentum component y

Definition at line 1086 of file Particle.h.

◆ m_pz

double m_pz
private

momentum component z

Definition at line 1087 of file Particle.h.

◆ m_trackFitResultIndex

unsigned m_trackFitResultIndex
private

0-based index of related TrackFitResult, relevant for kinks

Definition at line 1102 of file Particle.h.

◆ m_x

double m_x
private

position component x

Definition at line 1092 of file Particle.h.

◆ m_y

double m_y
private

position component y

Definition at line 1093 of file Particle.h.

◆ m_z

double m_z
private

position component z

Definition at line 1094 of file Particle.h.


The documentation for this class was generated from the following files: