Fork me on GitHub

source: svn/trunk/interface/FuncDef.h@ 486

Last change on this file since 486 was 486, checked in by Xavier Rouby, 15 years ago

updates needed for atlas jet/met resolution

File size: 7.7 KB
RevLine 
[17]1#ifndef __FuncDef__
2#define __FuncDef__
3
4#include "TStyle.h"
5#include "TCanvas.h"
6#include "TH1F.h"
7#include "TLegend.h"
8#include "TPad.h"
9#include "TTree.h"
10#include "TFile.h"
11#include "THStack.h"
12#include "TLine.h"
13#include "TArrow.h"
14#include "TMarker.h"
15#include "TStyle.h"
16#include "TROOT.h"
17
18#include <iomanip>
19#include <vector>
20#include <iostream>
21#include <string>
22#include "TPaveText.h"
23#include "TProfile.h"
24#include "TF1.h"
25#include "TGraph.h"
26#include "TGraphErrors.h"
27
28#include "interface/TdrStyle.h"
29
30using namespace std;
31
32TPaveText * MakeTPave(Float_t xmin,Float_t ymin,Float_t xmax,Float_t ymax,string text)
33{
34
35 TPaveText *leg1 = new TPaveText(xmin,ymin,xmax,ymax,"NDC");
36 leg1->AddText(text.c_str());
37 leg1->SetFillColor(10);
38 leg1->SetBorderSize(0);
39 leg1->SetTextFont(42);
40 leg1->SetTextSize(0.03791469);
41 return leg1;
42
43
44}
45
46
47TLegend * MakeLegend(Int_t FilledColor,Int_t BorderSize,Float_t TextSize,Double_t x1 = 0.60, Double_t y1 = 0.71, Double_t x2= 0.92, Double_t y2 = 0.92)
48{
49 TLegend *leg = new TLegend(x1,y1,x2,y2,NULL,"NDC");
50 leg->SetFillColor(FilledColor);
51 leg->SetBorderSize(BorderSize);
52 leg->SetTextSize(TextSize);
53 leg->SetTextFont(42);
54
55 return leg;
56}
57
58TH1F * MakeNormTH1F(Int_t numBin,Float_t minX,Float_t maxX, TTree * Analyze,string histo, Int_t Lcolor, Int_t Fcolor, Int_t Lstyle,Int_t width=2,bool Log=false)
59{
60 string temp = histo;
61 string nom = histo.erase(0,histo.find(">>")+2);
62 TH1F *h = new TH1F(nom.c_str(),"pt_lept ",numBin,minX,maxX);
63 //Analyze->Draw(temp.c_str(),"(JetPTResol.NonSmearePT >0 && JetPTResol.NonSmearePT < 20)");
64 Analyze->Draw(temp.c_str());
65 h->SetLineColor(Lcolor);
66 h->SetFillColor(Fcolor);
67 h->SetLineStyle(Lstyle);
68 h->SetLineWidth(width);
69 if(Log)gPad->SetLogy();
70 if(h->Integral()!=0)h->Scale(1./h->Integral());
71 return h;
72}
73
[27]74void GaussValues(TTree * Analyze,string histo,double &rms, double &mean, string min,string max)
[17]75{
76 string temp = histo;
77 string mintemp = min;
78 string maxtemp = max;
79
80 string nom = histo.erase(0,histo.find(">>")+2);
[153]81 TH1F *h = new TH1F(nom.c_str(),"",100,0,3);
82 string all = min + " && " + max;
83 Analyze->Draw(temp.c_str(),all.c_str());
84 h->SetMarkerSize(0.6);
[486]85 //double MeanFix = h->GetMean();
[478]86 double RangMin = (h->GetMean()-1.5*h->GetRMS());
87 double RangMax = (h->GetMean()+1.5*h->GetRMS());
[153]88 TF1 *Gauss = new TF1("Gauss","gaus",RangMin,RangMax);
89// Gauss->FixParameter(1,MeanFix);
90 h->Fit("Gauss","QR");
91 h->Fit("Gauss","QRI");
92 h->Fit("Gauss","QRI");
93 Double_t* params = Gauss->GetParameters();
94 rms=params[2];
95 //mean= MeanFix;
96 mean=params[1];
97 h->Draw("P");
98 h->GetXaxis()->SetTitle("E_{T}^{rec}/E_{T}^{MC} [GeV]");
99Gauss->Delete();
100}
[27]101
[478]102
[486]103void GaussValuesAsymmetry(TTree * Analyze,string histo, double &mean, string min,string max,string cut="1==1")
[478]104{
105 string temp = histo;
106 string mintemp = min;
107 string maxtemp = max;
108
109 string nom = histo.erase(0,histo.find(">>")+2);
[486]110 TH1F *h = new TH1F(nom.c_str(),nom.c_str(),50,-3,3);
111 //string all = min + " && " + max + " && abs(JetPTResol.Eta) < 0.5";
112 string all = min + " && " + max + " && " + cut;
[478]113 Analyze->Draw(temp.c_str(),all.c_str());
114 h->SetMarkerSize(0.6);
[486]115// mean = h->GetMean();
116 TF1 *Gauss = new TF1("Gauss","gaus",-0.4,0.4);
117 //Gauss->FixParameter(1,MeanFix);
118 h->Fit("Gauss","QR");
119 h->Fit("Gauss","QRI");
120 h->Fit("Gauss","QRI");
121 Double_t* params = Gauss->GetParameters();
122 mean=params[1];
123 h->Draw("P");
124 h->GetXaxis()->SetTitle("E_{T}^{rec}/E_{T}^{MC} [GeV]");
125 Gauss->Delete();
126// double RangMin = (h->GetMean()-2*h->GetRMS());
127// double RangMax = (h->GetMean()+2*h->GetRMS());
128}
129
130void GaussValuesAsymmetry2(TTree * Analyze,string histo, double &mean, string min,string max,string cut="1==1")
131{
132 string temp = histo;
133 string mintemp = min;
134 string maxtemp = max;
135
136 string nom = histo.erase(0,histo.find(">>")+2);
137 TH1F *h = new TH1F(nom.c_str(),nom.c_str(),50,-3,3);
138 string all = min + " && " + max + " && " + cut;
139 Analyze->Draw(temp.c_str(),all.c_str());
140 h->SetMarkerSize(0.6);
[478]141 mean = h->GetMean();
142}
143
144
145
[153]146void GaussValuesElec(TTree * Analyze,string histo,double &rms, double &mean, string min,string max)
147{
148 string temp = histo;
149 string mintemp = min;
150 string maxtemp = max;
151
152 string nom = histo.erase(0,histo.find(">>")+2);
153 TH1F *h = new TH1F(nom.c_str(),"",20,-1,3);
[27]154 string all = min + " && " + max;
155 Analyze->Draw(temp.c_str(),all.c_str());
[17]156 h->SetMarkerSize(0.6);
[23]157 double MeanFix = h->GetMean();
[153]158 TF1 *Gauss = new TF1("Gauss","gaus",-0.5,1.5);
[23]159 Gauss->FixParameter(1,MeanFix);
[39]160 h->Fit("Gauss","QR");
161 h->Fit("Gauss","QRI");
162 h->Fit("Gauss","QRI");
[17]163 Double_t* params = Gauss->GetParameters();
164 rms=params[2];
[153]165 //mean= MeanFix;
[17]166 mean=params[1];
167 h->Draw("P");
168 h->GetXaxis()->SetTitle("E_{T}^{rec}/E_{T}^{MC} [GeV]");
[153]169 Gauss->Delete();
170}
[27]171
[17]172
[153]173
[39]174void GaussValuesETmis(TTree * Analyze,string histo,double &rms, string min,string max)
[27]175{
176 string temp = histo;
177 string mintemp = min;
178 string maxtemp = max;
179
180 string nom = histo.erase(0,histo.find(">>")+2);
[153]181 TH1F *h = new TH1F(nom.c_str(),"",50,-50,50);
[27]182
183 string all = min + " && " + max;
184 Analyze->Draw(temp.c_str(),all.c_str());
185 h->SetMarkerSize(0.6);
[486]186 double RangMin = (h->GetMean()-2.5*h->GetRMS());
187 double RangMax = (h->GetMean()+2.5*h->GetRMS());
[153]188 //TF1 *Gauss = new TF1("Gauss","gaus");
[27]189 TF1 *Gauss = new TF1("Gauss","gaus",RangMin,RangMax);
[39]190 //TF1 *Gauss = new TF1("Gauss","gaus");
191 h->Fit("Gauss","QR");
192 h->Fit("Gauss","QRI");
193 h->Fit("Gauss","QRI");
[27]194 Double_t* params = Gauss->GetParameters();
195 rms=params[2];
[39]196 //rms=h->GetRMS();
197 //mean=params[1];
[27]198 h->Draw("P");
199 h->GetXaxis()->SetTitle("E_{T}^{rec}-E_{T}^{MC} [GeV]");
200}
201
202
[17]203TH1F * HiggsMakeNormTH1F(Float_t Scale, Int_t numBin,Float_t minX,Float_t maxX, TTree * Analyze,string histo, Int_t Lcolor, Int_t Fcolor, Int_t Lstyle,Int_t width=2,bool Log=false)
204{
205 string temp = histo;
206 string nom = histo.erase(0,histo.find(">>")+2);
207 TH1F *h = new TH1F(nom.c_str(),"pt_lept ",numBin,minX,maxX);
208 Analyze->Draw(temp.c_str());
209 h->SetLineColor(Lcolor);
210 h->SetFillColor(Fcolor);
211 h->SetLineStyle(Lstyle);
212 h->SetLineWidth(width);
213 if(Log)gPad->SetLogy();
214 if(h->Integral()!=0)h->Scale(1*Scale);
215 return h;
216}
217
218
219TH1F * MakeNormTH1FSum(Int_t numBin,Float_t minX,Float_t maxX,TTree * analyze1,TTree * analyze2,TTree * analyze3,
220string * histo,float * weight, Int_t Lcolor, Int_t Fcolor, Int_t Lstyle,Int_t width=2,bool Log=false)
221{
222
223 TTree *analyse[3]={analyze1,analyze2,analyze3};
224 TH1F *hq = new TH1F("hq","pt_lept ",numBin,minX,maxX);
225
226 for(unsigned int i=0; i<3; i++)
227 {
228 string temp = histo[i];
229 string nom = histo[i].erase(0,histo[i].find(">>")+2);
230 TH1F *h = new TH1F(nom.c_str(),"pt_lept ",numBin,minX,maxX);
231 analyse[i]->Draw(temp.c_str());
232 h->Scale(weight[i]);
233 hq->Add(h);
234 }
235
236 hq->SetLineColor(Lcolor);
237 hq->SetFillColor(Fcolor);
238 hq->SetLineStyle(Lstyle);
239 hq->SetLineWidth(width);
240 if(Log)gPad->SetLogy();
241 if(hq->Integral()!=0)hq->Scale(1./hq->Integral());
242
243 return hq;
244}
245
246TH1F * HiggsMakeNormTH1FSum(Int_t numBin,Float_t minX,Float_t maxX,TTree * analyze1,TTree * analyze2,TTree * analyze3,
247string * histo,float * weight, Int_t Lcolor, Int_t Fcolor, Int_t Lstyle,Int_t width=2,bool Log=false)
248{
249
250 TTree *analyse[3]={analyze1,analyze2,analyze3};
251 TH1F *hq = new TH1F("hq","pt_lept ",numBin,minX,maxX);
252
253 for(unsigned int i=0; i<3; i++)
254 {
255 string temp = histo[i];
256 string nom = histo[i].erase(0,histo[i].find(">>")+2);
257 TH1F *h = new TH1F(nom.c_str(),"pt_lept ",numBin,minX,maxX);
258 analyse[i]->Draw(temp.c_str());
259 h->Scale(weight[i]);
260 hq->Add(h);
261 }
262
263 hq->SetLineColor(Lcolor);
264 hq->SetFillColor(Fcolor);
265 hq->SetLineStyle(Lstyle);
266 hq->SetLineWidth(width);
267 if(Log)gPad->SetLogy();
268 if(hq->Integral()!=0)hq->Scale(1./hq->Integral());
269
270 return hq;
271}
272
273
274#endif
Note: See TracBrowser for help on using the repository browser.