-
Notifications
You must be signed in to change notification settings - Fork 0
/
Copy pathfakefit.C
executable file
·140 lines (117 loc) · 3.49 KB
/
fakefit.C
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
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
#include <vector>
#include "TString.h"
#include "TFile.h"
#include "THStack.h"
void fakefit(){
vector<TString> sigSS_str;
vector<TFile*> sigSS;
vector<TString> MC_str;
vector<TFile*> MC;
TH1F *h_sigSS;
TH1F *h_sigOS;
TH1F *h_sigSSBG;
TH1F *h_sigSSFR;
TH1F *h_sigSSTOT;
TH1F *h_bgSS;
TH1F *h_bgOS;
TH1F *h_fake;
TH1F *h_flip;
THStack *hstack;
sigSS_str.push_back("SingleMu_FR.root");
//MC_str.push_back("DY_10-50_FR.root");
//MC_str.push_back("DY_50_FR.root");
//MC_str.push_back("ttbar_FR.root");
MC_str.push_back("ZZ_inclusive_FR.root");
MC_str.push_back("WZ_inclusive_FR.root");
//MC_str.push_back("WW_inclusive_FR.root");
MC_str.push_back("WpWp_FR.root");
MC_str.push_back("WmWm_FR.root");
MC_str.push_back("ttZ_FR.root");
MC_str.push_back("ttW_FR.root");
MC_str.push_back("ttWW_FR.root");
MC_str.push_back("WWW_FR.root");
MC_str.push_back("ZZZ_FR.root");
MC_str.push_back("WWZ_FR.root");
MC_str.push_back("WZZ_FR.root");
/*#MC_str.push_back("W_jets_FR.root");
#MC_str.push_back("QCD_mu15_FR.root");*/
for(int i = 0; i < sigSS_str.size(); i++) {
TFile *f_tmp = new TFile(sigSS_str.at(i), "READ");
sigSS.push_back(f_tmp);
}
for(int i = 0; i < MC_str.size(); i++) {
TFile *f_tmp = new TFile(MC_str.at(i), "READ");
MC.push_back(f_tmp);
}
h_sigSS = (TH1F*)sigSS.at(0)->Get("NoJets_SS/h_NoJets_SS_pt");
h_sigOS = (TH1F*)sigSS.at(0)->Get("NoJets_OS/h_NoJets_OS_pt");
h_fake = (TH1F*)sigSS.at(0)->Get("TotalFakes/h_secondMuonPt_tf_TOTDY");
h_bgSS = (TH1F*)MC.at(0)->Get("NoJets_SS/h_NoJets_SS_pt");
h_bgOS = (TH1F*)MC.at(0)->Get("NoJets_OS/h_NoJets_OS_pt");
hstack = new THStack("hstack", "Signal and Background plots");
for(int i = 1; i < MC.size(); i++) {
TH1F *h_tmp = (TH1F*)MC.at(i)->Get("NoJets_SS/h_NoJets_SS_pt");
h_bgSS->Add(h_tmp,1);
h_tmp = (TH1F*)MC.at(i)->Get("NoJets_OS/h_NoJets_OS_pt");
h_bgOS->Add(h_tmp,1);
}
TCanvas c;
//h_sigSS->SetFillColor(kBlue);
h_sigSS->SetLineColor(kBlack);
h_sigSS->SetMarkerColor(kBlack);
h_sigSS->SetMarkerColor(kBlack);
h_sigSSBG = (TH1F*)h_sigSS->Clone();
h_sigSSBG->Add(h_bgSS,-1);
h_sigOS->Add(h_bgOS,-1);
h_sigSS->Sumw2();
h_sigOS->Sumw2();
h_sigSSBG->Sumw2();
//h_sigSSBG->Draw();
h_bgSS->SetFillColor(kRed);
h_bgSS->SetLineColor(kBlack);
gStyle->SetOptStat(0);
//c.SaveAs("Sig_minus_BG.pdf");
//c.SaveAs("Sig_minus_BG.eps");
h_sigSSFR = (TH1F*)h_sigSS->Clone();
h_sigSSFR->Add(h_fake,-1);
h_fake->SetFillColor(kGreen+2);
h_fake->SetLineColor(kBlack);
//h_sigSSFR->Draw();
gStyle->SetOptStat(0);
//c.SaveAs("Sig_minus_Fake.pdf");
//c.SaveAs("Sig_minus_Fake.eps");
h_sigSSTOT = (TH1F*)h_sigSSBG->Clone();
h_sigSSTOT->Add(h_fake,-1);
//h_sigSSTOT->Draw();
h_sigSSTOT->SetFillColor(kBlue);
//hstack->Add(h_sigSS);
hstack->Add(h_bgSS);
hstack->Add(h_fake);
//hstack->Add(h_sigSSTOT);
gStyle->SetOptStat(0);
//c.SaveAs("Sig_minus_All.pdf");
//c.SaveAs("Sig_minus_All.eps");
//h_sigSS->Draw();
TLegend *legend = new TLegend(.65, 0.945 - 4*0.065, .93, 0.91);
legend->SetFillColor(0);
legend->AddEntry(h_sigSS, "Signal", "ple");
legend->AddEntry(h_bgSS, "MC", "fl");
legend->AddEntry(h_fake, "Fakes", "fl");
//legend->AddEntry(h_sigSSTOT, "Signal - MC - fakes", "fl");
gPad->SetLogy();
//h_sigSS->Draw();
hstack->Draw("9histsame");
h_sigSS->Draw("same");
legend->Draw("same");
//c.SaveAs("hstack.pdf");
//c.SaveAs("hstack.eps");
h_flip = (TH1F*)h_sigSSTOT->Clone();
h_flip->Divide(h_sigOS);
h_flip->Draw();
gStyle->SetOptStat(0);
c.SaveAs("Charge_Filp_Rate.pdf");
h_flip->SetAxisRange(10,10e3, "X");
gPad->SetLogx();
c.SaveAs("Charge_Filp_Rate_log.pdf");
c.SaveAs("Charge_Filp_Rate_log.eps");
}