8 #include <svd/modules/svdPerformance/SVDB4CommissioningPlotsModule.h>
9 #include <framework/datastore/RelationVector.h>
11 #include <mdst/dataobjects/HitPatternVXD.h>
12 #include <vxd/geometry/GeoCache.h>
14 #include <boost/foreach.hpp>
21 SVDB4CommissioningPlotsModule::SVDB4CommissioningPlotsModule() :
Module()
22 , m_nTracks(0), m_Pvalue(), m_mom(0), m_nSVDhits(0)
25 setDescription(
"This module check performances of SVD reconstruction on Commissioning data");
27 addParam(
"outputFileName",
m_rootFileName,
"Name of output root file.", std::string(
"SVDB4CommissioningPlots_output.root"));
31 addParam(
"TrackListName",
m_TrackName,
"Name of Track Store Array.", std::string(
"Tracks"));
34 "Set true to produce the plots for RecoDigits (false by default)",
m_plotRecoDigits);
63 TH1F hRecoCharge(
"reco_charge_L@layerL@ladderS@sensor@view",
64 "Charge of RecoDigits in @layer.@ladder.@sensor @view/@side side",
66 hRecoCharge.GetXaxis()->SetTitle(
"charge (ke-)");
69 TH1F hRecoEnergy(
"reco_energy_L@layerL@ladderS@sensor@view",
70 "Energy of RecoDigits in @layer.@ladder.@sensor @view/@side side",
72 hRecoEnergy.GetXaxis()->SetTitle(
"energy (keV)");
75 TH1F hRecoTime(
"reco_time_L@layerL@ladderS@sensor@view",
76 "Time of RecoDigits in @layer.@ladder.@sensor @view/@side side",
78 hRecoTime.GetXaxis()->SetTitle(
"time (ns)");
81 TH1F hRecoNoise(
"reco_noise_L@layerL@ladderS@sensor@view",
82 "Noise of RecoDigits in @layer.@ladder.@sensor @view/@side side",
84 hRecoNoise.GetXaxis()->SetTitle(
"strip noise (e-)");
88 TH1F hClusterCharge(
"cluster_charge_L@layerL@ladderS@sensor@view",
89 "Charge of Clusters in @layer.@ladder.@sensor @view/@side side",
91 hClusterCharge.GetXaxis()->SetTitle(
"charge (ke-)");
94 TH1F hClusterSize(
"cluster_size_L@layerL@ladderS@sensor@view",
95 "Clusters Size for @layer.@ladder.@sensor @view/@side side",
97 hClusterSize.GetXaxis()->SetTitle(
"cluster size");
100 TH1F hClusterSNR(
"cluster_SNR_L@layerL@ladderS@sensor@view",
101 "SNR of Clusters in @layer.@ladder.@sensor @view/@side side",
103 hClusterSNR.GetXaxis()->SetTitle(
"SNR");
106 TH1F hClusterEnergy(
"cluster_energy_L@layerL@ladderS@sensor@view",
107 "Energy of Clusters in @layer.@ladder.@sensor @view/@side side",
109 hClusterEnergy.GetXaxis()->SetTitle(
"energy (keV)");
112 TH1F hClusterTime(
"cluster_time_L@layerL@ladderS@sensor@view",
113 "Time of Clusters in @layer.@ladder.@sensor @view/@side side",
115 hClusterTime.GetXaxis()->SetTitle(
"time (ns)");
119 TH1F hClusterTrkCharge(
"clusterTrk_charge_L@layerL@ladderS@sensor@view",
120 "Charge of Clusters Related to Tracks in @layer.@ladder.@sensor @view/@side side",
122 hClusterTrkCharge.GetXaxis()->SetTitle(
"charge (ke-)");
125 TH1F hClusterTrkSize(
"clusterTrk_size_L@layerL@ladderS@sensor@view",
126 "Cluster Size for @layer.@ladder.@sensor @view/@side side",
128 hClusterTrkSize.GetXaxis()->SetTitle(
"cluster size");
131 TH1F hClusterTrkSNR(
"clusterTrk_SNR_L@layerL@ladderS@sensor@view",
132 "SNR of Clusters Related to Tracks in @layer.@ladder.@sensor @view/@side side",
134 hClusterTrkSNR.GetXaxis()->SetTitle(
"SNR");
137 TH1F hClusterTrkEnergy(
"clusterTrk_energy_L@layerL@ladderS@sensor@view",
138 "Energy of Clusters Related to Tracks in @layer.@ladder.@sensor @view/@side side",
140 hClusterTrkEnergy.GetXaxis()->SetTitle(
"energy (keV)");
143 TH1F hClusterTrkTime(
"clusterTrk_time_L@layerL@ladderS@sensor@view",
144 "Time of Clusters Related to Tracks in @layer.@ladder.@sensor @view/@side side",
146 hClusterTrkTime.GetXaxis()->SetTitle(
"time (ns)");
149 TH1F hClusterTrkInterstripPos(
"clusterTrk_interstripPos_L@layerL@ladderS@sensor@view",
150 "Interstrip Position of Clusters Related to Tracks in @layer.@ladder.@sensor @view/@side side",
152 hClusterTrkInterstripPos.GetXaxis()->SetTitle(
"interstrip position");
156 m_nTracks =
new TH1F(
"h1nTracks",
"number of Tracks per event", 50, 0, 50);
157 m_nTracks->GetXaxis()->SetTitle(
"n Tracks");
158 m_Pvalue =
new TH1F(
"h1pValue",
"Tracks p value", 100, 0, 1);
159 m_Pvalue->GetXaxis()->SetTitle(
"p value");
160 m_mom =
new TH1F(
"h1momentum",
" Tracks Momentum", 200, 0, 10);
161 m_mom->GetXaxis()->SetTitle(
"p (GeV/c)");
162 m_nSVDhits =
new TH1F(
"h1nSVDhits",
"# SVD hits per track", 20, 0, 20);
163 m_nSVDhits->GetXaxis()->SetTitle(
"# SVD hits");
174 float c_eTOkeV = 3.6 / 1000;
193 for (
int cl = 0 ; cl < (int)svdClustersTrack.
size(); cl++) {
195 float clCharge = svdClustersTrack[cl]->getCharge();
196 float clEnergy = svdClustersTrack[cl]->getCharge() * c_eTOkeV;
197 int clSize = svdClustersTrack[cl]->getSize();
198 float clSN = svdClustersTrack[cl]->getSNR();
199 float clTime = svdClustersTrack[cl]->getClsTime();
200 float clPosition = svdClustersTrack[cl]->getPosition();
202 int side = svdClustersTrack[cl]->isUCluster();
208 float clInterstripPos = fmod(clPosition, pitch) / pitch;
224 B2DEBUG(29,
"%%%%%%%% NEW EVENT, number of Tracks = " <<
m_Tracks.getEntries());
229 for (
int digi = 0 ; digi <
m_svdRecos.getEntries(); digi++) {
257 bool isAssigned =
false;
259 if (theRC.
size() > 0) {
283 B2INFO(
"SVDB4CommissioningPlotsModule::endRun(), writing the histograms");
288 TDirectory* oldDir = gDirectory;
290 TDirectory* dir_track = oldDir->mkdir(
"tracks");
297 TDirectory* dir_reco = oldDir->mkdir(
"recoDigits");
298 TDirectory* dir_clusterAssigned = oldDir->mkdir(
"clusters_assigned");
299 TDirectory* dir_clusterNotAssigned = oldDir->mkdir(
"clusters_not_assigned");
304 TString layerName = Form(
"layer%d", layer.getLayerNumber());
305 TDirectory* dir_reco_layer = dir_reco->mkdir(layerName.Data());
306 TDirectory* dir_clusterAssigned_layer = dir_clusterAssigned->mkdir(layerName.Data());
307 TDirectory* dir_clusterNotAssigned_layer = dir_clusterNotAssigned->mkdir(layerName.Data());
308 for (
auto ladder : geoCache.getLadders(layer))
313 dir_reco_layer->cd();
319 dir_clusterAssigned_layer->cd();
326 dir_clusterNotAssigned_layer->cd();
static const ChargedStable pion
charged pion particle
void setDescription(const std::string &description)
Sets the description of the module.
Class for type safe access to objects that are referred to in relations.
size_t size() const
Get number of relations.
std::string m_rootFileName
root file name
TH1F * m_nSVDhits
track momentum
SVDHistograms< TH1F > * h_clusterTrkSNR
SVDClusters SNR.
bool m_plotRecoDigits
Produce plots for SVDRecoDigits when True.
SVDHistograms< TH1F > * h_clusterTrkCharge
SVDClusters Charge.
virtual void initialize() override
check StoreArrays & create rootfile
StoreArray< SVDCluster > m_svdClusters
SVDCluster StoreArray.
virtual void event() override
fill histograms
StoreArray< TrackFitResult > m_tfr
TrackFitResult StoreArray.
SVDNoiseCalibrations m_NoiseCal
SVDNoise Calibrations db object.
virtual void endRun() override
write histogrmas
TH1F * m_Pvalue
track p value
SVDHistograms< TH1F > * h_recoEnergy
SVDRecoDigits Energy.
int m_ntracks
number of tracks
TH1F * m_mom
track momentum
SVDHistograms< TH1F > * h_clusterTrkEnergy
SVDClusters Energy.
SVDHistograms< TH1F > * h_clusterEnergy
SVDClusters Energy.
SVDHistograms< TH1F > * h_clusterSNR
SVDClusters SNR.
std::string m_TrackName
Track StoreArray name.
std::string m_RecoDigitName
SVDRecoDigit StoreArray name.
SVDHistograms< TH1F > * h_recoNoise
SVDRecoDigits Noise.
virtual void beginRun() override
create histograms
std::string m_TrackFitResultName
TrackFitResult name.
SVDHistograms< TH1F > * h_clusterSize
SVDClusters Size.
SVDHistograms< TH1F > * h_recoCharge
SVDRecoDigits Charge.
SVDHistograms< TH1F > * h_clusterTime
SVDClusters Time.
TH1F * m_nTracks
number of tracks
SVDHistograms< TH1F > * h_recoTime
SVDRecoDigits Time.
StoreArray< RecoTrack > m_recoTracks
RecoTrack StoreArray.
std::string m_ClusterName
SVDCluster StoreArray name.
StoreArray< SVDRecoDigit > m_svdRecos
SVDRecoDigit StoreArray.
SVDHistograms< TH1F > * h_clusterTrkTime
SVDClusters Time.
SVDHistograms< TH1F > * h_clusterCharge
SVDClusters Charge.
StoreArray< Track > m_Tracks
Track StoreArray.
TFile * m_rootFilePtr
pointer at root file used for storing histograms
SVDHistograms< TH1F > * h_clusterTrkSize
SVDClusters Size.
SVDHistograms< TH1F > * h_clusterTrkInterstripPos
SVDClusters InterstripPosition.
int m_nEvents
number of events
void fill(const VxdID &vxdID, int view, Types ... args)
fill the histogram for
H * getHistogram(const VxdID &vxdID, int view)
get a reference to the histogram for
float getNoiseInElectrons(const VxdID &sensorID, const bool &isU, const unsigned short &strip) const
This method provides the correct noise conversion into electrons, taking into account that the noise ...
bool isRequired(const std::string &name="")
Ensure this array/object has been registered previously.
bool isOptional(const std::string &name="")
Tell the DataStore about an optional input.
int getEntries() const
Get the number of objects in the array.
Values of the result of a track fit with a given particle hypothesis.
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.
HitPatternVXD getHitPatternVXD() const
Getter for the hit pattern in the VXD;.
Class that bundles various TrackFitResults.
Class to faciliate easy access to sensor information of the VXD like coordinate transformations or pi...
const SensorInfoBase & getSensorInfo(Belle2::VxdID id) const
Return a referecne to the SensorInfo of a given SensorID.
static GeoCache & getInstance()
Return a reference to the singleton instance.
Base class to provide Sensor Information for PXD and SVD.
double getUPitch(double v=0) const
Return the pitch of the sensor.
double getVPitch(double v=0) const
Return the pitch of the sensor.
Class to uniquely identify a any structure of the PXD and SVD.
unsigned short baseType
The base integer type for VxdID.
void addParam(const std::string &name, T ¶mVariable, const std::string &description, const T &defaultValue)
Adds a new parameter to the module.
#define REG_MODULE(moduleName)
Register the given module (without 'Module' suffix) with the framework.
Abstract base class for different kinds of events.