1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
|
#include <TH2F.h>
void ResolutionPlots_HistoMaker(const std::string& unit) {
int n = 20;
float numbers[] = {1.0, 2.0, 3.0, 4.0, 5.0, 6.0, 7.0, 8.0, 9.0, 10.0,
11.0, 12.0, 13.0, 14.0, 15.0, 16.0, 17.0, 18.0, 19.0, 20.0};
std::string YAxisTitle;
std::string HistoTitle;
std::string OutputFile;
std::string RootFile;
float UL[20] = {0};
float NonUL[20] = {0};
if (unit == "centimetres") {
float UL_Array[] = {0.00137706, 0.00142804, 0.00223064, 0.00313546, 0.00528442, 0.00328381, 0.00365521,
0.00362465, 0.00404834, 0.00304523, 0.00154502, 0.00103244, 0.0108947, 0,
0.0030021, 0.00229157, 0.00244635, 0.00576464, 0.00461518, 0.00464276};
float NonUL_Array[] = {0.00211815, 0.00243601, 0.002224, 0.00223777, 0.00284721, 0.00306343, 0.00310523,
0.00334504, 0.00333095, 0.00326225, 0.00331065, 0.00237821, 0.00233033, 0,
0.00285122, 0.00287095, 0.00226949, 0.0030951, 0.00284769, 0.00285031};
for (int i = 0; i < 20; i++) {
UL[i] = UL_Array[i];
NonUL[i] = NonUL_Array[i];
}
YAxisTitle = "Resolution [cm]";
HistoTitle = "Resolution values for UL and non-UL samples, in centimetres";
OutputFile = "ResolutionComparison_ULAndNonUL_Centimetres.pdf";
RootFile = "ResolutionComparison_ULAndNonUL_Centimetres.root";
} else if (unit == "pitch units") {
float UL_Array[] = {0.172131, 0.143091, 0.161787, 0.126722, 0.17909, 0.197285, 0.180396,
0.170818, 0.182258, 0.166405, 0.0844271, 0.0846207, 0.0400775, 0,
0.120119, 0.171899, 0.160656, 0.18299, 0.177929, 0.178037};
float NonUL_Array[] = {0.153758, 0.151801, 0.14859, 0.148245, 0.147986, 0.146962, 0.147919,
0.147431, 0.146219, 0.145619, 0.14549, 0.147042, 0.147267, 0,
0.146873, 0.153169, 0.151639, 0.146694, 0.148681, 0.148683};
for (int i = 0; i < 20; i++) {
UL[i] = UL_Array[i];
NonUL[i] = NonUL_Array[i];
}
YAxisTitle = "Resolution [pitch units]";
HistoTitle = "Resolution values for the UL and non-UL samples in pitch units";
OutputFile = "ResolutionComparison_ULAndNonUL_PitchUnits.pdf";
RootFile = "ResolutionComparison_ULAndNonUL_PitchUnits.root";
} else {
std::cout << "ERROR: Unit must be centimetres or pitch units" << std::endl;
}
auto c1 = new TCanvas("c1", "c1", 800, 600);
TGraph* gr1 = new TGraph(n, numbers, UL);
gr1->SetName("UL samples");
gr1->SetTitle("UL samples");
gr1->SetMarkerStyle(21);
gr1->SetDrawOption("AP");
gr1->SetLineColor(0);
gr1->SetLineWidth(4);
gr1->SetFillStyle(0);
TGraph* gr2 = new TGraph(n, numbers, NonUL);
gr2->SetName("Non-UL samples");
gr2->SetTitle("Non-UL samples");
gr2->SetMarkerStyle(22);
gr2->SetMarkerColor(2);
gr2->SetDrawOption("P");
gr2->SetLineColor(0);
gr2->SetLineWidth(0);
gr2->SetFillStyle(0);
TMultiGraph* mg = new TMultiGraph();
mg->Add(gr1);
mg->Add(gr2);
mg->GetHistogram()->SetTitle(HistoTitle.c_str());
mg->GetHistogram()->SetTitleOffset(0.05);
mg->GetHistogram()->GetXaxis()->SetTitle("Region");
mg->GetHistogram()->GetXaxis()->SetTitleOffset(2.5);
c1->SetBottomMargin(0.2);
mg->GetHistogram()->GetXaxis()->SetBinLabel(1.0, "TIB L1");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(2.0), "TIB L2");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(3.0), "TIB L3");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(4.0), "TIB L4");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(5.0), "Side TID");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(6.0), "Wheel TID");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(7.0), "Ring TID");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(8.0), "TOB L1");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(9.0), "TOB L2");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(10.0), "TOB L3");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(11.0), "TOB L4");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(12.0), "TOB L5");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(13.0), "TOB L6");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(14.0), "Side TEC");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(15.0), "Wheel TEC");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(16.0), "Ring TEC");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(17.0), "TIB (All)");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(18.0), "TOB (All)");
mg->GetHistogram()->GetXaxis()->SetBinLabel(mg->GetHistogram()->GetXaxis()->FindBin(19.0), "TID (All)");
mg->GetHistogram()->GetXaxis()->SetBinLabel(100, "TEC (All)");
mg->GetHistogram()->GetYaxis()->SetTitle(YAxisTitle.c_str());
mg->Draw("ALP");
c1->BuildLegend();
mg->SaveAs(OutputFile.c_str());
TFile* output = new TFile(RootFile.c_str(), "RECREATE");
output->cd();
mg->Write();
output->Close();
}
void ResolutionPlots() {
ResolutionPlots_HistoMaker("centimetres");
ResolutionPlots_HistoMaker("pitch units");
}
|