// // // this code takes the mean-time offsets and time-difference offsets of all // double ended readout paddles and calculates the offsets for the individual // PMTs. Then the mean of all these offsets is determined and subracted from // all the individual offsets. In that way the timing offsets for the PMTs will // be neutral with respect to global timing calibrations between detectors. // The offsets for the single ended paddles are set to zero. // // 3 input files: // mean time both planes: mtparameters_plane0_ref18.dat // time difference plane 0: tof_timediffoffsets_plane0.dat // time difference plane 1: tof_timediffoffsets_plane1.dat // changed to: // time difference plane 0: timediff_offsets_plane%d_run%d.dat // time difference plane 1: timediff_offsets_plane%d_run%d.dat // // 2 output file: // tofpmt_tdc_offsets_all_runXXXXX.DB // tofpaddles_propagation_speed_runXXXXX.DB // #include "TROOT.h" #include "TStyle.h" #include "TMath.h" #include "TPad.h" #include #include #include #include #include #include #include using namespace std; void consolidate(int RunNumber){ // 3 input files // mean time both planes: mtparameters_plane0_ref18.dat // time difference plane 0: tof_timediffoffsets_plane0.dat // time difference plane 1: tof_timediffoffsets_plane1.dat double MeanTimes[2][44]; double DeltaTimes[2][44]; char inf[128]; sprintf(inf,"calibration%d/mtparameters_plane0_ref18.dat",RunNumber); ifstream INF; INF.open(inf); int k,plane; double t; while(!INF.eof()) { INF>>k>>plane>>t; MeanTimes[plane][k] = t; } INF.close(); sprintf(inf,"calibration%d/tof_timediffoffsets_plane0.dat",RunNumber); //sprintf(inf,"calibration%d/timediff_offsets_plane0_run%d.dat",RunNumber,RunNumber); INF.open(inf); double dummy; while(!INF.eof()) { INF>>k>>t>>dummy; DeltaTimes[0][k] = t; } INF.close(); sprintf(inf,"calibration%d/tof_timediffoffsets_plane1.dat",RunNumber); //sprintf(inf,"calibration%d/timediff_offsets_plane1_run%d.dat",RunNumber,RunNumber); INF.open(inf); while(!INF.eof()) { INF>>k>>t>>dummy; DeltaTimes[1][k] = t; } INF.close(); double OFFSETS[2][44][2]; char outf[128]; sprintf(outf,"calibration%d/tofpmt_tdc_offsets_all.dat",RunNumber); ofstream OUTF; OUTF.open(outf); OUTF<<"paddle plane offsetL offsetR"<22)){ histoffsets->Fill(OFFSETS[plane][k][0]); histoffsets->Fill(OFFSETS[plane][k][1]); } } } OUTF.close(); histoffsets->Draw(); histoffsets->Fit("gaus"); gPad->SetGrid(); gPad->Update(); sprintf(outf,"plots/distribution_of_offsets_run%d.pdf",RunNumber); gPad->SaveAs(outf); //TF1 *f1 = histoffsets->GetFunction("gaus"); //float MeanOff = f1->GetParameter(1); float MeanOff = histoffsets->GetMean(); // use mean instead of gaussian fit sprintf(outf,"calibration%d/tofpmt_tdc_offsets_all_run%d.DB",RunNumber,RunNumber); OUTF.open(outf); for (int plane=0;plane<2;plane++) { for (int end=0;end<2;end++){ for (int k=0;k<44;k++){ if ((k<21) || (k>22)){ OUTF<>dum1>>Speeds[k]>>dum2; //cout<>dum1>>Speeds[k+44]>>dum2; if (TMath::Abs(Speeds[k+44]-15.5)<2.){ SSum += Speeds[k]; Scnt++; } } INF.close(); double Mspeed = SSum/(double)Scnt; cout<<"Mean propagation speed is: "<