void proton_res()
{
gROOT->Reset();
//TFile *F1 = new TFile("proton.root");
TChain chain("TRACKING/trkeff");
chain.Add("proton1/proton1.root");
chain.Add("proton2/proton2.root");
chain.Add("proton3/proton3.root");
// Create histograms to calculate resolution
TH3D *dp_vs_p_vs_theta = new TH3D("dp_vs_p_vs_theta","Normalized momentum residuals vs p vs theta",75,0,130,10,0.,2.,100,-0.5,0.5);
chain.Project("dp_vs_p_vs_theta", "(sqrt(F.trktb.p.fX*F.trktb.p.fX+F.trktb.p.fY*F.trktb.p.fY+F.trktb.p.fZ*F.trktb.p.fZ)-F.pthrown.Mag())/F.pthrown.Mag():F.pthrown.Mag():180./3.14159*F.pthrown.Theta()", "(F.trktb.Nfdc>0 || F.trktb.Ncdc>0)&& TMath::Prob(F.trktb.trk_chisq,F.trktb.trk_Ndof)>0.001&&F.pthrown.Theta()>0.017");
TCanvas *c1 = new TCanvas("c1");
c1->SetTickx();
c1->SetTicky();
gStyle->SetOptStat(0);
TLegend *legend=new TLegend(0.65,0.7,0.85,0.95);
TH2D *res=new TH2D("res","Momentum resolution",75,0,130,10,0.,2.);
for (int i=2;i<=10;i++){
dp_vs_p_vs_theta->GetYaxis()->SetRange(i,i);
dp_vs_p_vs_theta->Project3D("zx");
dp_vs_p_vs_theta_zx->FitSlicesY();
TH1D *h=gROOT->FindObject("dp_vs_p_vs_theta_zx_2");
h->SetMaximum(0.1);
h->SetMinimum(0);
switch(i){
case 3:
h->Clone("h0");
break;
case 5:
h->Clone("h1");
break;
case 8:
h->Clone("h2");
break;
default:
break;
}
for (int j=1;j<=75;j++){
res->SetBinContent(j,i,h->GetBinContent(j));
}
}
gPad->SetRightMargin(0.05);
TH1D *h0=gROOT->FindObject("h0");
h0->SetMarkerStyle(20);
h0->SetMarkerSize(1.0);
h0->SetMarkerColor(1);
h0->SetLineColor(1);
h0->SetXTitle("#theta [degrees]");
h0->SetYTitle("#sigma(#deltap/p)");
h0->GetYaxis()->SetTitleOffset(1.25);
h0->SetTitle("Momentum resolution for protons");
h0->Draw("l");
legend->AddEntry(h0,"0.5 GeV/c","pl");
TH1D *h1=gROOT->FindObject("h1");
h1->SetMarkerStyle(20);
h1->SetMarkerSize(1.0);
h1->SetMarkerColor(2);
h1->SetLineColor(2);
h1->Draw("same");
legend->AddEntry(h1,"0.9 GeV/c","pl");
TH1D *h2=gROOT->FindObject("h2");
h2->SetMarkerStyle(20);
h2->SetMarkerSize(1.0);
h2->SetMarkerColor(4);
h2->SetLineColor(4);
h2->Draw("same");
legend->AddEntry(h2,"1.5 GeV/c","pl");
legend->Draw();
c1->SaveAs("proton_dp_vs_theta.png");
c1->SaveAs("proton_dp_vs_theta.pdf");
TCanvas *c2 = new TCanvas("c2");
c2->SetTickx();
c2->SetTicky();
gStyle->SetPalette(1,0);
gPad->SetLeftMargin(0.1);
gPad->SetRightMargin(0.15);
res->SetTitle("Momentum resolution for protons");
res->SetZTitle("#sigma(#deltap/p)");
res->SetXTitle("#theta [degrees]");
res->SetYTitle("p [GeV/c]");
res->SetMaximum(0.1);
res->SetContour(50);
res->GetZaxis()->SetTitleOffset(1.25);
res->Draw("colz");
c2->SaveAs("proton_dp_vs_p_vs_theta.png");
c2->SaveAs("proton_dp_vs_p_vs_theta.pdf");
ofstream ofile("proton_res.txt");
ofile <<"
"<" <" <" <