5 #include <TLorentzRotation.h>
10 #include <ktracker/SRecEvent.h>
31 mi_evt = findNode::getClass<SQEvent >(topNode,
"SQEvent");
32 mi_srec = findNode::getClass<SRecEvent >(topNode,
"SRecEvent");
33 mi_evt_true = findNode::getClass<SQMCEvent >(topNode,
"SQMCEvent");
34 mi_vec_trk = findNode::getClass<SQTrackVector >(topNode,
"SQTruthTrackVector");
35 mi_vec_dim = findNode::getClass<SQDimuonVector>(topNode,
"SQTruthDimuonVector");
36 if (!mi_evt || !mi_srec || !mi_evt_true || !mi_vec_trk || !mi_vec_dim) {
40 mo_file =
new TFile(
"sim_tree.root",
"RECREATE");
41 mo_tree =
new TTree(
"tree",
"Created by AnaSimDimuon");
43 mo_tree->Branch(
"evt" , &mo_evt);
46 mo_tree->Branch(
"dim_true", &mo_dim_true);
47 mo_tree->Branch(
"dim_reco", &mo_dim_reco);
58 for (
int ii = 0; ii < 4; ii++) {
70 int pol_sign = (mi_evt->
get_event_id() % 2 == 0 ? +1 : -1);
80 m_part_id_12_cnt[oss.str()]++;
86 FindDimuonRelation(id_dim_t2r);
89 for (
unsigned int ii = 0; ii < mi_vec_dim->
size(); ii++) {
110 mo_dim_true.push_back(dd);
118 if (id_dim_t2r[ii] >= 0) {
124 ddr.
x1 = dim_reco.
x1;
125 ddr.
x2 = dim_reco.
x2;
127 mo_dim_reco.push_back(ddr);
136 oss <<
"Process ID:\n";
137 for (map<int, int>::iterator it = m_proc_id_cnt.begin(); it != m_proc_id_cnt.end(); it++) {
138 oss << setw(10) << it->first <<
"\t" << setw(10) << it->second <<
"\n";
140 oss <<
"Particle-1&2 IDs:\n";
141 for (map<string, int>::iterator it = m_part_id_12_cnt.begin(); it != m_part_id_12_cnt.end(); it++) {
142 oss << setw(10) << it->first <<
"\t" << setw(10) << it->second <<
"\n";
144 oss <<
"Particle-1 ID:\n";
145 for (map<int, int>::iterator it = m_part_id_1_cnt.begin(); it != m_part_id_1_cnt.end(); it++) {
146 oss << setw(10) << it->first <<
"\t" << setw(10) << it->second <<
"\n";
148 oss <<
"Particle-2 ID:\n";
149 for (map<int, int>::iterator it = m_part_id_2_cnt.begin(); it != m_part_id_2_cnt.end(); it++) {
150 oss << setw(10) << it->first <<
"\t" << setw(10) << it->second <<
"\n";
152 oss <<
"Particle-3 ID:\n";
153 for (map<int, int>::iterator it = m_part_id_3_cnt.begin(); it != m_part_id_3_cnt.end(); it++) {
154 oss << setw(10) << it->first <<
"\t" << setw(10) << it->second <<
"\n";
156 oss <<
"Particle-4 ID:\n";
157 for (map<int, int>::iterator it = m_part_id_4_cnt.begin(); it != m_part_id_4_cnt.end(); it++) {
158 oss << setw(10) << it->first <<
"\t" << setw(10) << it->second <<
"\n";
160 cout <<
"\n" << oss.str() << endl;
162 ofstream ofs(
"pid_count.txt");
163 ofs << oss.str() << endl;
172 void AnaSimDimuon::FindDimuonRelation(IdMap_t& id_map)
175 for (
unsigned int i_true = 0; i_true < mi_vec_dim->
size(); i_true++) {
177 double mass_true = dim_true->
get_mom().M();
179 int i_reco_best = -1;
180 double mass_diff_best;
181 for (
int i_reco = 0; i_reco < mi_srec->
getNDimuons(); i_reco++) {
183 double mass_diff = fabs(dim_reco.
mass - mass_true);
184 if (i_reco_best < 0 || mass_diff < mass_diff_best) {
185 i_reco_best = i_reco;
186 mass_diff_best = mass_diff;
189 id_map[i_true] = i_reco_best;
AnaSimDimuon(const std::string &name="AnaSimDimuon")
int process_event(PHCompositeNode *topNode)
int Init(PHCompositeNode *topNode)
int End(PHCompositeNode *topNode)
Called at the end of all processing.
int InitRun(PHCompositeNode *topNode)
virtual const SQDimuon * at(const size_t id) const =0
virtual size_t size() const =0
An SQ interface class to hold one true or reconstructed dimuon.
virtual TLorentzVector get_mom_neg() const =0
Return the momentum of the negative track at vertex.
virtual TLorentzVector get_mom_pos() const =0
Return the momentum of the positive track at vertex.
virtual TLorentzVector get_mom() const =0
Return the dimuon momentum at vertex.
virtual TVector3 get_pos() const =0
Return the dimuon position at vertex.
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_event_id() const =0
Return the event ID, which is unique per run.
virtual int get_particle_id(const int i) const =0
Return the particle ID of the primary process, where i=0...3 for "0 + 1 -> 2 + 3".
virtual double get_weight() const =0
Return the event weight.
virtual TLorentzVector get_particle_momentum(const int i) const =0
Return the particle momentum of the primary process, where i=0...3 for "0 + 1 -> 2 + 3".
virtual int get_process_id() const =0
Return the primary process ID.
TVector3 vtx
3-vector vertex position
TLorentzVector p_pos
4-momentum of the muon tracks after vertex fit
Double_t mass
Kinematic variables.
SRecDimuon & getDimuon(Int_t i)
Int_t getNDimuons()
Get dimuons.
void CalcVar(const SQDimuon *dim, double &mass, double &pT, double &x1, double &x2, double &xF)
Calculate the key kinematic variables of dimuon.
void Lab2CollinsSoper(const SQDimuon *dim, double &costh, double &phi)
Convert the momenta of muon pair from Lab frame to Collins-Soper frame.
TLorentzVector par_mom[4]