// This will fit histograms from the tree in hd_root.root to // obtain a set of timewalk corrections functions. // // This is done by projecting the uncorrected times onto a // histogram in bins of fADC value. The maximum is then used to // fill a histo and fit it to a specific functional form and code is // generated to capture those fit results into a C++ accessible // format: timewalk_max.cc. #include #include using namespace std; #include #include #include #include #include #include void timewalk_calibrate_max(void) { TFile *f = new TFile("hd_root.root"); f->cd(); // avoid compiler warnings when running with "+" TTree *tree = (TTree*)gROOT->FindObject("tree"); TCanvas *c1 = new TCanvas("c1"); c1->SetTicks(); c1->SetGrid(); TH2D *axes = new TH2D("axes","", 100, 0.0, 400.0, 100, 0.0, 60.0); axes->SetStats(0); axes->SetXTitle("fADC"); axes->SetYTitle("t (ns)"); TF1 *fun_up = new TF1("fun_up", "[0] + [1]/(pow(x,[2])+[3])", 0.0, 400.0); TF1 *fun_dn = new TF1("fun_dn", "[0] + [1]/(pow(x,[2])+[3])", 0.0, 400.0); fun_up->SetLineWidth(2); fun_dn->SetLineWidth(2); fun_up->SetLineColor(kBlue); fun_dn->SetLineColor(kRed); double parms_up[10+1][4]; double parms_dn[10+1][4]; // Open PDF file for plots c1->Print("timewalk_max.ps["); // Loop over layers int Nlayers=0; for(int ilayer=1; ilayer<=10 ; ilayer++, Nlayers++){ // Create histos to hold maxima TH1D *hup = new TH1D("hup", "", 100, 0.0, 400.0); TH1D *hdn = new TH1D("hdn", "", 100, 0.0, 400.0); // First, project onto a 2D histo and then project slices // of that onto a temporary histo. This speeds things up // considerably compared to projecting each slice individually TH2D *hup_2D = new TH2D("hup_2D","", 100, 0.0, 400.0, 600, 0.0, 60.0); TH2D *hdn_2D = new TH2D("hdn_2D","", 100, 0.0, 400.0, 600, 0.0, 60.0); char cut[256]; sprintf(cut, "layer==%d", ilayer); tree->Project("hup_2D", "tup:fADC_up", cut); tree->Project("hdn_2D", "tdn:fADC_dn", cut); // Loop over bins in fADC for(int bin=1; bin<=hup->GetNbinsX(); bin++){ TH1D *hup_2D_py = hup_2D->ProjectionY("_py",bin,bin); TH1D *hdn_2D_py = hdn_2D->ProjectionY("_py",bin,bin); double epsilon = 0.100; double hup_max = hup_2D_py->GetBinCenter(hup_2D_py->GetMaximumBin()); double hup_integral = hup_2D_py->Integral(); double hup_rms = hup_2D_py->GetRMS(); double hup_max_err = hup_integral>0.0 ? hup_rms/sqrt(hup_integral):0.0; if(hup_max_err>0.0)hup_max_err = sqrt(epsilon*epsilon + hup_max_err*hup_max_err); hup->SetBinContent(bin, hup_max); hup->SetBinError(bin, hup_max_err); double hdn_max = hdn_2D_py->GetBinCenter(hdn_2D_py->GetMaximumBin()); double hdn_integral = hdn_2D_py->Integral(); double hdn_rms = hdn_2D_py->GetRMS(); double hdn_max_err = hdn_integral>0.0 ? hdn_rms/sqrt(hdn_integral):0.0; if(hdn_max_err>0.0)hdn_max_err = sqrt(epsilon*epsilon + hdn_max_err*hdn_max_err); hdn->SetBinContent(bin, hdn_max); hdn->SetBinError(bin, hdn_max_err); } hup->SetLineColor(kCyan); hdn->SetLineColor(kMagenta); hup->SetLineWidth(2); hdn->SetLineWidth(2); char title[256]; sprintf(title, "Timewalk for layer %d", ilayer); axes->SetTitle(title); TH2D *tmpup = new TH2D("tmpup", "",100,0.0, 400.0, 200, 0.0, 60.0); TH2D *tmpdn = (TH2D*)tmpup->Clone("tmpdn"); tree->Project("tmpup","tup:fADC_up", cut); tree->Project("tmpdn","tdn:fADC_dn", cut); axes->Draw(); tmpup->Draw("same"); tmpdn->Draw("same"); fun_up->SetParameter(0, 40.0); fun_up->SetParameter(1, 0.8); fun_up->SetParameter(2, 0.064); fun_up->SetParameter(3, -1.2); fun_dn->SetParameter(0, 17.0); fun_dn->SetParameter(1, 0.2); fun_dn->SetParameter(2, 0.034); fun_dn->SetParameter(3, -1.1); //fun_up->SetParLimits(0, 30.0, 50.0); //fun_dn->SetParLimits(0, 10.0, 30.0); hup->Fit(fun_up,"", "same", 30.0, 400.0); for(int ipar=0; ipar<=3; ipar++)parms_up[ilayer][ipar] = fun_up->GetParameter(ipar); hdn->Fit(fun_dn,"", "same", 30.0, 400.0); for(int ipar=0; ipar<=3; ipar++)parms_dn[ilayer][ipar] = fun_dn->GetParameter(ipar); c1->Update(); c1->Print("timewalk_max.ps"); char fname[256]; sprintf(fname, "timewalk_max_layer%02d.png", ilayer); c1->SaveAs(fname); } // Close PDF file c1->Print("timewalk_max.ps]"); // Write parameters out in form of C++ file const char *cppfname = "timewalk_max.cc"; ofstream pout(cppfname); pout<"<NLAYERS_BCAL ? NLAYERS_BCAL:layer;"<NLAYERS_BCAL ? NLAYERS_BCAL:layer;"<