ATLAS Offline Software
Loading...
Searching...
No Matches
Muon::MuonSegmentSlimPlots Class Reference

#include <MuonSegmentSlimPlots.h>

Inheritance diagram for Muon::MuonSegmentSlimPlots:
Collaboration diagram for Muon::MuonSegmentSlimPlots:

Public Member Functions

 MuonSegmentSlimPlots (PlotBase *pParent, const std::string &sDir)
 ~MuonSegmentSlimPlots ()
void fill (const xAOD::MuonSegment &muonSeg, float weight=1.0)
void initialize ()
void finalize ()
void setDetailLevel (int iDetailLevel)
void RegisterSubPlot (PlotBase *pPlotBase)
std::vector< HistDataretrieveBookedHistograms ()
 Retrieve all booked histograms.
std::vector< TreeDataretrieveBookedTrees ()
 Retrieve all booked trees.
std::vector< EfficiencyDataretrieveBookedEfficiencies ()
 Retrieve all booked efficiency objects.
TTree * BookTree (std::string_view name, bool prependDir=true)
 Book a TTree.
const std::string & getDirectory ()
Methods to book monitoring histograms

Note: methods starting with capitals should be deprecated in favour of camel-cased methods

TH1D * Book1D (std::string_view name, std::string_view labels, int nBins, float start, float end, bool prependDir=true)
 Book a TH1D histogram.
TH1D * Book1D (std::string_view name, TH1 *refHist, std::string_view labels, bool prependDir=true)
 Book a TH1D histogram using refHist as reference for number of bins and axis range.
TH2F * Book2D (std::string_view name, std::string_view labels, int nBinsX, float startX, float endX, int nBinsY, float startY, float endY, bool prependDir=true)
 Book a TH2F histogram.
TH2F * Book2D (std::string_view name, TH2 *refHist, std::string_view labels, bool prependDir=true)
 Book a TH2D histogram using refHist as reference for number of bins and axis range.
TH2F * Book2D (std::string_view name, std::string_view labels, int nBinsX, Double_t *binsX, int nBinsY, Double_t startY, Double_t endY, bool prependDir=true)
 Book a TH2F histogram with variable x axis binning.
TH3F * Book3D (std::string_view name, std::string_view labels, int nBinsX, float startX, float endX, int nBinsY, float startY, float endY, int nBinsZ, float startZ, float endZ, bool prependDir=true)
 Book a TH3F histogram.
TH3F * Book3D (std::string_view name, TH3 *refHist, std::string_view labels, bool prependDir=true)
 Book a TH3F histogram using refHist as reference for number of bins and axis range.
TProfile * BookTProfile (std::string_view name, std::string_view labels, int nBinsX, float startX, float endX, float startY=-1, float endY=-1, bool prependDir=true, bool useRMS=false)
 Book a TProfile histogram.
TProfile * BookTProfile (std::string_view name, std::string_view labels, int nBinsX, float *binsX, bool prependDir=true)
 Book a TProfile histogram with variable binning in x-axis.
TProfile * BookTProfileRangeY (std::string_view name, std::string_view labels, int nBinsX, double *binsX, double startY, double endY, bool prependDir=true)
 Book a TProfile histogram with variable binning in x-axis and limits in y-values.
TProfile2D * BookTProfile2D (std::string_view name, std::string_view labels, const int nBinsX, const double xlo, const double xhi, const int nBinsY, const double ylo, const double yhi, bool prependDir=true, bool useRMS=false)
 Book a TProfile 2D histogram with variable binning in x-axis and limits in y-values.
TProfile2D * BookTProfile2D (std::string_view name, std::string_view labels, const int nBinsX, double *binsX, const int nBinsY, double *binsY, bool prependDir=true, bool useRMS=false)
 Book a TProfile 2D histogram with variable binning in x-axis and limits in y-values.
TEfficiency * BookTEfficiency (std::string_view name, std::string_view labels, const int nBinsX, const float xlo, const float xhi, const bool prependDir=true)
 Book a (1-D) TEfficiency histogram.
TEfficiency * BookTEfficiency (std::string_view name, std::string_view labels, const int nBinsX, const float xlo, const float xhi, const int nBinsy, const float ylo, const float yhi, const bool prependDir=true)
 Book a (2-D) TEfficiency histogram.

Public Attributes

TH1 * segmentfitChi2 {nullptr}
TH1 * segmentfitNdof {nullptr}
TH1 * segmentfitChi2oNdof {nullptr}
TH1 * t0 {nullptr}
TH1 * t0_top {nullptr}
TH1 * t0_bottom {nullptr}
TH1 * t0err {nullptr}
TH1 * t0err_top {nullptr}
TH1 * t0err_bottom {nullptr}
TH1 * nPrecisionHits {nullptr}
TH1 * nPhiLayers {nullptr}
TH1 * nTrigEtaLayers {nullptr}
TH1 * etaIndex {nullptr}
TH1 * sector {nullptr}
TH1 * etadir {nullptr}
TH1 * etadir_barrel {nullptr}
TH1 * etadir_endcap {nullptr}
TH1 * phidir {nullptr}
TH2 * etaphidir {nullptr}
TH1 * chamberIndex {nullptr}
TH2 * chamberIndex_perSector {nullptr}
TH2 * eff_chamberIndex_perSector_numerator {nullptr}
TH2 * eff_chamberIndex_perSector_denominator {nullptr}
TH2 * eff_chamberIndex_perSector {nullptr}

Static Public Attributes

static constexpr std::array< float, 17 > Chamberarea
static constexpr std::array< float, 17 > Chamberexpectedhits
static constexpr std::array< float, 17 > Chamberexpectedtrighits

Protected Attributes

std::vector< PlotBase * > m_vSubNodes
std::vector< HistDatam_vBookedHistograms
std::vector< TreeDatam_vBookedTrees
std::vector< EfficiencyDatam_vBookedEfficiencies
std::string m_sDirectory
int m_iDetailLevel

Private Member Functions

virtual void initializePlots ()
virtual void finalizePlots ()

Static Private Member Functions

static std::string constructPrefix (std::string dir, bool prependDir)

Detailed Description

Definition at line 18 of file MuonSegmentSlimPlots.h.

Constructor & Destructor Documentation

◆ MuonSegmentSlimPlots()

Muon::MuonSegmentSlimPlots::MuonSegmentSlimPlots ( PlotBase * pParent,
const std::string & sDir )

Definition at line 16 of file MuonSegmentSlimPlots.cxx.

18 : PlotBase(pParent, sDir) {
19
20 // booking histograms
22 "segmentfitChi2", "Segment fit #chi^{2};#chi^{2};Entries", 100, 0, 200);
23 segmentfitNdof = Book1D("segmentfitNdof",
24 "Segment fit N_{dof};N_{dof};Entries", 100, 0, 20);
26 "segmentfitChi2oNdof",
27 "Segment fit #chi^{2}/N_{dof};Segment fit #chi^{2}/N_{dof};Entries",
28 100, 0, 20);
29
30 t0 = Book1D("t0", "Segment Refit t_{0};t_{0};Entries", 100, -25, 25);
31 t0_top = Book1D("t0_top", "Segment Refit t_{0} for y>0;t_{0};Entries", 100,
32 -25, 25);
33 t0_bottom = Book1D("t0_bottom", "Segment Refit t_{0} for y<0;t_{0};Entries",
34 100, -25, 25);
35 t0err = Book1D("t0err", "Segment Refit t_{0} error;t_{0} error;Entries",
36 100, 0, 10);
37 t0err_top = Book1D("t0err_top",
38 "Segment Refit t_{0} error for y>0;t_{0} error;Entries",
39 100, 0, 10);
41 "t0err_bottom", "Segment Refit t_{0} error for y<0;t_{0} error;Entries",
42 100, 0, 10);
43
44 nPrecisionHits = Book1D("nPrecisionHits",
45 "Segment precision hits;hits;Entries", 20, 0, 20);
46 nPhiLayers = Book1D("nPhiLayers", "Segment phi layers;#phi layers;Entries",
47 10, 0, 10);
49 "nTrigEtaLayers",
50 "Segment eta trigger layers;#eta trigger layers;Entries", 10, 0, 10);
51
52 etaIndex = Book1D("etaIndex", "Segment #eta Index ;#eta index;Entries", 21,
53 -10.5, 10.5);
54 sector = Book1D("sector", "Segment phi sector;#phi sector;Entries", 16, 0.5,
55 16.5);
56
57 etadir =
58 Book1D("etadir", "Segment pointing direction eta;#eta_{dir};Entries",
59 100, -5, 5);
61 Book1D("etadir_barrel",
62 "Segment pointing direction eta, barrel;#eta_{dir};Entries", 100,
63 -5, 5);
65 Book1D("etadir_endcap",
66 "Segment pointing direction eta, endcap;#eta_{dir};Entries", 100,
67 -5, 5);
68 phidir =
69 Book1D("phidir", "Segment pointing direction phi;#phi_{dir};Entries",
70 64, -3.2, 3.2);
71 etaphidir =
72 Book2D("etaphidir",
73 "Segment pointing direction phi vs eta;#eta_{dir};#phi_{dir}",
74 64, -3.2, 3.2, 64, -3.2, 3.2);
75
76 chamberIndex = Book1D("chamberIndex", "Chamber index; Chamber Index",
77 chIdxMax, 0, chIdxMax);
79 Book2D("chamberIndex_perSector",
80 "Number of Segments per Chamber, normalized by solid angle; "
81 "Sector; Chamber Index ",
82 33, -16.5, 16.5, chIdxMax, 0, chIdxMax);
84 Book2D("eff_chamberIndex_perSector_numerator",
85 "Number of expected hits for Segments per Chamber; Sector; "
86 "Chamber Index ",
87 33, -16.5, 16.5, chIdxMax, 0, chIdxMax);
89 Book2D("eff_chamberIndex_perSector_denominator",
90 "Number of recorded precision hits for Segments per Chamber; "
91 "Sector; Chamber Index ",
92 33, -16.5, 16.5, chIdxMax, 0, chIdxMax);
94 "eff_chamberIndex_perSector",
95 "precision layer hit efficiency per chamber; Sector; Chamber Index ",
96 33, -16.5, 16.5, chIdxMax, 0, chIdxMax);
97 // chamberIndex_dtheta = Book2D("chamberIndex_dtheta","Segment #Delta#theta
98 // between position and momentum; #Delta#theta; Chamber Index ", 180,
99 // -90.0, 90.0, chIdxMax,0,chIdxMax);
100 for (int i = 1; i <= chamberIndex->GetXaxis()->GetNbins(); i++) {
101 const char* temp_chambername =
104 chamberIndex->GetBinLowEdge(i)))
105 .c_str();
106 chamberIndex->GetXaxis()->SetBinLabel(i, temp_chambername);
107 chamberIndex_perSector->GetYaxis()->SetBinLabel(i, temp_chambername);
108 eff_chamberIndex_perSector_numerator->GetYaxis()->SetBinLabel(
109 i, temp_chambername);
110 eff_chamberIndex_perSector_denominator->GetYaxis()->SetBinLabel(
111 i, temp_chambername);
112 eff_chamberIndex_perSector->GetYaxis()->SetBinLabel(i,
113 temp_chambername);
114 }
115}
TH1D * Book1D(std::string_view name, std::string_view labels, int nBins, float start, float end, bool prependDir=true)
Book a TH1D histogram.
Definition PlotBase.cxx:94
PlotBase(PlotBase *parent, std::string_view sDir)
Definition PlotBase.cxx:29
TH2F * Book2D(std::string_view name, std::string_view labels, int nBinsX, float startX, float endX, int nBinsY, float startY, float endY, bool prependDir=true)
Book a TH2F histogram.
Definition PlotBase.cxx:123
const std::string & chName(ChIndex index)
convert ChIndex into a string
ChIndex
enum to classify the different chamber layers in the muon spectrometer
constexpr int chIdxMax

◆ ~MuonSegmentSlimPlots()

Muon::MuonSegmentSlimPlots::~MuonSegmentSlimPlots ( )

Definition at line 117 of file MuonSegmentSlimPlots.cxx.

117{}

Member Function Documentation

◆ Book1D() [1/2]

TH1D * PlotBase::Book1D ( std::string_view name,
std::string_view labels,
int nBins,
float start,
float end,
bool prependDir = true )
inherited

Book a TH1D histogram.

Definition at line 94 of file PlotBase.cxx.

95 {
96 std::string prefix = constructPrefix(m_sDirectory, prependDir);
97 Bool_t oldstat = TH1::AddDirectoryStatus();
98 TH1::AddDirectory(false);
99 TH1D *hist = new TH1D(prefix.append(name).c_str(), labels.data(), nBins, start, end);
100 TH1::AddDirectory(oldstat);
101
102 hist->Sumw2();
103 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
104 return hist;
105}
static std::string constructPrefix(std::string dir, bool prependDir)
Definition PlotBase.cxx:289
std::vector< HistData > m_vBookedHistograms
Definition PlotBase.h:98
std::string m_sDirectory
Definition PlotBase.h:101

◆ Book1D() [2/2]

TH1D * PlotBase::Book1D ( std::string_view name,
TH1 * refHist,
std::string_view labels,
bool prependDir = true )
inherited

Book a TH1D histogram using refHist as reference for number of bins and axis range.

Definition at line 108 of file PlotBase.cxx.

108 {
109 std::string prefix = constructPrefix(m_sDirectory, prependDir);
110 Bool_t oldstat = TH1::AddDirectoryStatus();
111 TH1::AddDirectory(false);
112 TH1D *hist = new TH1D(prefix.append(name).c_str(), labels.data(), refHist->GetNbinsX(),
113 refHist->GetXaxis()->GetXbins()->GetArray());
114 hist->Sumw2();
115 TH1::AddDirectory(oldstat);
116
117
118 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
119 return hist;
120}

◆ Book2D() [1/3]

TH2F * PlotBase::Book2D ( std::string_view name,
std::string_view labels,
int nBinsX,
Double_t * binsX,
int nBinsY,
Double_t startY,
Double_t endY,
bool prependDir = true )
inherited

Book a TH2F histogram with variable x axis binning.

Definition at line 144 of file PlotBase.cxx.

145 {
146 std::string prefix = constructPrefix(m_sDirectory, prependDir);
147 Bool_t oldstat = TH2::AddDirectoryStatus();
148 TH2::AddDirectory(false);
149 TH2F *hist = new TH2F(prefix.append(name).c_str(), labels.data(), nBinsX, binsX, nBinsY, startY, endY);
150 hist->Sumw2();
151 TH2::AddDirectory(oldstat);
152 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
153 return hist;
154}
TH2F(name, title, nxbins, bins_par2, bins_par3, bins_par4, bins_par5=None, bins_par6=None, path='', **kwargs)

◆ Book2D() [2/3]

TH2F * PlotBase::Book2D ( std::string_view name,
std::string_view labels,
int nBinsX,
float startX,
float endX,
int nBinsY,
float startY,
float endY,
bool prependDir = true )
inherited

Book a TH2F histogram.

Definition at line 123 of file PlotBase.cxx.

124 {
125 std::string prefix = constructPrefix(m_sDirectory, prependDir);
126 Bool_t oldstat = TH2::AddDirectoryStatus();
127 TH2::AddDirectory(false);
128 TH2F *hist = new TH2F(prefix.append(name).c_str(), labels.data(), nBinsX, startX, endX, nBinsY, startY, endY);
129 hist->Sumw2();
130 TH2::AddDirectory(oldstat);
131
132
133 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
134 return hist;
135}

◆ Book2D() [3/3]

TH2F * PlotBase::Book2D ( std::string_view name,
TH2 * refHist,
std::string_view labels,
bool prependDir = true )
inherited

Book a TH2D histogram using refHist as reference for number of bins and axis range.

Definition at line 138 of file PlotBase.cxx.

138 {
139 return Book2D(name, labels, refHist->GetNbinsX(), refHist->GetXaxis()->GetXmin(), refHist->GetXaxis()->GetXmax(),
140 refHist->GetNbinsY(), refHist->GetYaxis()->GetXmin(), refHist->GetYaxis()->GetXmax(), prependDir);
141}

◆ Book3D() [1/2]

TH3F * PlotBase::Book3D ( std::string_view name,
std::string_view labels,
int nBinsX,
float startX,
float endX,
int nBinsY,
float startY,
float endY,
int nBinsZ,
float startZ,
float endZ,
bool prependDir = true )
inherited

Book a TH3F histogram.

Definition at line 157 of file PlotBase.cxx.

158 {
159 std::string prefix = constructPrefix(m_sDirectory, prependDir);
160 Bool_t oldstat = TH3::AddDirectoryStatus();
161 TH3::AddDirectory(false);
162 TH3F *hist = new TH3F(prefix.append(name).c_str(),
163 labels.data(), nBinsX, startX, endX, nBinsY, startY, endY, nBinsZ, startZ, endZ);
164 hist->Sumw2();
165 TH3::AddDirectory(oldstat);
166 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
167 return hist;
168}

◆ Book3D() [2/2]

TH3F * PlotBase::Book3D ( std::string_view name,
TH3 * refHist,
std::string_view labels,
bool prependDir = true )
inherited

Book a TH3F histogram using refHist as reference for number of bins and axis range.

Definition at line 171 of file PlotBase.cxx.

171 {
172 std::string prefix = constructPrefix(m_sDirectory, prependDir);
173 Bool_t oldstat = TH3::AddDirectoryStatus();
174 TH3::AddDirectory(false);
175 TH3F *hist = new TH3F(prefix.append(name).c_str(), labels.data(), refHist->GetNbinsX(),
176 refHist->GetXaxis()->GetXbins()->GetArray(), refHist->GetNbinsY(),
177 refHist->GetYaxis()->GetXbins()->GetArray(), refHist->GetNbinsZ(),
178 refHist->GetZaxis()->GetXbins()->GetArray());
179 TH3::AddDirectory(oldstat);
180
181 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
182 return hist;
183}

◆ BookTEfficiency() [1/2]

TEfficiency * PlotBase::BookTEfficiency ( std::string_view name,
std::string_view labels,
const int nBinsX,
const float xlo,
const float xhi,
const bool prependDir = true )
inherited

Book a (1-D) TEfficiency histogram.

Definition at line 257 of file PlotBase.cxx.

257 {
258 std::string prefix = constructPrefix(m_sDirectory, prependDir);
259 TEfficiency *hist = new TEfficiency(prefix.append(name).c_str(), labels.data(), nBinsX, xlo, xhi);
260 hist->SetDirectory(nullptr);
261 m_vBookedEfficiencies.emplace_back(hist, m_sDirectory);
262 return hist;
263}
std::vector< EfficiencyData > m_vBookedEfficiencies
Definition PlotBase.h:100

◆ BookTEfficiency() [2/2]

TEfficiency * PlotBase::BookTEfficiency ( std::string_view name,
std::string_view labels,
const int nBinsX,
const float xlo,
const float xhi,
const int nBinsy,
const float ylo,
const float yhi,
const bool prependDir = true )
inherited

Book a (2-D) TEfficiency histogram.

Definition at line 266 of file PlotBase.cxx.

266 {
267 std::string prefix = constructPrefix(m_sDirectory, prependDir);
268
269 TEfficiency *hist = new TEfficiency(prefix.append(name).c_str(), labels.data(), nBinsX, xlo, xhi, nBinsY, ylo, yhi);
270 hist->SetDirectory(nullptr);
271 m_vBookedEfficiencies.emplace_back(hist, m_sDirectory);
272
273 return hist;
274}

◆ BookTProfile() [1/2]

TProfile * PlotBase::BookTProfile ( std::string_view name,
std::string_view labels,
int nBinsX,
float * binsX,
bool prependDir = true )
inherited

Book a TProfile histogram with variable binning in x-axis.

Definition at line 204 of file PlotBase.cxx.

204 {
205 std::string prefix = constructPrefix(m_sDirectory, prependDir);
206 TProfile *hist(nullptr);
207 Bool_t oldstat = TProfile::AddDirectoryStatus();
208 TProfile::AddDirectory(false);
209
210 hist = new TProfile(prefix.append(name).c_str(), labels.data(), nBinsX, binsX);
211 TProfile::AddDirectory(oldstat);
212 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
213 return hist;
214}

◆ BookTProfile() [2/2]

TProfile * PlotBase::BookTProfile ( std::string_view name,
std::string_view labels,
int nBinsX,
float startX,
float endX,
float startY = -1,
float endY = -1,
bool prependDir = true,
bool useRMS = false )
inherited

Book a TProfile histogram.

Definition at line 186 of file PlotBase.cxx.

187 {
188 std::string prefix = constructPrefix(m_sDirectory, prependDir);
189 TProfile *hist(nullptr);
190 Bool_t oldstat = TProfile::AddDirectoryStatus();
191 TProfile::AddDirectory(false);
192 std::string opt = useRMS ? "S" : "";
193 if ((startY == -1) and (endY == -1)) {
194 hist = new TProfile(prefix.append(name).c_str(), labels.data(), nBinsX, startX, endX, opt.c_str());
195 } else {
196 hist = new TProfile(prefix.append(name).c_str(), labels.data(), nBinsX, startX, endX, startY, endY, opt.c_str());
197 }
198 TProfile::AddDirectory(oldstat);
199 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
200 return hist;
201}

◆ BookTProfile2D() [1/2]

TProfile2D * PlotBase::BookTProfile2D ( std::string_view name,
std::string_view labels,
const int nBinsX,
const double xlo,
const double xhi,
const int nBinsY,
const double ylo,
const double yhi,
bool prependDir = true,
bool useRMS = false )
inherited

Book a TProfile 2D histogram with variable binning in x-axis and limits in y-values.

Definition at line 231 of file PlotBase.cxx.

233 {
234 std::string prefix = constructPrefix(m_sDirectory, prependDir);
235 Bool_t oldstat = TProfile2D::AddDirectoryStatus();
236 TProfile2D::AddDirectory(false);
237 std::string opt = useRMS ? "S" : "";
238 TProfile2D *hist = new TProfile2D(prefix.append(name).c_str(), labels.data(), nBinsX, xlo, xhi, nBinsY, ylo, yhi, opt.c_str());
239 TProfile2D::AddDirectory(oldstat);
240 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
241 return hist;
242}

◆ BookTProfile2D() [2/2]

TProfile2D * PlotBase::BookTProfile2D ( std::string_view name,
std::string_view labels,
const int nBinsX,
double * binsX,
const int nBinsY,
double * binsY,
bool prependDir = true,
bool useRMS = false )
inherited

Book a TProfile 2D histogram with variable binning in x-axis and limits in y-values.

Definition at line 245 of file PlotBase.cxx.

245 {
246 std::string prefix = constructPrefix(m_sDirectory, prependDir);
247 Bool_t oldstat = TProfile2D::AddDirectoryStatus();
248 TProfile2D::AddDirectory(false);
249 std::string opt = useRMS ? "S" : "";
250 TProfile2D *hist = new TProfile2D(prefix.append(name).c_str(), labels.data(), nBinsX, binsX, nBinsY, binsY, opt.c_str());
251 TProfile2D::AddDirectory(oldstat);
252 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
253 return hist;
254}

◆ BookTProfileRangeY()

TProfile * PlotBase::BookTProfileRangeY ( std::string_view name,
std::string_view labels,
int nBinsX,
double * binsX,
double startY,
double endY,
bool prependDir = true )
inherited

Book a TProfile histogram with variable binning in x-axis and limits in y-values.

Definition at line 217 of file PlotBase.cxx.

218 {
219 std::string prefix = constructPrefix(m_sDirectory, prependDir);
220 TProfile *hist(nullptr);
221 Bool_t oldstat = TProfile::AddDirectoryStatus();
222 TProfile::AddDirectory(false);
223
224 hist = new TProfile(prefix.append(name).c_str(), labels.data(), (Int_t) nBinsX, binsX, startY, endY);
225 TProfile::AddDirectory(oldstat);
226 m_vBookedHistograms.emplace_back(hist, m_sDirectory);
227 return hist;
228}

◆ BookTree()

TTree * PlotBase::BookTree ( std::string_view name,
bool prependDir = true )
inherited

Book a TTree.

Definition at line 277 of file PlotBase.cxx.

277 {
278 std::string prefix = constructPrefix(m_sDirectory, prependDir);
279 TTree *tree = new TTree(prefix.append(name).c_str(), "");
280
281 tree->SetAutoSave(0);
282 tree->SetAutoFlush(0);
283 tree->SetDirectory(nullptr);
284 m_vBookedTrees.emplace_back(tree, m_sDirectory);
285 return tree;
286}
std::vector< TreeData > m_vBookedTrees
Definition PlotBase.h:99
TChain * tree

◆ constructPrefix()

std::string PlotBase::constructPrefix ( std::string dir,
bool prependDir )
staticprivateinherited

Definition at line 289 of file PlotBase.cxx.

289 {
290 if (!prependDir) {
291 return "";
292 }
293 std::replace(dir.begin(), dir.end(), '/', '_');
294 return dir;
295}

◆ fill()

void Muon::MuonSegmentSlimPlots::fill ( const xAOD::MuonSegment & muonSeg,
float weight = 1.0 )

Definition at line 119 of file MuonSegmentSlimPlots.cxx.

119 {
120 float chi2 = muSeg.chiSquared();
121 float ndof = muSeg.numberDoF();
122 segmentfitChi2->Fill(chi2, weight);
123 segmentfitNdof->Fill(ndof, weight);
124 if (ndof > 0) {
125 segmentfitChi2oNdof->Fill(muSeg.chiSquared() / muSeg.numberDoF(),
126 weight);
127 }
128
129 float y = muSeg.y();
130
131 float segt0 = muSeg.t0();
132 float segt0err = muSeg.t0error();
133
134 t0->Fill(segt0, weight);
135 t0err->Fill(segt0err, weight);
136 if (y > 0) {
137 t0_top->Fill(segt0, weight);
138 t0err_top->Fill(segt0err, weight);
139 } else {
140 t0_bottom->Fill(segt0, weight);
141 t0err_bottom->Fill(segt0err, weight);
142 }
143
144 sector->Fill(muSeg.sector(), weight);
145
146 nPrecisionHits->Fill(muSeg.nPrecisionHits(), weight);
147 nPhiLayers->Fill(muSeg.nPhiLayers(), weight);
148 nTrigEtaLayers->Fill(muSeg.nTrigEtaLayers(), weight);
149
150 int chIndex = static_cast<int>(muSeg.chamberIndex());
151 float chambernorm =
152 1 / Chamberarea[chIndex]; // weight of the segment using the chamber
153 // eta-phi area
154 chamberIndex->Fill(chIndex, weight);
155 int sectorIndex = muSeg.sector();
156 // fill the count of segments; switch the sign here to make the plots
157 if (muSeg.z() < 0) {
158 sectorIndex = -sectorIndex;
159 }
160 chamberIndex_perSector->Fill(sectorIndex, chIndex, chambernorm);
162 sectorIndex, chIndex,
163 (muSeg.nPrecisionHits() > Chamberexpectedhits[chIndex])
165 : muSeg.nPrecisionHits());
168 // update sector eta index plots; switch the sign back here to make the
169 // plots
170 sectorIndex = muSeg.sector();
171
172 // position and direction plots
173 // protect against cases with no hit information!
174 Amg::Vector3D globalDir{muSeg.px(), muSeg.py(), muSeg.pz()};
175
176 if (globalDir.mag() < DBL_EPSILON) {
177 return;
178 }
179
180 float eta = globalDir.eta();
181 float phi = globalDir.phi();
182 etadir->Fill(eta, weight);
183 phidir->Fill(phi, weight);
184 etaphidir->Fill(eta, phi);
185}
Scalar eta() const
pseudorapidity method
Scalar phi() const
phi method
#define y
static constexpr std::array< float, 17 > Chamberexpectedhits
static constexpr std::array< float, 17 > Chamberarea
double chi2(TH1 *h0, TH1 *h1)
Eigen::Matrix< double, 3, 1 > Vector3D
float ndof(const U &p)
ChIndex chIndex(const std::string &index)
convert ChIndex name string to enum

◆ finalize()

void PlotBase::finalize ( )
inherited

Definition at line 47 of file PlotBase.cxx.

47 {
48 for (auto *subNode: m_vSubNodes) {
49 subNode->finalize();
50 }
52}
std::vector< PlotBase * > m_vSubNodes
Definition PlotBase.h:97
virtual void finalizePlots()
Definition PlotBase.h:93

◆ finalizePlots()

◆ getDirectory()

const std::string & PlotBase::getDirectory ( )
inlineinherited

Definition at line 89 of file PlotBase.h.

89{return m_sDirectory;}

◆ initialize()

void PlotBase::initialize ( )
inherited

Definition at line 39 of file PlotBase.cxx.

39 {
40 for (auto *subNode: m_vSubNodes) {
41 subNode->initialize();
42 }
44}
virtual void initializePlots()
Definition PlotBase.h:92

◆ initializePlots()

virtual void PlotBase::initializePlots ( )
inlineprivatevirtualinherited

Reimplemented in DiTau::CorePlots, DiTau::ResolutionPlots, Egamma::ClusMomentumPlots, Egamma::ElectronFrwdPlots, Egamma::ElectronPlots, Egamma::IsolationPlots, Egamma::KinematicsPlots, Egamma::LRTElectronPlots, Egamma::PhotonAmbPlots, Egamma::PhotonCnvPlots, Egamma::PhotonConversionPlots, Egamma::PhotonPlots, Egamma::ShowerShapesPlots, Egamma::TrackPlots, ElectronValidationPlots, IDTPM::DuplicateRatePlots, IDTPM::EfficiencyPlots, IDTPM::FakeRatePlots, IDTPM::HitsOnTracksPlots, IDTPM::NtracksPlots, IDTPM::OfflineElectronPlots, IDTPM::ResolutionPlots, IDTPM::SummaryPlots, IDTPM::TrackParametersPlots, IDTPM::VertexParametersPlots, InDetBasicPlot, InDetPerfNtuple, InDetPerfPlot_Duplicate, InDetPerfPlot_Efficiency, InDetPerfPlot_FakeRate, InDetPerfPlot_HitEfficiency, InDetPerfPlot_HitResidual, InDetPerfPlot_Hits, InDetPerfPlot_nTracks, InDetPerfPlot_Resolution, InDetPerfPlot_TrackParameters, InDetPerfPlot_TrkInJet, InDetPerfPlot_TRTExtension, InDetPerfPlot_Vertex, InDetPerfPlot_VertexTruthMatching, InDetPerfPlot_VerticesVsMu, JetTagDQA::BTaggingValidationPlots, LRTElectronValidationPlots, Muon::BetaPlots, Muon::ChargeDepParamPlots, Muon::HitFracTypePlots, Muon::IsoCorrPlots, Muon::IsoPlots, Muon::MomentumPullPlots, Muon::MomentumTruthPullPlots, Muon::MuonParamElossPlots, Muon::MuonParamPlots, Muon::RecoInfoPlots, Muon::SlowMuonParamPlots, PFO::ClusterMomentPlots, PFO::ClusterPlots, PFO::FlowElement_LinkerPlots, PFO::LeptonFELinkerPlots, PFO::PFOAlgPropertyPlots, PFO::PFOAttributePlots, PFO::PFOCalibHitClusterMomentPlots, PFO::PFOClusterMomentPlots, PFO::PFOPlots, PFO::PFOPVMatchedPlots, PhotonValidationPlots, PhysVal::BTagPlots, PhysVal::EventInfoPlots, PhysVal::KinematicsPlots, PhysVal::METPlots, PhysVal::TrkAndVtxPlots, RecoLumiPlots, RecoMuonIDTrackPlots, RecoMuonPlots, RecoMuonSegmentPlots, RecoMuonTrackPlots, RecoPhysPlots, RecoVertexPlots, Tau::CorePlots, Tau::DecayModeMigration, Tau::EfficiencyPlots, Tau::EventPlots, Tau::EVetoPlots, Tau::GeneralTauPlots, Tau::ResolutionPlots, Tau::TauIDVariablesPlots, Tau::TauKinematicPlots, Tau::TauParticleFlowPlots, TCCPlots, Trk::DefParamPullPlots, Trk::EfficiencyPlots, Trk::ExtrLayerPlots, Trk::ExtrRegionPlots, Trk::HitResidualPlots, Trk::HitTypePlots, Trk::IDHitPlots, Trk::ImpactPlots, Trk::ParamPlots, Trk::RecoInfoPlots, Trk::ResolutionPlots, Trk::TruthInfoPlots, ZeeValidation::FWDZeePlots, ZeeValidation::ReconElectronsPlots, ZeeValidation::TrueElectronsPlots, ZeeValidation::TrueFwdElectronsPlots, and ZeeValidation::ZeePlots.

Definition at line 92 of file PlotBase.h.

92{;}

◆ RegisterSubPlot()

void PlotBase::RegisterSubPlot ( PlotBase * pPlotBase)
inlineinherited

Definition at line 42 of file PlotBase.h.

42{m_vSubNodes.push_back(pPlotBase);}

◆ retrieveBookedEfficiencies()

std::vector< EfficiencyData > PlotBase::retrieveBookedEfficiencies ( )
inherited

Retrieve all booked efficiency objects.

Definition at line 83 of file PlotBase.cxx.

83 {
84 std::vector<EfficiencyData> vBookedEfficiencies = m_vBookedEfficiencies;
85 for (const auto &subNode: m_vSubNodes) {
86 std::vector<EfficiencyData> subNodeHists = subNode->retrieveBookedEfficiencies();
87 vBookedEfficiencies.insert(vBookedEfficiencies.end(), subNodeHists.begin(), subNodeHists.end());
88 }
89 return vBookedEfficiencies;
90}

◆ retrieveBookedHistograms()

std::vector< HistData > PlotBase::retrieveBookedHistograms ( )
inherited

Retrieve all booked histograms.

Definition at line 63 of file PlotBase.cxx.

63 {
64 std::vector<HistData> vBookedHistograms = m_vBookedHistograms;
65 for (const auto &subNode: m_vSubNodes) {
66 std::vector<HistData> subNodeHists = subNode->retrieveBookedHistograms();
67 vBookedHistograms.insert(vBookedHistograms.end(), subNodeHists.begin(), subNodeHists.end());
68 }
69 return vBookedHistograms;
70}

◆ retrieveBookedTrees()

std::vector< TreeData > PlotBase::retrieveBookedTrees ( )
inherited

Retrieve all booked trees.

Definition at line 73 of file PlotBase.cxx.

73 {
74 std::vector<TreeData> vBookedTrees = m_vBookedTrees;
75 for (auto *subNode: m_vSubNodes) {
76 std::vector<TreeData> subNodeTrees = subNode->retrieveBookedTrees();
77 vBookedTrees.insert(vBookedTrees.end(), subNodeTrees.begin(), subNodeTrees.end());
78 }
79 return vBookedTrees;
80}

◆ setDetailLevel()

void PlotBase::setDetailLevel ( int iDetailLevel)
inherited

Definition at line 55 of file PlotBase.cxx.

55 {
56 for (auto *subNode: m_vSubNodes) {
57 subNode->setDetailLevel(iDetailLevel);
58 }
59 m_iDetailLevel = iDetailLevel;
60}
int m_iDetailLevel
Definition PlotBase.h:102

Member Data Documentation

◆ Chamberarea

std::array<float, 17> Muon::MuonSegmentSlimPlots::Chamberarea
staticconstexpr
Initial value:
{
0.465313, 0.589744, 0.393503, 0.516815, 0.404094, 0.588759,
0.0700091, 0.204258, 0.50283, 0.577781, 0.902194, 0.484968,
0.746214, 0.111742, 0.192025, 0.380506, 0.380506}

Definition at line 54 of file MuonSegmentSlimPlots.h.

54 {
55 0.465313, 0.589744, 0.393503, 0.516815, 0.404094, 0.588759,
56 0.0700091, 0.204258, 0.50283, 0.577781, 0.902194, 0.484968,
57 0.746214, 0.111742, 0.192025, 0.380506, 0.380506}; // eta * phi for

◆ Chamberexpectedhits

std::array<float, 17> Muon::MuonSegmentSlimPlots::Chamberexpectedhits
staticconstexpr
Initial value:
{
8.0, 8.0, 6.0, 6.0, 6.0, 6.0, 4.0, 8.0, 8.0,
6.0, 6.0, 6.0, 6.0, 6.0, 6.0, 4.0, 4.0}

Definition at line 59 of file MuonSegmentSlimPlots.h.

59 {
60 8.0, 8.0, 6.0, 6.0, 6.0, 6.0, 4.0, 8.0, 8.0,
61 6.0, 6.0, 6.0, 6.0, 6.0, 6.0, 4.0, 4.0}; // number of expected hits for

◆ Chamberexpectedtrighits

std::array<float, 17> Muon::MuonSegmentSlimPlots::Chamberexpectedtrighits
staticconstexpr
Initial value:
{
1.0, 1.0, 5.0, 5.0, 3.0, 3.0, 1.0, 2.0, 2.0,
7.0, 7.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0}

Definition at line 66 of file MuonSegmentSlimPlots.h.

66 {
67 1.0, 1.0, 5.0, 5.0, 3.0, 3.0, 1.0, 2.0, 2.0,
68 7.0, 7.0, 1.0, 1.0, 1.0, 1.0, 1.0, 1.0}; // number of expected hits for

◆ chamberIndex

TH1* Muon::MuonSegmentSlimPlots::chamberIndex {nullptr}

Definition at line 48 of file MuonSegmentSlimPlots.h.

48{nullptr};

◆ chamberIndex_perSector

TH2* Muon::MuonSegmentSlimPlots::chamberIndex_perSector {nullptr}

Definition at line 49 of file MuonSegmentSlimPlots.h.

49{nullptr};

◆ eff_chamberIndex_perSector

TH2* Muon::MuonSegmentSlimPlots::eff_chamberIndex_perSector {nullptr}

Definition at line 52 of file MuonSegmentSlimPlots.h.

52{nullptr};

◆ eff_chamberIndex_perSector_denominator

TH2* Muon::MuonSegmentSlimPlots::eff_chamberIndex_perSector_denominator {nullptr}

Definition at line 51 of file MuonSegmentSlimPlots.h.

51{nullptr};

◆ eff_chamberIndex_perSector_numerator

TH2* Muon::MuonSegmentSlimPlots::eff_chamberIndex_perSector_numerator {nullptr}

Definition at line 50 of file MuonSegmentSlimPlots.h.

50{nullptr};

◆ etadir

TH1* Muon::MuonSegmentSlimPlots::etadir {nullptr}

Definition at line 42 of file MuonSegmentSlimPlots.h.

42{nullptr};

◆ etadir_barrel

TH1* Muon::MuonSegmentSlimPlots::etadir_barrel {nullptr}

Definition at line 43 of file MuonSegmentSlimPlots.h.

43{nullptr};

◆ etadir_endcap

TH1* Muon::MuonSegmentSlimPlots::etadir_endcap {nullptr}

Definition at line 44 of file MuonSegmentSlimPlots.h.

44{nullptr};

◆ etaIndex

TH1* Muon::MuonSegmentSlimPlots::etaIndex {nullptr}

Definition at line 40 of file MuonSegmentSlimPlots.h.

40{nullptr};

◆ etaphidir

TH2* Muon::MuonSegmentSlimPlots::etaphidir {nullptr}

Definition at line 46 of file MuonSegmentSlimPlots.h.

46{nullptr};

◆ m_iDetailLevel

int PlotBase::m_iDetailLevel
protectedinherited

Definition at line 102 of file PlotBase.h.

◆ m_sDirectory

std::string PlotBase::m_sDirectory
protectedinherited

Definition at line 101 of file PlotBase.h.

◆ m_vBookedEfficiencies

std::vector<EfficiencyData> PlotBase::m_vBookedEfficiencies
protectedinherited

Definition at line 100 of file PlotBase.h.

◆ m_vBookedHistograms

std::vector<HistData> PlotBase::m_vBookedHistograms
protectedinherited

Definition at line 98 of file PlotBase.h.

◆ m_vBookedTrees

std::vector<TreeData> PlotBase::m_vBookedTrees
protectedinherited

Definition at line 99 of file PlotBase.h.

◆ m_vSubNodes

std::vector<PlotBase*> PlotBase::m_vSubNodes
protectedinherited

Definition at line 97 of file PlotBase.h.

◆ nPhiLayers

TH1* Muon::MuonSegmentSlimPlots::nPhiLayers {nullptr}

Definition at line 37 of file MuonSegmentSlimPlots.h.

37{nullptr};

◆ nPrecisionHits

TH1* Muon::MuonSegmentSlimPlots::nPrecisionHits {nullptr}

Definition at line 36 of file MuonSegmentSlimPlots.h.

36{nullptr};

◆ nTrigEtaLayers

TH1* Muon::MuonSegmentSlimPlots::nTrigEtaLayers {nullptr}

Definition at line 38 of file MuonSegmentSlimPlots.h.

38{nullptr};

◆ phidir

TH1* Muon::MuonSegmentSlimPlots::phidir {nullptr}

Definition at line 45 of file MuonSegmentSlimPlots.h.

45{nullptr};

◆ sector

TH1* Muon::MuonSegmentSlimPlots::sector {nullptr}

Definition at line 41 of file MuonSegmentSlimPlots.h.

41{nullptr};

◆ segmentfitChi2

TH1* Muon::MuonSegmentSlimPlots::segmentfitChi2 {nullptr}

Definition at line 25 of file MuonSegmentSlimPlots.h.

25{nullptr};

◆ segmentfitChi2oNdof

TH1* Muon::MuonSegmentSlimPlots::segmentfitChi2oNdof {nullptr}

Definition at line 27 of file MuonSegmentSlimPlots.h.

27{nullptr};

◆ segmentfitNdof

TH1* Muon::MuonSegmentSlimPlots::segmentfitNdof {nullptr}

Definition at line 26 of file MuonSegmentSlimPlots.h.

26{nullptr};

◆ t0

TH1* Muon::MuonSegmentSlimPlots::t0 {nullptr}

Definition at line 29 of file MuonSegmentSlimPlots.h.

29{nullptr};

◆ t0_bottom

TH1* Muon::MuonSegmentSlimPlots::t0_bottom {nullptr}

Definition at line 31 of file MuonSegmentSlimPlots.h.

31{nullptr};

◆ t0_top

TH1* Muon::MuonSegmentSlimPlots::t0_top {nullptr}

Definition at line 30 of file MuonSegmentSlimPlots.h.

30{nullptr};

◆ t0err

TH1* Muon::MuonSegmentSlimPlots::t0err {nullptr}

Definition at line 32 of file MuonSegmentSlimPlots.h.

32{nullptr};

◆ t0err_bottom

TH1* Muon::MuonSegmentSlimPlots::t0err_bottom {nullptr}

Definition at line 34 of file MuonSegmentSlimPlots.h.

34{nullptr};

◆ t0err_top

TH1* Muon::MuonSegmentSlimPlots::t0err_top {nullptr}

Definition at line 33 of file MuonSegmentSlimPlots.h.

33{nullptr};

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