#include "TCanvas.h" #include "TAxis.h" #include "TH1.h" #include #include #include "TGraphErrors.h" string DoubleToString(double a) { ostringstream temp; temp<SetOptStat(0); TCanvas *c1 = new TCanvas("c1", "The centroid with error bars", 100, 5, 1000, 600); c1->Divide(1,1); double ex[n] = {0.0, 0.0, 0.0, 0.0, 0.0, 0.0}; c1->cd(1); TH1F* h = new TH1F("h", "h", 100, 0., 2.0); h->Draw(); TGraphErrors *gr = new TGraphErrors(n, x, y, ex, ey); //gr->Draw("AP*"); h->SetMinimum(0.00); h->SetMaximum(1.00); gr->SetMarkerStyle(20); gr->SetMarkerSize(1); gr->SetMarkerColor(kBlack); gr->SetLineColor(kBlack); h->GetXaxis()->SetTitle("<-t> (GeV^{2})"); h->GetYaxis()->SetTitle("P #Sigma"); h->GetXaxis()->SetRangeUser(0.0,2.0); h->GetYaxis()->SetTitleOffset(1.2); h->SetTitle("The P#Sigma of #pi^{0} photoproduction for total"); //c1->Update(); gr->Draw("same P"); //c1->Print("figPhiP/PSigma.pdf"); c1->Print(figName); return; } double Meanmt(TString datafileName, TString Hist2DName, double minx, double maxx, TString figsName, int i) { TFile *fdata = TFile::Open(datafileName); TH2D* h = (TH2D*)fdata->Get(Hist2DName); gStyle->SetOptStat("nemr"); //Double_t ylow = 0.0; //Double_t yup = 0.2; Double_t ylow = -3.14; Double_t yup = 3.14; TCanvas *cc_ave = new TCanvas("cc_ave", "cc_ave", 600, 400); cc_ave->Divide(1,1); double maximum=0.0; int binMiny = h->GetYaxis()->FindBin(ylow); int binMaxy = h->GetYaxis()->FindBin(yup); TH1D *h1 = (TH1D*)h->ProjectionX(Form("E2gamma_%d", i),binMiny,binMaxy); maximum = h1->GetMaximum(); maximum *= 3.6; h1->SetMaximum(maximum); int binMinx = h->GetXaxis()->FindBin(minx); int binMaxx = h->GetXaxis()->FindBin(maxx); h1->GetXaxis()->SetRange(binMinx,binMaxx); cout<<"min_x="<GetMean(1)<cd(1); h1->Draw(""); //cc_ave->Print(figsName); return h1->GetMean(1); } void drawpi0AsysBkgTSubRbin(double lowCoh = 8.4, double highCoh = 9.0) { int rebin = 5; double minx = -3.14; double maxx = 3.14; gStyle->SetOptStat(0); gStyle->SetOptFit(1111); TFile *fPERP = TFile::Open("./histroot/ana_p2gamma_phip_perp.root"); if(!fPERP) return; TH2D* h2PERP = (TH2D*)fPERP->Get("Phi_Proton_vs_t_2"); TH2D* h2PERPBkg = (TH2D*)fPERP->Get("Acci_Phi_Proton_vs_t_2"); TFile *fPARA = TFile::Open("./histroot/ana_p2gamma_phip_para.root"); if(!fPARA) return; TH2D* h2PARA = (TH2D*)fPARA->Get("Phi_Proton_vs_t_2"); TH2D* h2PARABkg = (TH2D*)fPARA->Get("Acci_Phi_Proton_vs_t_2"); TString datafileName = "./histroot/ana_p2gamma_Cuts_NewData.root"; TString Hist2DName = "Phi_Proton_vs_t_2"; const int nt = 19; double Array_t[nt] = {0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0, 0.0}; for(int i=0; i<=12; i++) { Array_t[i] = 0.08*(i+1); } for(int i=13; iSumw2(); hPERP->Rebin(rebin); int binMinPERPBkg = h2PERPBkg->GetXaxis()->FindBin(Array_t[j]); int binMaxPERPBkg = h2PERPBkg->GetXaxis()->FindBin(Array_t[i]); TH1D *hPERPBkg = (TH1D*)h2PERPBkg->ProjectionY(Form("phi_p_perp_bkg_%d", i),binMinPERPBkg,binMaxPERPBkg); hPERPBkg->Sumw2(); hPERPBkg->Rebin(rebin); Double_t normC = 1.0/6.0; hPERPBkg->Scale(normC); TH1D* hPERPSub = new TH1D("hPERPSub", "Phi_Proton_pi_cutBE_sub", 20, minx, maxx); hPERPSub->Sumw2(); hPERPSub->Add(hPERP, hPERPBkg, 1, -1); hPERPSub->Draw(); int binMinPARA = h2PARA->GetXaxis()->FindBin(Array_t[j]); int binMaxPARA = h2PARA->GetXaxis()->FindBin(Array_t[i]); TH1D *hPARA = (TH1D*)h2PARA->ProjectionY(Form("phi_p_para_%d", i),binMinPARA,binMaxPARA); hPARA->Sumw2(); hPARA->Rebin(rebin); int binMinPARABkg = h2PARABkg->GetXaxis()->FindBin(Array_t[j]); int binMaxPARABkg = h2PARABkg->GetXaxis()->FindBin(Array_t[i]); TH1D *hPARABkg = (TH1D*)h2PARABkg->ProjectionY(Form("phi_p_para_bkg_%d", i),binMinPARABkg,binMaxPARABkg); hPARABkg->Sumw2(); hPARABkg->Rebin(rebin); hPARABkg->Scale(normC); TH1D* hPARASub = new TH1D(Form("hPARASub_%d", i), "Phi_Proton_pi_cutBE_sub", 20, minx, maxx); hPARASub->Sumw2(); hPARASub->Add(hPARA, hPARABkg, 1, -1); //double norm = hPERPSub->Integral()/hPARASub->Integral(); double norm = 22081.0/18768.0; //hPARASub->Scale(norm); // set max-min and get normalization double maximum = hPERPSub->GetMaximum(); if(hPARASub->GetMaximum() > maximum) maximum = hPARA->GetMaximum(); maximum *= 2.6; hPERPSub->SetMinimum(0); hPARASub->SetMinimum(0); hPERPSub->SetMaximum(maximum); hPARASub->SetMaximum(maximum); TH1D* hPPSum = new TH1D(Form("hPERPSum_%d", i), "Phi_Proton_pi_cutBE_sum", 20, minx, maxx); hPPSum->Sumw2(); hPPSum->Add(hPERPSub, hPARASub, 1, norm); double maximumSum = hPPSum->GetMaximum(); maximumSum *= 2.6; hPPSum->SetMinimum(0); hPPSum->SetMaximum(maximumSum); // make asymmetry TH1I* hAsym = hPERPSub->GetAsymmetry(hPARASub, norm); double maximumAsym = hAsym->GetMaximum(); maximumAsym *= 2.6; hAsym->SetMaximum(maximumAsym); TCanvas *cc = new TCanvas("cc", "cc", 900, 760); cc->Divide(2,2); cc->cd(1); TF1* fitPERP = new TF1(Form("psiFitPERP_%d", i),"[0]*(1.0 + [1]*cos(2*(x + [2])))"); fitPERP->SetLineColor(kRed); hPERPSub->Fit(fitPERP, ""); hPERPSub->SetMarkerStyle(20); hPERPSub->SetMarkerColor(kRed); hPERPSub->Draw("e"); cc->cd(2); TF1* fitPARA = new TF1(Form("psiFitPARA_%d", i),"[0]*(1.0 + [1]*cos(2*(x + [2])))"); fitPARA->SetLineColor(kRed); hPARASub->Fit(fitPARA, ""); hPARASub->Draw("e"); hPARASub->SetMarkerStyle(20); hPARASub->SetMarkerColor(kRed); cc->cd(3); TF1* fitAsym = new TF1(Form("asymFit_%d", i),"[0]*cos(2*(x + [1]))"); fitAsym->SetLineColor(kRed); hAsym->Fit(fitAsym, ""); hAsym->SetMarkerStyle(20); hAsym->SetMarkerColor(kRed); hAsym->Draw("e"); y[j] = fitAsym->GetParameter(0); ey[j] = fitAsym->GetParError(0); cc->cd(4); TF1* fitSum = new TF1(Form("sumFit_%d", i),"[0]*(1.0 + [1]*cos(2*(x + [2])))"); fitSum->SetLineColor(kRed); hPPSum->Fit(fitSum, ""); hPPSum->SetMarkerStyle(20); hPPSum->SetMarkerColor(kRed); hPPSum->Draw("e"); cc->Print(figsName); cout<<"x[j]="<