12 #include <ktracker/FastTracklet.h>
32 h1_stat =
new TH1D(
"h1_stat" ,
";Reco. status;N of tracks", 25, -24.5, 0.5);
34 int id_n = ST_ID_MAX - ST_ID_MIN + 1;
35 double id_l = ST_ID_MIN - 0.5;
36 double id_h = ST_ID_MAX + 0.5;
37 h1_st_id =
new TH1D(
"h1_st_id",
";Station ID;N of tracks", id_n, id_l, id_h);
38 h2_ntrk =
new TH2D(
"h2_ntrk" ,
";N of tracks/event;Station ID;N of tracks", 200, -0.5, 199.5, id_n, id_l, id_h);
39 h2_nhit =
new TH2D(
"h2_nhit" ,
";N of hits/track;Station ID;N of tracks", 18, 0.5, 18.5, id_n, id_l, id_h);
40 h2_mom =
new TH2D(
"h2_mom" ,
";Momentum (GeV);Station ID;N of tracks", 22, 0.0, 120.0, id_n, id_l, id_h);
41 h2_rchi2 =
new TH2D(
"h2_rchi2",
";#chi^{2}/NDF;Station ID;N of tracks", 50, 0.0, 10.0, id_n, id_l, id_h);
42 h2_x0 =
new TH2D(
"h2_x0" ,
";x_{0} (cm);Station ID;N of tracks", 100, -500, 500, id_n, id_l, id_h);
43 h2_y0 =
new TH2D(
"h2_y0" ,
";y_{0} (cm);Station ID;N of tracks", 100, -500, 500, id_n, id_l, id_h);
44 h2_tx =
new TH2D(
"h2_tx" ,
";t_{x};Station ID;N of tracks", 100, -1.0, 1.0, id_n, id_l, id_h);
45 h2_ty =
new TH2D(
"h2_ty" ,
";t_{y};Station ID;N of tracks", 100, -1.0, 1.0, id_n, id_l, id_h);
46 h2_x_st =
new TH2D(
"h2_x_st" ,
";x_{St} (cm);Station ID;N of tracks", 100, -250, 250, id_n, id_l, id_h);
47 h2_y_st =
new TH2D(
"h2_y_st" ,
";y_{St} (cm);Station ID;N of tracks", 100, -250, 250, id_n, id_l, id_h);
56 double t_min = cal_par->
GetTMin(ip);
57 double t_max = cal_par->
GetTMax(ip);
58 double r_max = cal_par->
GetRMax(ip);
60 const double t_width = 4.0/9.0 * 3;
62 oss <<
"h1_time_wide_" << det_name;
64 oss2 <<
"#" << setw(2) << (ip+1) <<
": " << det_name <<
";TDC time (ns);Yields";
65 h1_time_wide[ip] =
new TH1D(oss.str().c_str(), oss2.str().c_str(), 2000, 0, 2000*t_width);
67 int bin_t_lo = (int)(t_min / t_width);
68 int bin_t_hi = (int)(t_max / t_width) + 1;
70 oss <<
"h1_time_" << det_name;
72 oss2 <<
"#" << setw(2) << (ip+1) <<
": " << det_name <<
";TDC time (ns);Yields";
73 h1_time[ip] =
new TH1D(oss.str().c_str(), oss2.str().c_str(), bin_t_hi-bin_t_lo, t_width*(bin_t_lo)-0.01, t_width*(bin_t_hi)-0.01);
76 oss <<
"h2_tp_wp_" << det_name;
78 oss2 <<
"#" << setw(2) << (ip+1) <<
": " << det_name <<
";Track position (cm);Wire position (cm);";
79 h2_tp_wp[ip] =
new TH2D(oss.str().c_str(), oss2.str().c_str(), 120, -0.6*det_dy, 0.6*det_dy, 120, -0.6*det_dy, 0.6*det_dy);
82 oss <<
"h2_rt_" << det_name;
84 oss2 <<
"#" << setw(2) << (ip+1) <<
": " << det_name <<
";TDC time (ns);R (cm);";
85 h2_RT[ip] =
new TH2D(oss.str().c_str(), oss2.str().c_str(), T_BIN, t_min, t_max, R_BIN, 0, 1.2*r_max );
88 oss <<
"h2_resi_" << det_name;
90 oss2 <<
"#" << setw(2) << (ip+1) <<
": " << det_name <<
";TDC time (ns);Residual (cm);";
91 h2_Resi[ip] =
new TH2D(oss.str().c_str(), oss2.str().c_str(), T_BIN, t_min, t_max, R_BIN, -0.5, 0.5);
94 oss <<
"h2_tr_" << det_name;
96 oss2 <<
"#" << setw(2) << (ip+1) <<
": " << det_name <<
";TDC time (ns);R (cm);";
97 h2_TR[ip] =
new TH2D(oss.str().c_str(), oss2.str().c_str(), R_BIN, 0, 1.2*r_max, T_BIN, t_min, t_max );
100 oss <<
"h2_tr_ex_" << det_name;
102 oss2 <<
"#" << setw(2) << (ip+1) <<
": " << det_name <<
";Track distance (cm);TDC time (ns);";
103 h2_TR_ex[ip] =
new TH2D(oss.str().c_str(), oss2.str().c_str(), R_BIN*2, -1.2*r_max, 1.2*r_max, T_BIN, t_min, t_max );
106 oss <<
"h2_td_dd_" << det_name;
108 oss2 <<
"#" << setw(2) << (ip+1) <<
": " << det_name <<
";Track distance (cm);Drift distance (cm);Yields";
109 h2_td_dd[ip] =
new TH2D(oss.str().c_str(), oss2.str().c_str(), R_BIN*2, -1.2*r_max, 1.2*r_max, R_BIN, 0, 1.2*r_max);
115 h1_stat->Fill(rec_stat);
117 for (
int st_id = ST_ID_MIN; st_id <= ST_ID_MAX; st_id++) {
118 int n_trk = list_n_trk.find(st_id) != list_n_trk.end() ? list_n_trk.at(st_id) : 0;
119 h2_ntrk->Fill(n_trk, st_id);
127 int ndf = n_hit - (st_id == 7 ? 5 : 4);
128 double rchi2 = ndf > 0 ? trk->
chisq / ndf : 0;
131 double x_st = trk->
x0 + z_st * trk->
tx;
132 double y_st = trk->
y0 + z_st * trk->
ty;
134 h1_st_id->Fill(st_id);
135 h2_nhit ->Fill(n_hit , st_id);
136 h2_mom ->Fill(1/trk->
invP, st_id);
137 h2_rchi2->Fill(rchi2 , st_id);
138 h2_x0 ->Fill(trk->
x0 , st_id);
139 h2_y0 ->Fill(trk->
y0 , st_id);
140 h2_tx ->Fill(trk->
tx , st_id);
141 h2_ty ->Fill(trk->
ty , st_id);
142 h2_x_st ->Fill(x_st , st_id);
143 h2_y_st ->Fill(y_st , st_id);
148 for(
auto it = trk->
hits.begin(); it != trk->
hits.end(); ++it) {
149 if(it->hit.index < 0)
continue;
151 int det_id = it->hit.detectorID;
152 int ele_id = it->hit.elementID;
153 double drift_dist = it->hit.driftDistance;
154 double tdc_time = it->hit.tdcTime;
156 double wire_pos = it->hit.pos;
157 FillHit(det_id, drift_dist, tdc_time, track_pos, wire_pos);
166 void CalibData::FillHit(
const int det_id,
const double drift_dist,
const double tdc_time,
const double track_pos,
const double wire_pos)
168 double track_dist = track_pos - wire_pos;
169 h1_time_wide[det_id-1]->Fill(tdc_time);
170 h1_time [det_id-1]->Fill(tdc_time);
171 h2_tp_wp [det_id-1]->Fill(track_pos, wire_pos);
172 h2_RT [det_id-1]->Fill(tdc_time, fabs(track_dist));
173 h2_Resi [det_id-1]->Fill(tdc_time, fabs(drift_dist) - fabs(track_dist));
174 h2_TR [det_id-1]->Fill(fabs(track_dist), tdc_time);
175 h2_TR_ex [det_id-1]->Fill(track_dist, tdc_time);
176 h2_td_dd [det_id-1]->Fill(track_dist, drift_dist);
181 cout <<
"DrawHistEvent()" << endl;
183 TCanvas* c1 =
new TCanvas(
"c1",
"", 800, 600);
185 gStyle->SetOptStat(0);
194 oss << dir_out <<
"/h1_st_id.png";
195 c1->SaveAs(oss.str().c_str());
199 DrawIn1D(h2_ntrk ,
"ntrk" , dir_out, iy_lo, iy_hi);
200 DrawIn1D(h2_nhit ,
"nhit" , dir_out, iy_lo, iy_hi);
202 DrawIn1D(h2_rchi2,
"rchi2", dir_out, iy_lo, iy_hi);
205 DrawIn1D(h2_tx ,
"tx" , dir_out, iy_lo, iy_hi);
206 DrawIn1D(h2_ty ,
"ty" , dir_out, iy_lo, iy_hi);
207 DrawIn1D(h2_x_st ,
"x_st" , dir_out, iy_lo, iy_hi);
208 DrawIn1D(h2_y_st ,
"y_st" , dir_out, iy_lo, iy_hi);
215 cout <<
"DrawHistHit()" << endl;
217 TCanvas* c1 =
new TCanvas(
"c1",
"", 800, 600);
219 gStyle->SetOptStat(0);
230 oss << setw(2) << (ip+1) <<
"_" << det_name <<
".png";
231 string suffix = oss.str();
234 h1_time_wide[ip]->Draw();
235 c1->SaveAs( (dir_out +
"/h1_time_wide_" + suffix).c_str() );
238 c1->SaveAs( (dir_out +
"/h1_time_" + suffix).c_str() );
243 TH1* h1_tp = h2_tp_wp[ip]->ProjectionX(
"h1_tp");
245 c1->SaveAs( (dir_out +
"/h1_tp_" + suffix).c_str() );
253 h2_TR_ex[ip]->Draw(
"colz");
254 c1->SaveAs( (dir_out +
"/h2_tr_ex_" + suffix).c_str() );
256 h2_Resi[ip]->Draw(
"colz");
257 c1->SaveAs( (dir_out +
"/h2_resi_" + suffix).c_str() );
259 h2_td_dd[ip]->Draw(
"colz");
260 c1->SaveAs( (dir_out +
"/h2_td_dd_" + suffix).c_str() );
262 TH1* h1_td = h2_td_dd[ip]->ProjectionX(
"h1_td");
264 c1->SaveAs( (dir_out +
"/h1_td_" + suffix).c_str() );
267 TH1* h1_dd = h2_td_dd[ip]->ProjectionY(
"h1_dd");
269 c1->SaveAs( (dir_out +
"/h1_dd_" + suffix).c_str() );
275 void CalibData::DrawIn1D(TH2* h2,
const string label,
const string dir_out,
int iy_lo,
int iy_hi)
277 if (iy_lo <= 0) iy_lo = 1;
278 if (iy_hi <= 0) iy_hi = h2->GetNbinsY();
281 oss << h2->GetTitle() <<
";" << h2->GetXaxis()->GetTitle() <<
";" << h2->GetZaxis()->GetTitle();
282 THStack hs(
"hs", oss.str().c_str());
283 TLegend leg(0.90, 0.90-0.03*(iy_hi-iy_lo+2), 0.99, 0.99);
284 leg.SetHeader(
"St. ID");
285 for (
int iy = iy_lo; iy <= iy_hi; iy++) {
287 oss << h2->GetName() <<
"_" << iy;
288 TH1* h1 = h2->ProjectionX(oss.str().c_str(), iy, iy);
289 h1->SetLineColor(iy - iy_lo + 1);
293 oss << h2->GetYaxis()->GetBinCenter(iy);
294 leg.AddEntry(h1, oss.str().c_str(),
"l");
297 TCanvas* c1 =
new TCanvas(
"c1_din1d",
"", 800, 600);
300 gStyle->SetOptStat(0);
305 oss << dir_out <<
"/h1_" << label <<
".png";
306 c1->SaveAs(oss.str().c_str());
void FillTracklet(const Tracklet *trk)
void FillTrackletHits(const Tracklet *trk)
void DrawHistHit(const std::string dir_out)
void DrawHistEvent(const std::string dir_out)
void FillEventInfo(const int rec_stat, const std::map< int, int > list_n_trk)
void FillHit(const int det_id, const double drift_dist, const double tdc_time, const double track_pos, const double wire_pos)
Fill the hit information.
void Init(CalibParam *ptr)
Class to hold the calibration parameters.
bool GetAnaPlane(const int i_pl)
double GetTMax(const int i_pl) const
double GetRMax(const int i_pl) const
static double ZOfStationID(const int st_id)
double GetTMin(const int i_pl) const
User interface class about the geometry of detector planes.
static GeomSvc * instance()
singlton instance
double getPlaneScaleX(int detectorID) const
std::string getDetectorName(const int &detectorID) const
std::list< SignedHit > hits
double getExpPositionW(int detectorID) const
void AutoSetRange(TH1 *h1, const int margin_lo=5, const int margin_hi=5)
Adjust the axis range via "h1->GetXaxis()->SetRange(bin_lo, bin_hi)" to zoom up non-empty bins.