Belle II Software prerelease-10-00-00a
HitXPModule.h
1/**************************************************************************
2 * basf2 (Belle II Analysis Software Framework) *
3 * Author: The Belle II Collaboration *
4 * *
5 * See git log for contributors and copyright holders. *
6 * This file is licensed under LGPL-3.0, see LICENSE.md. *
7 **************************************************************************/
8
9#pragma once
10
11#include <framework/core/Module.h>
12#include <framework/datastore/StoreArray.h>
13#include <mdst/dataobjects/MCParticle.h>
14#include <tracking/dataobjects/hitXP.h>
15#include <TTree.h>
16#include <TFile.h>
17
18#include <set>
19
20namespace Belle2 {
25
40
44 class HitXPModule : public Module {
45 public:
46
48
50
53 void initialize() override;
54
56 void beginRun() override;
57
60 void event() override;
61
63 void endRun() override;
64
66 void terminate() override;
67
68 private:
69 TTree* m_tree = nullptr;
70 TFile* m_outputFile = nullptr;
71 std::vector<hitXP> m_hitXP;
72 std::set<hitXP, hitXP::timeCompare> m_hitXPSet;
73 bool c_addTree;
74
75 int m_trackNumber = 0;
76 int m_eventNumber = 0;
80
81 TTree* m_treeSel = nullptr;
82 TFile* m_outputFileSel = nullptr;
83 std::vector<hitXP> m_hitXPSel;
87
88 TTree* m_treeTiSel = nullptr;
89 TFile* m_outputFileTiSel = nullptr;
90 std::vector<hitXP> m_hitXPTiSel;
94
95 TFile* m_outputFileExt = nullptr;
96 TTree* m_treeExt = nullptr;
97 std::vector<double> m_EpositionEntryX;
98 std::vector<double> m_EpositionEntryY;
99 std::vector<double> m_EpositionEntryZ;
100 std::vector<double> m_EmomentumEntryX;
101 std::vector<double> m_EmomentumEntryY;
102 std::vector<double> m_EmomentumEntryZ;
103 std::vector<double> m_EpositionLocalEntryX;
104 std::vector<double> m_EpositionLocalEntryY;
105 std::vector<double> m_EpositionLocalEntryZ;
106 std::vector<int> m_EPDGID;
107 std::vector<double> m_Eposition0X;
108 std::vector<double> m_Eposition0Y;
109 std::vector<double> m_Eposition0Z;
110 std::vector<double> m_Emomentum0X;
111 std::vector<double> m_Emomentum0Y;
112 std::vector<double> m_Emomentum0Z;
113 std::vector<double> m_Etime;
114 std::vector<int> m_EsensorSensor;
115 std::vector<int> m_EsensorLayer;
116 std::vector<int> m_EsensorLadder;
117 std::vector<int> m_Ereconstructed;
118 std::vector<int> m_EclusterU;
119 std::vector<int> m_EclusterV;
120 std::vector<double> m_Echarge;
124 std::vector<double> m_EomegaEntry;
125 std::vector<double> m_Eomega0;
126 std::vector<double> m_Ed0Entry;
127 std::vector<double> m_Ed00;
128 std::vector<double> m_Ephi0Entry;
129 std::vector<double> m_Ephi00;
130 std::vector<double> m_Ez0Entry;
131 std::vector<double> m_Ez00;
132 std::vector<double> m_EtanlambdaEntry;
133 std::vector<double> m_Etanlambda0;
134 int m_Eprimary = 0;
135
137
138 protected:
139
140 };
141
142}
std::vector< double > m_EmomentumEntryX
external momentum at entry point, coordinate x
std::vector< int > m_EclusterV
external flag of v-cluster
TFile * m_outputFile
output file
Definition HitXPModule.h:70
std::vector< double > m_EomegaEntry
external omega parameter at entry point
std::vector< hitXP > m_hitXPSel
selected vector of hitXP
Definition HitXPModule.h:83
TTree * m_treeTiSel
tight selected output tree
Definition HitXPModule.h:88
TTree * m_tree
full output tree
Definition HitXPModule.h:69
std::vector< double > m_Etanlambda0
external tanlambda parameter at IP
std::vector< double > m_EtanlambdaEntry
external tanlambda parameter at entry point
TTree * m_treeExt
external output tree
Definition HitXPModule.h:96
std::vector< int > m_EPDGID
external PDGID
std::vector< int > m_EsensorLayer
external layer of the hit
int m_Eprimary
external flag for primary particles
std::vector< double > m_EmomentumEntryY
external momentum at entry point, coordinate x
void initialize() override
Initialize the Module.
int m_eventNumberTiSel
tight selected interative number of the event in the run
Definition HitXPModule.h:92
bool c_addTree
parameter to produce additional tree
Definition HitXPModule.h:73
void event() override
This method is the core of the module.
TFile * m_outputFileSel
selected output file
Definition HitXPModule.h:82
TTree * m_treeSel
selected output tree
Definition HitXPModule.h:81
std::vector< double > m_EpositionLocalEntryZ
external local position at entry point, coordinate z
std::vector< int > m_Ereconstructed
external flag of track-reconstruction or not
std::vector< double > m_EmomentumEntryZ
external momentum at entry point, coordinate x
std::vector< double > m_Etime
external time of the hit
void endRun() override
This method is called if the current run ends.
std::vector< double > m_Ephi0Entry
external phi0 parameter at entry point
std::vector< double > m_Ed00
external d0 parameter at IP
std::vector< int > m_EsensorSensor
external sensor of the hit
int m_trackNumberSel
selected iterative number of the track in the run
Definition HitXPModule.h:84
void terminate() override
This method is called at the end of the event processing.
std::vector< double > m_Emomentum0X
external momentum at IP, coordinate x
std::vector< double > m_Eposition0X
external position at IP, coordinate x
std::vector< double > m_EpositionLocalEntryY
external local position at entry point, coordinate y
int m_trackIterator
iterator used to count track (m_trackNumber)
Definition HitXPModule.h:78
std::vector< int > m_EsensorLadder
external ladder of the hit
std::vector< double > m_EpositionLocalEntryX
external local position at entry point, coordinate x
std::vector< double > m_Emomentum0Y
external momentum at IP, coordinate y
std::vector< int > m_EclusterU
external flag of u-cluster
int m_EeventNumber
external iterator of event in the run
std::vector< double > m_EpositionEntryX
external position at entry point, coordinate x
Definition HitXPModule.h:97
int m_numberHitPerTrackTiSel
tight selected counter of the number of the hit for each track
Definition HitXPModule.h:93
std::vector< hitXP > m_hitXPTiSel
tight selected vector of hitXP
Definition HitXPModule.h:90
int m_eventNumber
interative number of the event in the run
Definition HitXPModule.h:76
int m_numberHitPerTrack
counter of the number of the hit for each track
Definition HitXPModule.h:77
TFile * m_outputFileTiSel
tight selected output file
Definition HitXPModule.h:89
void beginRun() override
Called when entering a new run.
int m_trackNumber
iterative number of the track in the run
Definition HitXPModule.h:75
std::set< hitXP, hitXP::timeCompare > m_hitXPSet
set of the hitXP, used to order tn time he hit
Definition HitXPModule.h:72
TFile * m_outputFileExt
external output file
Definition HitXPModule.h:95
std::vector< double > m_EpositionEntryZ
external position at entry point, coordinate z
Definition HitXPModule.h:99
int m_eventNumberSel
selected interative number of the event in the run
Definition HitXPModule.h:85
std::vector< double > m_Emomentum0Z
external momentum at IP, coordinate z
int m_trackNumberTiSel
tight selected iterative number of the track in the run
Definition HitXPModule.h:91
std::vector< double > m_Ephi00
external phi0 parameter at IP
std::vector< double > m_Echarge
external charge
int m_numberHitPerTrackSel
selected counter of the number of the hit for each track
Definition HitXPModule.h:86
std::vector< hitXP > m_hitXP
vector of the hitXP, used to fill the output tree
Definition HitXPModule.h:71
int m_EtrackNumber
external iterator of track in the run
std::vector< double > m_EpositionEntryY
external position at entry point, coordinate y
Definition HitXPModule.h:98
int m_eventIterator
iterator used to count event number (m_eventNumber)
Definition HitXPModule.h:79
std::vector< double > m_Ed0Entry
external d0 parameter at entry point
StoreArray< MCParticle > m_MCParticles
MCParticles StoreArray.
std::vector< double > m_Ez00
external z0 parameter at IP
std::vector< double > m_Eomega0
external omega parameter at IP
std::vector< double > m_Eposition0Z
external position at IP, coordinate z
int m_EnumberHitPerTrack
external number of the hit for each track
std::vector< double > m_Eposition0Y
external position at IP, coordinate y
std::vector< double > m_Ez0Entry
external z0 parameter at entry point
Module()
Constructor.
Definition Module.cc:30
Accessor to arrays stored in the data store.
Definition StoreArray.h:113
Abstract base class for different kinds of events.