Belle II Software
release-08-01-10
|
Class to store ECL Showers. More...
#include <ECLShower.h>
Public Types | |
enum | Hypothesis : unsigned int { c_muonNPhotons = 1 , c_chargedHadron = 2 , c_electronNPhotons = 3 , c_nPhotons = 5 , c_neutralHadron = 6 , c_mergedPi0 = 7 } |
The hypothesis ID for ECLShowers. More... | |
enum | StatusBit : unsigned int { c_hasDeadCrystal = 1 << 0 , c_hasHotCrystal = 1 << 1 , c_hasProblematicCrystal = c_hasDeadCrystal | c_hasHotCrystal , c_hasPulseShapeDiscrimination = 1 << 2 } |
The status information for the ECLShowers. More... | |
Public Member Functions | |
ECLShower () | |
Default constructor for ROOT. More... | |
void | setIsTrack (bool val) |
Set Match with Track. | |
void | setStatus (int Status) |
Set Status. | |
void | setShowerId (int ShowerId) |
Set Shower ID. | |
void | setConnectedRegionId (int connectedRegionId) |
Set Connected region ID. | |
void | setHypothesisId (int hypothesisId) |
Set Hypothesis identifier. | |
void | setCentralCellId (int centralCellId) |
Set central cell id. | |
void | setEnergy (double Energy) |
Set Energy. | |
void | setEnergyRaw (double EnergySum) |
Set Raw Energy Sum. | |
void | setTheta (double Theta) |
Set Theta (rad) | |
void | setPhi (double Phi) |
Set Phi (rad) | |
void | setR (double R) |
Set R. | |
void | setCovarianceMatrix (double covArray[6]) |
Set symmetric Error Array(3x3) for [0]->Error on Energy [2]->Error on Phi [5]->Error on Theta. | |
void | setTime (double Time) |
Set Time. | |
void | setDeltaTime99 (double TimeReso) |
Set Time Resolution. | |
void | setEnergyHighestCrystal (double HighestEnergy) |
Set Highest Energy. | |
void | setLateralEnergy (double lateralEnergy) |
Set Lateral Energy. | |
void | setMinTrkDistance (double dist) |
Set Distance to closest track. | |
void | setTrkDepth (double trkDepth) |
Set path on track extrapolation line to POCA to average cluster direction. | |
void | setShowerDepth (double showerDepth) |
Set path on the average cluster direction. | |
void | setNumberOfCrystals (double nofCrystals) |
Set sum of weights of crystals. | |
void | setAbsZernikeMoment (unsigned int n, unsigned int m, double absZernikeMoment) |
Set absolute value of Zernike Moment nm, for nm between 10 and 55. | |
void | setZernikeMVA (double zernikeMVA) |
SetZernike MVA value. | |
void | setSecondMoment (double secondMoment) |
Set second moment. | |
void | setE1oE9 (double E1oE9) |
Set energy ration E1 over E9. | |
void | setE9oE21 (double E9oE21) |
Set energy ration E9 over E21. | |
void | setShowerHadronIntensity (double hadronIntensity) |
Set shower hadron intensity. | |
void | setPulseShapeDiscriminationMVA (double mvaVal) |
Set shower hadron intensity. | |
void | setNumberOfHadronDigits (double NumberOfHadronDigits) |
Set numver of hadron digits. | |
void | setNumberOfCrystalsForEnergy (double numberOfCrystalsForEnergy) |
Set number of crystals used for energy calculation. | |
void | setNominalNumberOfCrystalsForEnergy (double nominalNumberOfCrystalsForEnergy) |
Set nominal number of crystals used for energy calculation. | |
void | setNOptimalGroupIndex (int nOptimalGroupIndex) |
Set group number used to find nominalNumberOfCrystalsForEnergy. | |
void | setNOptimalEnergyBin (int nOptimalEnergyBin) |
Set energy bin number used to find nominalNumberOfCrystalsForEnergy. | |
void | setNOptimalEnergy (double nOptimalEnergy) |
Set energy used to find nOptimalEnergyBin. | |
void | setListOfCrystalsForEnergy (const std::vector< unsigned int > &listofcrystals) |
Set list of cell ids used for energy calculation. | |
void | setListOfCrystalEnergyRankAndQuality (std::vector< std::pair< unsigned int, bool >> listOfCrystalEnergyRankAndQuality) |
Set list of indexes of related ECLCalDigit objects sorted by calibrated energy with flag for PSD useability for charged PID. | |
bool | getIsTrack () const |
Get if matched with a Track. More... | |
int | getStatus () const |
Get Status. More... | |
int | getShowerId () const |
Get Shower Id. More... | |
int | getConnectedRegionId () const |
Get Connected region Id. More... | |
int | getHypothesisId () const |
Get Hypothesis Id. More... | |
int | getCentralCellId () const |
Get central cell Id. More... | |
double | getEnergy () const |
Get Energy. More... | |
double | getEnergyRaw () const |
Get Energy Sum. More... | |
double | getTheta () const |
Get Theta. More... | |
double | getPhi () const |
Get Phi. More... | |
double | getR () const |
Get R. More... | |
void | getCovarianceMatrixAsArray (double covArray[6]) const |
Get Error Array for Energy->[0], Phi->[2], Theta->[5]. More... | |
double | getUncertaintyEnergy () const |
Get Error of Energy. More... | |
double | getUncertaintyTheta () const |
Get Error of theta. More... | |
double | getUncertaintyPhi () const |
Get Error of phi. More... | |
double | getTime () const |
Get Time. More... | |
double | getDeltaTime99 () const |
Get Time Resolution. More... | |
double | getEnergyHighestCrystal () const |
Get Highest Energy in Shower. More... | |
double | getLateralEnergy () const |
Get Lateral Energy in Shower. More... | |
double | getMinTrkDistance () const |
Get distance to closest Track. More... | |
double | getTrkDepth () const |
path on track extrapolation to POCA to average cluster direction More... | |
double | getShowerDepth () const |
path on track extrapolation to POCA to average cluster direction More... | |
double | getNumberOfCrystals () const |
Get NofCrystals. More... | |
double | getAbsZernikeMoment (unsigned int n, unsigned int m) const |
Get absolute value of Zernike Moment nm. More... | |
double | getZernikeMVA () const |
Get Zernike MVA. More... | |
double | getSecondMoment () const |
Get second moment. More... | |
double | getE1oE9 () const |
Get energy ratio E1oE9. More... | |
double | getE9oE21 () const |
Get energy ratio E9oE21. More... | |
double | getShowerHadronIntensity () const |
Get shower hadron intensity. More... | |
double | getPulseShapeDiscriminationMVA () const |
Get shower hadron intensity. More... | |
double | getNumberOfHadronDigits () const |
Get number of hadron digits. More... | |
double | getNumberOfCrystalsForEnergy () const |
Get number of crystals used for energy calculation. More... | |
double | getNominalNumberOfCrystalsForEnergy () const |
Get nominal number of crystals used for energy calculation. More... | |
int | getNOptimalGroupIndex () const |
Get index of group of crystals used to find nominalNumberOfCrystalsForEnergy. More... | |
int | getNOptimalEnergyBin () const |
Get energy bin used to find nominalNumberOfCrystalsForEnergy. More... | |
double | getNOptimalEnergy () const |
Get energy used to find nOptimalEnergyBin. More... | |
std::vector< unsigned int > & | getListOfCrystalsForEnergy () |
Get list of cellids used for energy calculation. More... | |
std::vector< std::pair< unsigned int, bool > > | getListOfCrystalEnergyRankAndQuality () |
Get list of indexes of related ECLCalDigit objects sorted by calibrated energy with flag for PSD useability for charged PID. More... | |
ROOT::Math::XYZVector | getMomentum () const |
The method to get return ROOT::Math::XYZVector Momentum. | |
TMatrixDSym | getCovarianceMatrix3x3 () const |
Return TMatrixDsym 3x3 covariance matrix for E, Phi and Theta. | |
int | getDetectorRegion () const |
Return detector region: 0: below acceptance, 1: FWD, 2: BRL, 3: BWD, 11: FWDGAP, 13: BWDGAP. | |
bool | hasStatus (unsigned short int bitmask) const |
Return if specific status bit is set. More... | |
void | addStatus (unsigned short int bitmask) |
Add bitmask to current status. More... | |
bool | hasHotCrystal () const |
Check if shower contains a hot crystal. | |
bool | hasDeadCrystal () const |
Check if shower contains a dead crystal. | |
bool | hasProblematicCrystal () const |
Check if shower contains a problematic crystal. | |
bool | hasPulseShapeDiscrimination () const |
Check if shower contains pulse shape discrimination information. | |
int | getUniqueId () const |
Return unique identifier. | |
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). More... | |
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). More... | |
void | copyRelations (const RelationsInterface< BASE > *sourceObj) |
Copies all relations of sourceObj (pointing from or to sourceObj) to this object (including weights). More... | |
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. More... | |
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. More... | |
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. More... | |
template<class TO > | |
TO * | getRelatedTo (const std::string &name="", const std::string &namedRelation="") const |
Get the object to which this object has a relation. More... | |
template<class FROM > | |
FROM * | getRelatedFrom (const std::string &name="", const std::string &namedRelation="") const |
Get the object from which this object has a relation. More... | |
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. More... | |
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. More... | |
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. More... | |
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. More... | |
virtual std::string | getName () const |
Return a short name that describes this object, e.g. More... | |
virtual std::string | getInfoHTML () const |
Return a short summary of this object's contents in HTML format. More... | |
std::string | getInfo () const |
Return a short summary of this object's contents in raw text format. More... | |
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. | |
Protected Member Functions | |
TClonesArray * | getArrayPointer () const |
Returns the pointer to the raw DataStore array holding this object (protected since these arrays are easy to misuse). | |
Private Member Functions | |
ClassDef (ECLShower, 17) | |
ClassDef. | |
Private Attributes | |
bool | m_isTrk |
Match with track (GDN) | |
int | m_status |
Status. | |
int | m_showerId |
Shower ID. | |
int | m_connectedRegionId |
Connected Region ID (TF) | |
int | m_hypothesisId |
Hypothesis ID (TF) | |
int | m_centralCellId |
Central cell ID (TF) | |
Double32_t | m_energy |
Energy (GeV) | |
Double32_t | m_energyRaw |
Raw Energy Sum(GeV) | |
Double32_t | m_theta |
Theta (rad) | |
Double32_t | m_phi |
Phi (rad) | |
Double32_t | m_r |
R (cm) | |
Double32_t | m_Error [6] |
Error of Energy, Theta and Phi. | |
Double32_t | m_time |
Time. | |
Double32_t | m_deltaTime99 |
Time that contains 99% of signal crystals. | |
Double32_t | m_energyHighestCrystal |
Highest Energy in Shower (GeV) (TF) | |
Double32_t | m_lateralEnergy |
Lateral Energy in Shower (GDN) | |
Double32_t | m_minTrkDistance |
Distance between shower and closest track (GDN) | |
Double32_t | m_trkDepth |
Path on track ext. More... | |
Double32_t | m_showerDepth |
Same as above, but on the cluster average direction (GDN) | |
Double32_t | m_numberOfCrystals |
Sum of weights of crystals (~number of crystals) (TF) | |
Double32_t | m_absZernikeMoments [20] |
Shower shape variables, absolute values of Zernike Moments (MH) | |
Double32_t | m_zernikeMVA |
Shower shape variable, zernike MVA output. | |
Double32_t | m_secondMoment |
Shower shape variable, second moment (for merged pi0) (TF) | |
Double32_t | m_E1oE9 |
Shower shape variable, E1oE9 (TF) | |
Double32_t | m_E9oE21 |
Shower shape variable, E9oE25. | |
Double32_t | m_ShowerHadronIntensity |
Shower Hadron Component Intensity (pulse shape discrimination variable). More... | |
Double32_t | m_PulseShapeDiscriminationMVA |
MVA classifier that uses pulse shape discrimination to identify electromagnetic vs hadronic showers. | |
Double32_t | m_NumberOfHadronDigits |
Number of hadron digits in shower (pulse shape discrimination variable). More... | |
Double32_t | m_numberOfCrystalsForEnergy |
number of crystals used for energy calculation (TF) | |
Double32_t | m_nominalNumberOfCrystalsForEnergy |
number of crystals used for energy calculation (TF) | |
int | m_nOptimalGroupIndex |
group (of crystals) number used to find nominalNumberOfCrystalsForEnergy (CH) | |
int | m_nOptimalEnergyBin |
energy bin used to find nominalNumberOfCrystalsForEnergy (CH) | |
Double32_t | m_nOptimalEnergy |
energy used in ECLSplitterN1 to find nOptimalEnergyBin (CH) | |
std::vector< unsigned int > | m_listOfCrystalsForEnergy |
list of cell ids used for energy calculation (TF) | |
std::vector< std::pair< unsigned int, bool > > | m_listOfCrystalEnergyRankAndQuality |
list of indices of related ECLCalDigits by energy. More... | |
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. | |
Class to store ECL Showers.
Definition at line 30 of file ECLShower.h.
enum Hypothesis : unsigned int |
The hypothesis ID for ECLShowers.
Unlike ECLClusters, ECLShowers have one and only one hypothesis ID.
Definition at line 34 of file ECLShower.h.
enum StatusBit : unsigned int |
The status information for the ECLShowers.
Definition at line 50 of file ECLShower.h.
|
inline |
Default constructor for ROOT.
< Match with track < Status (e.g. shower contains one hot crystal) < Shower ID < Connected Region ID < Hypothesis ID < Central Cell ID < Energy (GeV) < Raw Energy Sum (GeV) < Theta (rad) < Phi (rad) < R (cm) < Error Array for Energy->[0], Phi->[2], Theta->[5] < Time < Time that contains 99% of true signals < Highest energy in Shower < Lateral Energy
< Distance between shower and closest track
< Path on track extrapolation to POCA to average cluster direction
< Same as above, but on the cluster average direction < Sum of weights of crystals (~number of crystals) < Shower shape variables, absolute values of Zernike Moments 10 to 55 < Shower shape variable, Zernike MVA output < Shower shape variable, second moment (needed for merged pi0) < Shower shape variable, E1oE9 < Shower shape variable, E9oE21 < Shower Hadron Intensity. Will be removed in release-04. < Digit level MVA classifier that uses pulse shape discrimination. < Shower Number of hadron digits < number of crystals used for energy calculation < nominal number of crystals used for energy calculation < index of group of crystals used to find m_nominalNumberOfCrystalsForEnergy < energy bin used to find m_nominalNumberOfCrystalsForEnergy < energy used to find nOptimalEnergyBin in ECLSplitterN1 < list of cell ids used for energy calculation < list of ECLCalDigit indices sorted by online energy
Definition at line 66 of file ECLShower.h.
|
inlineinherited |
Add a relation from this object to another object (with caching).
object | The object to which the relation should point. |
weight | The weight of the relation. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 142 of file RelationsObject.h.
|
inlineinherited |
Add a relation from this object to another object (no caching, can be quite slow).
object | The object to which the relation should point. |
weight | The weight of the relation. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 155 of file RelationsObject.h.
|
inline |
Add bitmask to current status.
bitmask | The status code which should be added. |
Definition at line 504 of file ECLShower.h.
|
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.
|
inline |
Get absolute value of Zernike Moment nm.
Definition at line 377 of file ECLShower.h.
|
inline |
|
inline |
|
inline |
Get Error Array for Energy->[0], Phi->[2], Theta->[5].
Definition at line 312 of file ECLShower.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
|
inlineinherited |
Return a short summary of this object's contents in raw text format.
Returns the contents of getInfoHTML() while translating line-breaks etc.
Definition at line 370 of file RelationsObject.h.
|
inlinevirtualinherited |
Return a short summary of this object's contents in HTML format.
Reimplement this in your own class to provide useful output for display or debugging purposes. For example, you might do something like:
Reimplemented in RecoTrack, TRGSummary, TrackFitResult, Track, SoftwareTriggerResult, PIDLikelihood, MCParticle, Cluster, and Particle.
Definition at line 362 of file RelationsObject.h.
|
inline |
Get if matched with a Track.
Definition at line 257 of file ECLShower.h.
|
inline |
|
inline |
Get list of indexes of related ECLCalDigit objects sorted by calibrated energy with flag for PSD useability for charged PID.
Definition at line 447 of file ECLShower.h.
|
inline |
Get list of cellids used for energy calculation.
Definition at line 442 of file ECLShower.h.
|
inline |
Get distance to closest Track.
Definition at line 357 of file ECLShower.h.
|
inlinevirtualinherited |
Return a short name that describes this object, e.g.
pi+ for an MCParticle.
Reimplemented in SpacePoint, MCParticle, and Particle.
Definition at line 344 of file RelationsObject.h.
|
inline |
Get nominal number of crystals used for energy calculation.
Definition at line 422 of file ECLShower.h.
|
inline |
Get energy used to find nOptimalEnergyBin.
Definition at line 437 of file ECLShower.h.
|
inline |
Get energy bin used to find nominalNumberOfCrystalsForEnergy.
Definition at line 432 of file ECLShower.h.
|
inline |
Get index of group of crystals used to find nominalNumberOfCrystalsForEnergy.
Definition at line 427 of file ECLShower.h.
|
inline |
|
inline |
Get number of crystals used for energy calculation.
Definition at line 417 of file ECLShower.h.
|
inline |
Get number of hadron digits.
Definition at line 412 of file ECLShower.h.
|
inline |
|
inline |
Get shower hadron intensity.
Definition at line 407 of file ECLShower.h.
|
inline |
|
inlineinherited |
Get the object to or from which this object has a relation.
T | The class of objects to or from which the relation points. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 278 of file RelationsObject.h.
|
inlineinherited |
Get the object from which this object has a relation.
FROM | The class of objects from which the relation points. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 263 of file RelationsObject.h.
|
inlineinherited |
Get first related object & weight of relation pointing from an array.
FROM | The class of objects from which the relation points. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 314 of file RelationsObject.h.
|
inlineinherited |
Get the object to which this object has a relation.
TO | The class of objects to which the relation points. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 248 of file RelationsObject.h.
|
inlineinherited |
Get first related object & weight of relation pointing to an array.
TO | The class of objects to which the relation points. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 297 of file RelationsObject.h.
|
inlineinherited |
Get first related object & weight of relation pointing from/to an array.
T | The class of objects to or from which the relation points. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 331 of file RelationsObject.h.
|
inlineinherited |
Get the relations that point from another store array to this object.
FROM | The class of objects from which the relations point. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 212 of file RelationsObject.h.
|
inlineinherited |
Get the relations that point from this object to another store array.
TO | The class of objects to which the relations point. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 197 of file RelationsObject.h.
|
inlineinherited |
Get the relations between this object and another store array.
Relations in both directions are returned.
T | The class of objects to or from which the relations point. |
name | The 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. |
namedRelation | Additional name for the relation, or "" for the default naming |
Definition at line 230 of file RelationsObject.h.
|
inline |
|
inline |
path on track extrapolation to POCA to average cluster direction
Definition at line 367 of file ECLShower.h.
|
inline |
Get shower hadron intensity.
Definition at line 402 of file ECLShower.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
path on track extrapolation to POCA to average cluster direction
Definition at line 362 of file ECLShower.h.
|
inline |
|
inline |
|
inline |
|
inline |
|
inline |
Return if specific status bit is set.
bitmask | The bitmask which is compared to the status of the shower. |
Definition at line 498 of file ECLShower.h.
|
private |
list of indices of related ECLCalDigits by energy.
Also stores a quality flag for each digit denoting whether the PSD information can be used for charged particle ID. Cached here to avoid resorting the ECLCalDigit vector 90 times per track.
Definition at line 570 of file ECLShower.h.
|
private |
Number of hadron digits in shower (pulse shape discrimination variable).
Weighted sum of digits in shower with significant scintillation emission (> 3 MeV) in the hadronic scintillation component. (SL)
Definition at line 562 of file ECLShower.h.
|
private |
Shower Hadron Component Intensity (pulse shape discrimination variable).
Sum of the CsI(Tl) hadron scintillation component emission normalized to the sum of CsI(Tl) total scintillation emission. Computed only using showers digits with energy greater than 50 MeV and good offline waveform fit chi2. (SL)
Definition at line 558 of file ECLShower.h.
|
private |