12 #include <ktracker/SRecEvent.h>
27 , m_file_name (
"output.root")
48 m_sq_evt = findNode::getClass<SQEvent >(topNode,
"SQEvent");
49 m_sq_hit_vec = findNode::getClass<SQHitVector>(topNode,
"SQHitVector");
50 m_srec = findNode::getClass<SRecEvent >(topNode,
"SRecEvent");
53 m_file =
new TFile(m_file_name.c_str(),
"RECREATE");
54 m_tree =
new TTree(
"tree",
"Created by AnaDimuon");
55 m_tree->Branch(
"event" , &m_evt);
56 m_tree->Branch(
"dimuon_list", &m_dim_list);
58 SQRun* sq_run = findNode::getClass<SQRun>(topNode,
"SQRun");
64 cout <<
"!!WARNING!! OnlMonTrigEP::InitRunOnlMon(): roadset.LoadConfig returned " << ret <<
".\n";
66 cout <<
"Roadset " << m_rs.
str(1) << endl;
83 m_evt.
D1 = m_evt.
D2 = m_evt.
D3p = m_evt.
D3m = 0;
87 if ( 0 < det_id && det_id <= 6) m_evt.
D1++;
88 else if (12 < det_id && det_id <= 18) m_evt.
D2++;
89 else if (18 < det_id && det_id <= 24) m_evt.
D3p++;
90 else if (24 < det_id && det_id <= 30) m_evt.
D3m++;
112 for (
int i_dim = 0; i_dim < n_dim; i_dim++) {
158 m_dim_list.push_back(dd);
175 cout <<
"N of trees = " << tree->GetNtrees() << endl;
176 gSystem->mkdir(
"result",
true);
177 ofstream ofs(
"result/result.txt");
179 TFile* file_out =
new TFile(
"result/result.root",
"RECREATE");
181 TH1* h1_D1 =
new TH1D(
"h1_D1" ,
";D1 occupancy;N of events", 500, -0.5, 499.5);
182 TH1* h1_D2 =
new TH1D(
"h1_D2" ,
";D2 occupancy;N of events", 300, -0.5, 299.5);
183 TH1* h1_D3p =
new TH1D(
"h1_D3p",
";D3p occupancy;N of events", 300, -0.5, 299.5);
184 TH1* h1_D3m =
new TH1D(
"h1_D3m",
";D3m occupancy;N of events", 300, -0.5, 299.5);
186 TH1* h1_nhit_pos =
new TH1D(
"h1_nhit_pos",
"#mu^{+};N of hits/track;", 6, 12.5, 18.5);
187 TH1* h1_chi2_pos =
new TH1D(
"h1_chi2_pos",
"#mu^{+};Track #chi^{2};", 100, 0, 2);
188 TH1* h1_z_pos =
new TH1D(
"h1_z_pos" ,
"#mu^{+};Track z (cm);" , 100, -700, 300);
189 TH1* h1_pz_pos =
new TH1D(
"h1_pz_pos" ,
"#mu^{+};Track p_{z} (GeV);", 100, 0, 100);
195 TH1* h1_chi2_tgt_pos =
new TH1D(
"h1_chi2_tgt_pos",
"#mu^{+};Track #chi^{2} at target;" , 100, 0, 10);
196 TH1* h1_chi2_dum_pos =
new TH1D(
"h1_chi2_dum_pos",
"#mu^{+};Track #chi^{2} at dump;" , 100, 0, 10);
197 TH1* h1_chi2_ups_pos =
new TH1D(
"h1_chi2_ups_pos",
"#mu^{+};Track #chi^{2} at upstream;", 100, 0, 10);
198 TH1* h1_chi2_tmd_pos =
new TH1D(
"h1_chi2_tmd_pos",
"#mu^{+};#chi^{2}_{Target} - #chi^{2}_{Dump};" , 100, -10, 10);
199 TH1* h1_chi2_tmu_pos =
new TH1D(
"h1_chi2_tmu_pos",
"#mu^{+};#chi^{2}_{Target} - #chi^{2}_{Upstream};", 100, -10, 10);
201 TH1* h1_nhit_neg =
new TH1D(
"h1_nhit_neg",
"#mu^{-};N of hits/track;", 6, 12.5, 18.5);
202 TH1* h1_chi2_neg =
new TH1D(
"h1_chi2_neg",
"#mu^{-};Track #chi^{2};", 100, 0, 2);
203 TH1* h1_z_neg =
new TH1D(
"h1_z_neg" ,
"#mu^{-};Track z (cm);", 100, -700, 300);
204 TH1* h1_pz_neg =
new TH1D(
"h1_pz_neg" ,
"#mu^{-};Track p_{z} (GeV);", 100, 0, 100);
210 TH1* h1_chi2_tgt_neg =
new TH1D(
"h1_chi2_tgt_neg",
"#mu^{-};Track #chi^{2} at target;" , 100, 0, 10);
211 TH1* h1_chi2_dum_neg =
new TH1D(
"h1_chi2_dum_neg",
"#mu^{-};Track #chi^{2} at dump;" , 100, 0, 10);
212 TH1* h1_chi2_ups_neg =
new TH1D(
"h1_chi2_ups_neg",
"#mu^{-};Track #chi^{2} at upstream;", 100, 0, 10);
213 TH1* h1_chi2_tmd_neg =
new TH1D(
"h1_chi2_tmd_neg",
"#mu^{-};#chi^{2}_{Target} - #chi^{2}_{Dump};" , 100, -10, 10);
214 TH1* h1_chi2_tmu_neg =
new TH1D(
"h1_chi2_tmu_neg",
"#mu^{-};#chi^{2}_{Target} - #chi^{2}_{Upstream};", 100, -10, 10);
216 TH1* h1_dx =
new TH1D(
"h1_dx" ,
";Dimuon x (cm);", 100, -1, 1);
217 TH1* h1_dy =
new TH1D(
"h1_dy" ,
";Dimuon y (cm);", 100, -1, 1);
218 TH1* h1_dz =
new TH1D(
"h1_dz" ,
";Dimuon z (cm);", 100, -700, 300);
219 TH1* h1_dpx =
new TH1D(
"h1_dpx",
";Dimuon p_{x} (GeV);", 100, -5, 5);
220 TH1* h1_dpy =
new TH1D(
"h1_dpy",
";Dimuon p_{y} (GeV);", 100, -5, 5);
221 TH1* h1_dpz =
new TH1D(
"h1_dpz",
";Dimuon p_{z} (GeV);", 100, 30, 130);
222 TH1* h1_m =
new TH1D(
"h1_m" ,
";Dimuon mass (GeV);", 100, 0, 10);
223 TH1* h1_trk_sep =
new TH1D(
"h1_trk_sep",
";Track separation: z_{#mu +} - z_{#mu -} (cm);", 100, -500, 500);
225 TH1* h1_dz_sel =
new TH1D(
"h1_dz_sel" ,
";Dimuon z (cm);", 100, -700, 300);
226 TH1* h1_dpz_sel =
new TH1D(
"h1_dpz_sel",
";Dimuon p_{z} (GeV);", 100, 30, 130);
227 TH1* h1_m_sel =
new TH1D(
"h1_m_sel" ,
";Dimuon mass (GeV);", 100, 0, 10);
229 TH1* h1_dz_tgt =
new TH1D(
"h1_dz_tgt" ,
";Dimuon z (cm);" , 100, -700, 300);
230 TH1* h1_dpz_tgt =
new TH1D(
"h1_dpz_tgt",
";Dimuon p_{z} (GeV);", 100, 30, 130);
231 TH1* h1_m_tgt =
new TH1D(
"h1_m_tgt" ,
";Dimuon mass (GeV);" , 100, 0, 10);
238 tree->SetBranchAddress(
"event" , &evt);
239 tree->SetBranchAddress(
"dimuon_list", &dim_list);
241 int n_ent = tree->GetEntries();
242 cout <<
"N of entries = " << n_ent << endl;
243 for (
int i_ent = 0; i_ent < n_ent; i_ent++) {
244 if ((i_ent+1) % (n_ent/10) == 0) cout <<
" " << 10*(i_ent+1)/(n_ent/10) <<
"%" << flush;
245 tree->GetEntry(i_ent);
252 h1_D1 ->Fill(evt->
D1 );
253 h1_D2 ->Fill(evt->
D2 );
254 h1_D3p->Fill(evt->
D3p);
255 h1_D3m->Fill(evt->
D3m);
258 for (
auto it = dim_list->begin(); it != dim_list->end(); it++) {
270 << evt->
D1 <<
" " << evt->
D2 <<
" " << evt->
D3p <<
" " << evt->
D3m <<
" "
271 << dd->
pos.Z() <<
" " << dd->
mom.M() << endl;
278 h1_z_pos ->Fill(dd->
pos_pos.Z());
279 h1_pz_pos ->Fill(dd->
mom_pos.Z());
283 h1_z_neg ->Fill(dd->
pos_neg.Z());
284 h1_pz_neg ->Fill(dd->
mom_neg.Z());
294 h1_chi2_tgt_pos->Fill(chi2_tgt_pos);
295 h1_chi2_dum_pos->Fill(chi2_dum_pos);
296 h1_chi2_ups_pos->Fill(chi2_ups_pos);
297 h1_chi2_tmd_pos->Fill(chi2_tgt_pos - chi2_dum_pos);
298 h1_chi2_tmu_pos->Fill(chi2_tgt_pos - chi2_ups_pos);
308 h1_chi2_tgt_neg->Fill(chi2_tgt_neg);
309 h1_chi2_dum_neg->Fill(chi2_dum_neg);
310 h1_chi2_ups_neg->Fill(chi2_ups_neg);
311 h1_chi2_tmd_neg->Fill(chi2_tgt_neg - chi2_dum_neg);
312 h1_chi2_tmu_neg->Fill(chi2_tgt_neg - chi2_ups_neg);
322 h1_dx ->Fill(dd->
pos.X());
323 h1_dy ->Fill(dd->
pos.Y());
324 h1_dz ->Fill(dd->
pos.Z());
325 h1_dpx ->Fill(dd->
mom.X());
326 h1_dpy ->Fill(dd->
mom.Y());
327 h1_dpz ->Fill(dd->
mom.Z());
328 h1_m ->Fill(dd->
mom.M());
329 h1_trk_sep->Fill(trk_sep);
331 if (chi2_tgt_pos < 0 || chi2_dum_pos < 0 || chi2_ups_pos < 0 ||
332 chi2_tgt_pos - chi2_dum_pos > 0 || chi2_tgt_pos - chi2_ups_pos > 0)
continue;
333 if (chi2_tgt_neg < 0 || chi2_dum_neg < 0 || chi2_ups_neg < 0 ||
334 chi2_tgt_neg - chi2_dum_neg > 0 || chi2_tgt_neg - chi2_ups_neg > 0)
continue;
342 h1_dz_sel ->Fill(dd->
pos.Z());
343 h1_dpz_sel->Fill(dd->
mom.Z());
344 h1_m_sel ->Fill(dd->
mom.M());
346 h1_dz_tgt ->Fill(dd->
pos.Z());
352 TCanvas* c1 =
new TCanvas(
"c1",
"");
356 h1_D1 ->Draw(); c1->SaveAs(
"result/h1_D1.png");
357 h1_D2 ->Draw(); c1->SaveAs(
"result/h1_D2.png");
358 h1_D3p->Draw(); c1->SaveAs(
"result/h1_D3p.png");
359 h1_D3m->Draw(); c1->SaveAs(
"result/h1_D3m.png");
361 h1_nhit_pos->Draw(); c1->SaveAs(
"result/h1_nhit_pos.png");
362 h1_chi2_pos->Draw(); c1->SaveAs(
"result/h1_chi2_pos.png");
363 h1_z_pos ->Draw(); c1->SaveAs(
"result/h1_z_pos.png");
364 h1_pz_pos ->Draw(); c1->SaveAs(
"result/h1_pz_pos.png");
370 h1_chi2_tgt_pos->Draw(); c1->SaveAs(
"result/h1_chi2_tgt_pos.png");
371 h1_chi2_dum_pos->Draw(); c1->SaveAs(
"result/h1_chi2_dum_pos.png");
372 h1_chi2_ups_pos->Draw(); c1->SaveAs(
"result/h1_chi2_ups_pos.png");
373 h1_chi2_tmd_pos->Draw(); c1->SaveAs(
"result/h1_chi2_tmd_pos.png");
374 h1_chi2_tmu_pos->Draw(); c1->SaveAs(
"result/h1_chi2_tmu_pos.png");
376 h1_nhit_neg->Draw(); c1->SaveAs(
"result/h1_nhit_neg.png");
377 h1_chi2_neg->Draw(); c1->SaveAs(
"result/h1_chi2_neg.png");
378 h1_z_neg ->Draw(); c1->SaveAs(
"result/h1_z_neg.png");
379 h1_pz_neg ->Draw(); c1->SaveAs(
"result/h1_pz_neg.png");
385 h1_chi2_tgt_neg->Draw(); c1->SaveAs(
"result/h1_chi2_tgt_neg.png");
386 h1_chi2_dum_neg->Draw(); c1->SaveAs(
"result/h1_chi2_dum_neg.png");
387 h1_chi2_ups_neg->Draw(); c1->SaveAs(
"result/h1_chi2_ups_neg.png");
388 h1_chi2_tmd_neg->Draw(); c1->SaveAs(
"result/h1_chi2_tmd_neg.png");
389 h1_chi2_tmu_neg->Draw(); c1->SaveAs(
"result/h1_chi2_tmu_neg.png");
391 h1_dx ->Draw(); c1->SaveAs(
"result/h1_dx.png");
392 h1_dy ->Draw(); c1->SaveAs(
"result/h1_dy.png");
393 h1_dz ->Draw(); c1->SaveAs(
"result/h1_dz.png");
394 h1_dpx ->Draw(); c1->SaveAs(
"result/h1_dpx.png");
395 h1_dpy ->Draw(); c1->SaveAs(
"result/h1_dpy.png");
396 h1_dpz ->Draw(); c1->SaveAs(
"result/h1_dpz.png");
397 h1_m ->Draw(); c1->SaveAs(
"result/h1_m.png");
398 h1_trk_sep->Draw(); c1->SaveAs(
"result/h1_trk_sep.png");
402 h1_dz_sel->SetLineColor(kRed);
403 h1_dz_sel->SetLineWidth(2);
405 c1->SaveAs(
"result/h1_dz_sel.png");
407 h1_dpz_sel->SetLineColor(kRed);
408 h1_dpz_sel->SetLineWidth(2);
410 c1->SaveAs(
"result/h1_dpz_sel.png");
412 h1_m_sel ->SetLineColor(kRed);
413 h1_m_sel ->SetLineWidth(2);
415 c1->SaveAs(
"result/h1_m_sel.png");
417 h1_dz_tgt->SetLineColor(kBlue);
418 h1_dz_tgt->SetLineWidth(2);
420 c1->SaveAs(
"result/h1_dz_tgt.png");
422 h1_dpz_tgt->SetLineColor(kBlue);
423 h1_dpz_tgt->SetLineWidth(2);
425 c1->SaveAs(
"result/h1_dpz_tgt.png");
427 h1_m_tgt ->SetLineColor(kBlue);
428 h1_m_tgt ->SetLineWidth(2);
430 c1->SaveAs(
"result/h1_m_tgt.png");
std::vector< DimuonData > DimuonList
AnaDimuon(const std::string &name="AnaDimuon")
int End(PHCompositeNode *topNode)
Called at the end of all processing.
int InitRun(PHCompositeNode *topNode)
static void AnalyzeTree(TChain *tree)
int Init(PHCompositeNode *topNode)
int process_event(PHCompositeNode *topNode)
virtual int get_run_id() const =0
Return the run ID.
virtual bool get_trigger(const SQEvent::TriggerMask i) const =0
Return the trigger bit (fired or not) of the selected trigger channel.
virtual int get_spill_id() const =0
Return the spill ID.
virtual int get_event_id() const =0
Return the event ID, which is unique per run.
virtual ConstIter end() const =0
virtual ConstIter begin() const =0
std::vector< SQHit * >::iterator Iter
An SQ interface class to hold one detector hit.
virtual short get_detector_id() const
Return the detector ID of this hit.
An SQ interface class to hold the run-level info.
virtual int get_v1495_id(const int chan) const
Return the ID of the chan-th V1495 boards.
TLorentzVector p_neg_target
virtual TVector3 get_pos() const
Return the dimuon position at vertex.
TLorentzVector p_pos_target
Track momentum projections at different location.
virtual TLorentzVector get_mom() const
Return the dimuon momentum at vertex.
virtual int get_track_id_neg() const
Return the track ID of the negative track.
virtual int get_track_id_pos() const
Return the track ID of the positive track.
TLorentzVector p_pos_dump
TLorentzVector p_neg_dump
SRecDimuon & getDimuon(Int_t i)
SRecTrack & getTrack(Int_t i)
Int_t getNDimuons()
Get dimuons.
Double_t getChisqTarget()
virtual double get_chsiq_upstream() const
virtual TVector3 get_pos_dump() const
virtual int get_num_hits() const
Return the number of hits associated to this track.
virtual TVector3 get_pos_target() const
virtual double get_chisq_dump() const
virtual TLorentzVector get_mom_vtx() const
Return the track momentum at vertex.
virtual double get_chisq() const
virtual TVector3 get_pos_vtx() const
Return the track position at vertex.
TrigRoad * FindRoad(const int road_id)
int LoadConfig(const std::string dir)
std::string str(const int level=0) const
double chisq_upstream_neg
TLorentzVector mom_target
Dimuon momentum with choice = 1.
double chisq_upstream_pos
TLorentzVector mom_dump
Dimuon momentum with choice = 2.