10 #include <arich/modules/arichNtuple/ARICHNtupleModule.h>
13 #include <framework/dataobjects/EventMetaData.h>
14 #include <arich/dataobjects/ARICHLikelihood.h>
15 #include <arich/dataobjects/ARICHAeroHit.h>
16 #include <arich/dataobjects/ARICHTrack.h>
17 #include <arich/dataobjects/ARICHPhoton.h>
18 #include <arich/dataobjects/ARICHHit.h>
19 #include <arich/dataobjects/ARICHInfo.h>
22 #include <framework/datastore/StoreObjPtr.h>
24 #include <mdst/dataobjects/HitPatternCDC.h>
26 #ifdef ALIGNMENT_USING_BHABHA
27 #include <mdst/dataobjects/ECLCluster.h>
31 #include <framework/gearbox/Const.h>
32 #include <framework/logging/Logger.h>
59 setDescription(
"The module saves variables needed for performance analysis, such as postion and momentum of the hit, likelihoods for hypotheses and number of photons.");
75 B2FATAL(
"Couldn't open file '" <<
m_outputFile <<
"' for writing!");
79 m_tree =
new TTree(
"arich",
"ARICH validation ntuple");
90 #ifdef ALIGNMENT_USING_BHABHA
121 m_tree->Branch(
"photons",
"std::vector<Belle2::ARICHPhoton>", &
m_arich.photons);
134 arichHits.isRequired();
146 #ifdef ALIGNMENT_USING_BHABHA
155 for (
const auto& cluster : eclClusters) {
156 if (!cluster.isNeutral())
continue;
157 if (cluster.getHypothesisId() != 5 && cluster.getHypothesisId() != 1)
159 if (cluster.getEnergy() > 0.1) E_tot += cluster.getEnergy();
167 const Track* mdstTrack = NULL;
185 if (arichTrack.hitsWindow()) {
186 TVector2 winHit = arichTrack.windowHitPosition();
208 #ifdef ALIGNMENT_USING_BHABHA
225 ROOT::Math::XYZVector trkPos = fitResult->
getPosition();
230 #ifdef ALIGNMENT_USING_BHABHA
231 ROOT::Math::XYZVector trkMom = fitResult->
getMomentum();
240 int fromARICHMCP = 0;
241 particle = mdstTrack->getRelated<
MCParticle>();
242 if (!particle) { particle = mdstTrack->getRelated<
MCParticle>(
"arichMCParticles"); fromARICHMCP = 1;}
246 m_arich.
seen = particle->hasSeenInDetector(Const::ARICH);
247 ROOT::Math::XYZVector prodVertex = particle->getProductionVertex();
251 ROOT::Math::XYZVector decVertex = particle->getDecayVertex();
259 std::vector<Belle2::MCParticle*> daughs = particle->getDaughters();
260 for (
const auto daugh : daughs) {
261 if (daugh == NULL)
continue;
270 const std::vector<ARICHPhoton>& photons = arichTrack.getPhotons();
272 for (
auto it = photons.begin(); it != photons.end(); ++it) {
274 if (iph.
getHitID() < arichHits.getEntries()) {
275 auto ihit = *arichHits[iph.
getHitID()];
276 int module = ihit.getModule();
277 int channel = ihit.getChannel();
278 int chid = 1 << 16 | module << 8 | channel;
281 m_arich.photons.push_back(iph);
284 TVector3 recPos = arichTrack.getPosition();
289 TVector3 recMom = arichTrack.getDirection() * arichTrack.getMomentum();
295 TVector3 truePos = aeroHit->getPosition();
300 TVector3 trueMom = aeroHit->getMomentum();
315 m_arich.
seen = particle->hasSeenInDetector(Const::ARICH);
316 ROOT::Math::XYZVector prodVertex = particle->getProductionVertex();
320 ROOT::Math::XYZVector decVertex = particle->getDecayVertex();
325 std::vector<Belle2::MCParticle*> daughs = particle->getDaughters();
326 for (
const auto daugh : daughs) {
Datastore class that holds information on track parameters at the entrance in aerogel.
This is a class to store ARICH likelihoods in the datastore.
TTree * m_tree
pointer to output tree
StoreArray< ARICHAeroHit > m_arichAeroHits
Optional input array of ARICHAeroHits.
std::string m_outputFile
output root file
StoreArray< ARICHTrack > m_arichTracks
Required array of input ARICHTracks.
ARICH::ARICHTree m_arich
ntuple structure
StoreArray< MCParticle > m_arichMCPs
Optional input array of MCParticles.
StoreArray< Track > m_tracks
Optional input array of Tracks.
StoreArray< ARICHLikelihood > m_arichLikelihoods
Required array of input ARICHLikelihoods.
TFile * m_file
pointer to output root file
StoreArray< ARICHInfo > m_arichInfo
Optional input array of ARICHInfo.
Struct for ARICH reconstructed photon (hit related to track) information.
void setHitID(int id)
Set ID of corresponding ARICHHit.
int getHitID()
Get ID of corresponding ARICHHit.
static const ChargedStable muon
muon particle
static const ChargedStable pion
charged pion particle
static const ChargedStable proton
proton particle
static const ChargedStable kaon
charged kaon particle
static const ChargedStable electron
electron particle
static const ChargedStable deuteron
deuteron particle
double getE9oE21() const
Return E9/E21 (shower shape variable).
double getEnergy(EHypothesisBit hypothesis) const
Return Energy (GeV).
Store one Ext hit as a ROOT object.
unsigned short getNHits() const
Get the total Number of CDC hits in the fit.
A Class to store the Monte Carlo particle information.
@ c_PrimaryParticle
bit 0: Particle is primary particle.
void setDescription(const std::string &description)
Sets the description of the module.
T * getRelated(const std::string &name="", const std::string &namedRelation="") const
Get the object to or from which this object has a relation.
bool isOptional(const std::string &name="")
Tell the DataStore about an optional input.
Accessor to arrays stored in the data store.
Type-safe access to single objects in the data store.
Values of the result of a track fit with a given particle hypothesis.
short getChargeSign() const
Return track charge (1 or -1).
double getPValue() const
Getter for Chi2 Probability of the track fit.
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.
HitPatternCDC getHitPatternCDC() const
Getter for the hit pattern in the CDC;.
Class that bundles various TrackFitResults.
virtual void initialize() override
Initialize the Module.
virtual void event() override
Event processor.
virtual void terminate() override
Termination action.
virtual ~ARICHNtupleModule()
Destructor.
REG_MODULE(arichBtest)
Register the Module.
ARICHNtupleModule()
Constructor.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
Abstract base class for different kinds of events.
Float_t zDec
decay vertex (cylindrical coordinate z) of MCParticle
Int_t detPhot
number of detected photons
Int_t nCDC
number of track CDC hits
Float_t winHit[2]
vector of reconstructed photons
Float_t rhoDec
decay vertex (cylindrical coordinate r) of MCParticle
ParticlesArray logL
log likelihoods
Int_t scatter
1 if particle scattered (i.e.
Int_t nRec
number of reconstructed photons
Short_t primary
is a primary particle (from related MCParticle)
Short_t seen
is seen in ARICH (from related MCParticle)
TrackHit recHit
extrapolated Track hit
Int_t motherPDG
PDG code of related mother MCParticle.
ParticlesArray numBkg
number of expected background photons
ParticlesArray expPhot
number of expected photons (signal + bkg)
Float_t phiProd
production vertex (cylindrical coordinate phi) of MCParticle
Int_t trgtype
track hit on hapd window (x,y coordinates)
Float_t rhoProd
production vertex (cylindrical coordinate r) of MCParticle
void clear()
Clear the structure: set elements to zero.
Float_t phiDec
decay vertex (cylindrical coordinate phi) of MCParticle
Bool_t inAcc
track in detector acceptance, i.e.
TrackHit mcHit
related MC particle hit
Int_t PDG
PDG code of related MCParticle.
Int_t status
track status (add proper description)
Float_t pValue
p-value of Track fit
Float_t zProd
production vertex (cylindrical coordinate z) of MCParticle
Float_t p
momentum magnitude
Float_t z
impact point, z component
Float_t theta
momentum polar angle
Float_t phi
momentum azimuthal angle
Float_t x
impact point, x component
Float_t y
impact point, y component