CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
HTrack.cc
Go to the documentation of this file.
6 
7 //#include "DQMServices/Core/interface/DQMStore.h"
10 
11 #include "TFile.h"
12 #include "TDirectory.h"
13 
14 
15 using namespace std;
16 
17 HTrack::HTrack( DQMStore::IBooker & ibooker, string dirName_,string name,string whereIs):theName(name.c_str()),where(whereIs.c_str()){
18 
19  ibooker.cd();
20  std::string dirName=dirName_;
21  dirName+="/";
22  dirName+=name.c_str();
23  dirName+="_";
24  dirName+=whereIs.c_str();
25 
26  ibooker.setCurrentFolder(dirName.c_str());
27  hVariables = new HTrackVariables(ibooker, dirName.c_str(),name,whereIs);
28 
29  ibooker.cd();
30  string resName = dirName;
31  resName+="/Resolution";
32  hResolution = new HResolution(ibooker, resName.c_str(),name+"_Res",whereIs);
33  ibooker.cd();
34  ibooker.setCurrentFolder(dirName.c_str());
35  hTDRResolution = new HResolution(ibooker, resName.c_str(),name+"_TDRRes",whereIs);
36 
37  ibooker.cd();
38  ibooker.setCurrentFolder(dirName.c_str());
39  string pullName = dirName;
40  pullName+="/Pull";
41  hPull = new HResolution(ibooker, pullName.c_str(),name+"_Pull",whereIs);
42  hTDRPull = new HResolution(ibooker,pullName.c_str(),name+"_TDRPull",whereIs);
43 
44 
45  doSubHisto = false;
46 
47  if(doSubHisto){
48  ibooker.cd();
49  ibooker.setCurrentFolder(dirName.c_str());
50  string subName = dirName;
51  subName+="/subHistos";
52  // [5-10] GeV range
53  hResolution_5_10 = new HResolution(ibooker, subName.c_str(),name+"_Res_Pt_5_10",whereIs);
54  hTDRResolution_5_10 = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Pt_5_10",whereIs);
55  hPull_5_10 = new HResolution(ibooker, subName.c_str(),name+"_Pull_Pt_5_10",whereIs);
56 
57 
58  hResolution_10_40 = new HResolution(ibooker, subName.c_str(),name+"_Res_Pt_10_40",whereIs);
59  hTDRResolution_10_40 = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Pt_10_40",whereIs);
60  hPull_10_40 = new HResolution(ibooker, subName.c_str(),name+"_Pull_Pt_10_40",whereIs);
61 
62 
63  hResolution_40_70 = new HResolution(ibooker, subName.c_str(),name+"_Res_Pt_40_70",whereIs);
64  hTDRResolution_40_70 = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Pt_40_70",whereIs);
65  hPull_40_70 = new HResolution(ibooker, subName.c_str(),name+"_Pull_Pt_40_70",whereIs);
66 
67 
68  hResolution_70_100 = new HResolution(ibooker, subName.c_str(),name+"_Res_Pt_70_100",whereIs);
69  hTDRResolution_70_100 = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Pt_70_100",whereIs);
70  hPull_70_100 = new HResolution(ibooker, subName.c_str(),name+"_Pull_Pt_70_100",whereIs);
71 
72 
73  hResolution_08 = new HResolution(ibooker, subName.c_str(),name+"_Res_Eta_08",whereIs);
74  hTDRResolution_08 = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Eta_08",whereIs);
75  hPull_08 = new HResolution(ibooker, subName.c_str(),name+"_Pull_Eta_08",whereIs);
76 
77 
78  hResolution_08_12 = new HResolution(ibooker, subName.c_str(),name+"_Res_Eta_08_12",whereIs);
79  hTDRResolution_08_12 = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Eta_08_12",whereIs);
80  hPull_08_12 = new HResolution(ibooker, subName.c_str(),name+"_Pull_Eta_08_12",whereIs);
81 
82 
83  hResolution_12_21 = new HResolution(ibooker, subName.c_str(),name+"_Res_Eta_12_21",whereIs);
84  hTDRResolution_12_21 = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Eta_12_21",whereIs);
85  hPull_12_21 = new HResolution(ibooker, subName.c_str(),name+"_Pull_Eta_12_21",whereIs);
86 
87 
88  hResolution_12_24 = new HResolution(ibooker, subName.c_str(),name+"_Res_Eta_12_24",whereIs);
89  hTDRResolution_12_24 = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Eta_12_24",whereIs);
90  hPull_12_24 = new HResolution(ibooker, subName.c_str(),name+"_Pull_Eta_12_24",whereIs);
91 
92 
93  hResolution_12_21_plus = new HResolution(ibooker, subName.c_str(),name+"_Res_Eta_12_21_plus",whereIs);
94  hTDRResolution_12_21_plus = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Eta_12_21_plus",whereIs);
95  hPull_12_21_plus = new HResolution(ibooker, subName.c_str(),name+"_Pull_Eta_12_21_plus",whereIs);
96 
97 
98  hResolution_12_24_plus = new HResolution(ibooker, subName.c_str(),name+"_Res_Eta_12_24_plus",whereIs);
99  hTDRResolution_12_24_plus = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Eta_12_24_plus",whereIs);
100  hPull_12_24_plus = new HResolution(ibooker, subName.c_str(),name+"_Pull_Eta_12_24_plus",whereIs);
101 
102 
103  hResolution_12_21_minus = new HResolution(ibooker, subName.c_str(),name+"_Res_Eta_12_21_minus",whereIs);
104  hTDRResolution_12_21_minus = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Eta_12_21_minus",whereIs);
105  hPull_12_21_minus = new HResolution(ibooker, subName.c_str(),name+"_Pull_Eta_12_21_minus",whereIs);
106 
107 
108  hResolution_12_24_minus = new HResolution(ibooker, subName.c_str(),name+"_Res_Eta_12_24_minus",whereIs);
109  hTDRResolution_12_24_minus = new HResolution(ibooker, subName.c_str(),name+"_TDRRes_Eta_12_24_minus",whereIs);
110  hPull_12_24_minus = new HResolution(ibooker, subName.c_str(),name+"_Pull_Eta_12_24_minus",whereIs);
111  }
112 }
113 
114 double HTrack::pull(double rec,double sim, double sigmarec){
115  return (rec-sim)/sigmarec;
116 }
117 
118 double HTrack::resolution(double rec,double sim){
119  return (rec-sim)/sim;
120 }
121 
122 
124  Fill(*tsos.freeState());
125 }
126 
128 
129  hVariables->Fill(fts.momentum().mag(),
130  fts.momentum().perp(),
131  fts.momentum().eta(),
132  fts.momentum().phi(),
133  fts.charge());
134 }
135 
137  hVariables->FillDeltaR(deltaR);
138 }
139 
140 
142  return hVariables->computeEfficiency(sim,ibooker);
143 }
144 
145 
147  computeResolutionAndPull(*tsos.freeState(),simTrack);
148 }
149 
150 
152 
153 
154  // Global Resolution
155  computeResolution(fts,simTrack,hResolution);
156  computePull(fts,simTrack,hPull);
157 
158  // TDR Resolution
159  computeTDRResolution(fts,simTrack,hTDRResolution);
160  // computeTDRPull(fts,simTracks,hTDRPull);
161 
162 
163  hVariables->Fill(sqrt(simTrack.momentum().Perp2()),
164  simTrack.momentum().eta(),
165  simTrack.momentum().phi()); //FIXME
166 
167 
168  if(doSubHisto){
169  // [5-10] GeV range
170  if(sqrt(simTrack.momentum().Perp2()) <10 ){
171  computeResolution(fts,simTrack,hResolution_5_10);
173  computePull(fts,simTrack,hPull_5_10);
174  }
175 
176  // [10-40] GeV range
177  if(sqrt(simTrack.momentum().Perp2()) >=10 && sqrt(simTrack.momentum().Perp2()) < 40){
178  computeResolution(fts,simTrack,hResolution_10_40);
180  computePull(fts,simTrack,hPull_10_40);
181  }
182 
183  // [40-70] GeV range
184  if(sqrt(simTrack.momentum().Perp2()) >=40 && sqrt(simTrack.momentum().Perp2()) < 70){
185  computeResolution(fts,simTrack,hResolution_40_70);
187  computePull(fts,simTrack,hPull_40_70);
188  }
189 
190  // [70-100] GeV range
191  if(sqrt(simTrack.momentum().Perp2()) >= 70 && sqrt(simTrack.momentum().Perp2()) < 100){
192  computeResolution(fts,simTrack,hResolution_70_100);
194  computePull(fts,simTrack,hPull_70_100);
195  }
196 
197  // eta range |eta|<0.8
198  if(abs(simTrack.momentum().eta()) <= 0.8){
199  computeResolution(fts,simTrack,hResolution_08);
201  computePull(fts,simTrack,hPull_08);
202  }
203 
204  // eta range 0.8<|eta|<1.2
205  if( abs(simTrack.momentum().eta()) > 0.8 && abs(simTrack.momentum().eta()) <= 1.2 ){
206  computeResolution(fts,simTrack,hResolution_08_12);
208  computePull(fts,simTrack,hPull_08_12);
209  }
210 
211  // eta range 1.2<|eta|<2.1
212  if( abs(simTrack.momentum().eta()) > 1.2 && abs(simTrack.momentum().eta()) <= 2.1 ){
213  computeResolution(fts,simTrack,hResolution_12_21);
215  computePull(fts,simTrack,hPull_12_21);
216 
217  if(simTrack.momentum().eta() > 0){
220  computePull(fts,simTrack,hPull_12_21_plus);
221  }
222  else{
225  computePull(fts,simTrack,hPull_12_21_minus);
226  }
227  }
228 
229  // eta range 1.2<|eta|<2.4
230  if( abs(simTrack.momentum().eta()) > 1.2 && abs(simTrack.momentum().eta()) <= 2.4 ){
231  computeResolution(fts,simTrack,hResolution_12_24);
233  computePull(fts,simTrack,hPull_12_24);
234 
235  if(simTrack.momentum().eta() > 0){
238  computePull(fts,simTrack,hPull_12_24_plus);
239  }
240  else{
243  computePull(fts,simTrack,hPull_12_24_minus);
244  }
245  }
246  }
247 }
248 
250  SimTrack& simTrack,
251  HResolution* hReso){
252 
253 
254  hReso->Fill(simTrack.momentum().mag(),
255  sqrt(simTrack.momentum().Perp2()),
256  simTrack.momentum().eta(),
257  simTrack.momentum().phi(),
258  resolution(fts.momentum().mag(),simTrack.momentum().mag()),
259  resolution(fts.momentum().perp(),sqrt(simTrack.momentum().Perp2())),
260  fts.momentum().eta()-simTrack.momentum().eta(),
261  fts.momentum().phi()-simTrack.momentum().phi(),
262  fts.charge()+simTrack.type()/abs(simTrack.type())); // FIXME
263 }
264 
266  SimTrack& simTrack,
267  HResolution* hReso){
268 
269  int simCharge = -simTrack.type()/ abs(simTrack.type());
270 
271  double invSimP = (simTrack.momentum().mag() == 0 ) ? 0 : simTrack.momentum().mag();
272  double signedInverseRecMom = (simTrack.momentum().mag() == 0 ) ? 0 : fts.signedInverseMomentum();
273 
274  hReso->Fill(simTrack.momentum().mag(),
275  sqrt(simTrack.momentum().Perp2()),
276  simTrack.momentum().eta(),
277  simTrack.momentum().phi(),
278  resolution(signedInverseRecMom , simCharge*invSimP ),
279  resolution(fts.charge()/fts.momentum().perp(),simCharge/sqrt(simTrack.momentum().Perp2())));
280 }
281 
283  SimTrack& simTrack,
284  HResolution* hReso){
285 
286  // x,y,z, px,py,pz
288 
289  double partialPterror = errors[3][3]*pow(fts.momentum().x(),2) + errors[4][4]*pow(fts.momentum().y(),2);
290 
291  // sqrt( (px*spx)^2 + (py*spy)^2 ) / pt
292  double pterror = sqrt(partialPterror)/fts.momentum().perp();
293 
294  // sqrt( (px*spx)^2 + (py*spy)^2 + (pz*spz)^2 ) / p
295  double perror = sqrt(partialPterror+errors[5][5]*pow(fts.momentum().z(),2))/fts.momentum().mag();
296 
297  double phierror = sqrt(fts.curvilinearError().matrix()[2][2]);
298 
299  double etaerror = sqrt(fts.curvilinearError().matrix()[1][1])*abs(sin(fts.momentum().theta()));
300 
301 
302  hReso->Fill(simTrack.momentum().mag(),
303  sqrt(simTrack.momentum().Perp2()),
304  simTrack.momentum().eta(),
305  simTrack.momentum().phi(),
306  pull(fts.momentum().mag(),simTrack.momentum().mag(),perror),
307  pull(fts.momentum().perp(),sqrt(simTrack.momentum().Perp2()),pterror),
308  pull(fts.momentum().eta(),simTrack.momentum().eta(),etaerror),
309  pull(fts.momentum().phi(),simTrack.momentum().phi(),phierror),
310  pull(fts.charge() , -simTrack.type()/ abs(simTrack.type()), 1.)); // FIXME
311 }
HResolution * hPull_08_12
Definition: HTrack.h:88
double computeEfficiency(HTrackVariables *sim, DQMStore::IBooker &ibooker)
Definition: Histograms.h:90
void computeResolutionAndPull(TrajectoryStateOnSurface &vtx, SimTrack &simTrack)
Definition: HTrack.cc:146
HResolution * hResolution_12_21
Definition: HTrack.h:91
HResolution * hTDRResolution
Definition: HTrack.h:57
HResolution * hTDRResolution_12_24_plus
Definition: HTrack.h:107
CartesianTrajectoryError cartesianError() const
HResolution * hPull
Definition: HTrack.h:54
T perp() const
Definition: PV3DBase.h:72
HResolution * hResolution
Definition: HTrack.h:53
void cd(void)
Definition: DQMStore.cc:266
HResolution * hTDRResolution_12_24
Definition: HTrack.h:97
HResolution * hTDRResolution_40_70
Definition: HTrack.h:72
HResolution * hResolution_12_24_plus
Definition: HTrack.h:106
double resolution(double rec, double sim)
Definition: HTrack.cc:118
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
ROOT::Math::SMatrix< double, 6, 6, ROOT::Math::MatRepSym< double, 6 > > AlgebraicSymMatrix66
Geom::Phi< T > phi() const
Definition: PV3DBase.h:69
T y() const
Definition: PV3DBase.h:63
void computeTDRResolution(const FreeTrajectoryState &fts, SimTrack &simTracks, HResolution *hReso)
Definition: HTrack.cc:265
HResolution * hResolution_10_40
Definition: HTrack.h:66
HResolution * hPull_10_40
Definition: HTrack.h:68
HResolution * hResolution_12_24
Definition: HTrack.h:96
void computeResolution(const FreeTrajectoryState &fts, SimTrack &simTracks, HResolution *hReso)
Definition: HTrack.cc:249
TrackCharge charge() const
HResolution * hResolution_12_21_plus
Definition: HTrack.h:101
Definition: sim.h:19
const CurvilinearTrajectoryError & curvilinearError() const
HResolution * hTDRResolution_5_10
Definition: HTrack.h:62
HResolution * hResolution_12_24_minus
Definition: HTrack.h:116
Geom::Theta< T > theta() const
Definition: PV3DBase.h:75
HResolution * hResolution_5_10
Definition: HTrack.h:61
T mag() const
Definition: PV3DBase.h:67
HTrackVariables * hVariables
Definition: HTrack.h:50
HResolution * hTDRResolution_12_21_minus
Definition: HTrack.h:112
HResolution * hPull_12_21
Definition: HTrack.h:93
HResolution * hResolution_08_12
Definition: HTrack.h:86
T sqrt(T t)
Definition: SSEVec.h:48
HResolution * hTDRResolution_12_21
Definition: HTrack.h:92
FreeTrajectoryState const * freeState(bool withErrors=true) const
T z() const
Definition: PV3DBase.h:64
HResolution * hTDRResolution_12_24_minus
Definition: HTrack.h:117
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
HResolution * hResolution_40_70
Definition: HTrack.h:71
HResolution * hResolution_08
Definition: HTrack.h:81
HResolution * hPull_70_100
Definition: HTrack.h:78
void Fill(TrajectoryStateOnSurface &)
Definition: HTrack.cc:123
GlobalVector momentum() const
bool doSubHisto
Definition: HTrack.h:123
HResolution * hTDRPull
Definition: HTrack.h:58
HResolution * hPull_40_70
Definition: HTrack.h:73
const AlgebraicSymMatrix66 & matrix() const
double deltaR(double eta1, double eta2, double phi1, double phi2)
Definition: TreeUtility.cc:17
HResolution * hTDRResolution_08_12
Definition: HTrack.h:87
HResolution * hPull_12_24_minus
Definition: HTrack.h:118
HResolution * hPull_12_21_minus
Definition: HTrack.h:113
void Fill(double p, double pt, double eta, double phi, double charge)
Definition: Histograms.h:71
void setCurrentFolder(const std::string &fullpath)
Definition: DQMStore.cc:274
HResolution * hPull_12_24
Definition: HTrack.h:98
double computeEfficiency(HTrackVariables *sim, DQMStore::IBooker &)
Definition: HTrack.cc:141
HResolution * hTDRResolution_70_100
Definition: HTrack.h:77
T eta() const
Definition: PV3DBase.h:76
HResolution * hTDRResolution_08
Definition: HTrack.h:82
int type() const
particle type (HEP PDT convension)
Definition: CoreSimTrack.h:40
HResolution * hPull_12_24_plus
Definition: HTrack.h:108
const AlgebraicSymMatrix55 & matrix() const
HTrack(DQMStore::IBooker &, std::string, std::string name, std::string whereIs="")
Definition: HTrack.cc:17
double pull(double rec, double sim, double sigmarec)
Definition: HTrack.cc:114
const math::XYZTLorentzVectorD & momentum() const
particle info...
Definition: CoreSimTrack.h:36
HResolution * hResolution_70_100
Definition: HTrack.h:76
HResolution * hTDRResolution_10_40
Definition: HTrack.h:67
void FillDeltaR(double)
Definition: HTrack.cc:136
void computePull(const FreeTrajectoryState &fts, SimTrack &simTracks, HResolution *hReso)
Definition: HTrack.cc:282
HResolution * hPull_5_10
Definition: HTrack.h:63
virtual Int_t Fill(Double_t x, Double_t y)
Definition: Histograms.h:1739
T x() const
Definition: PV3DBase.h:62
double signedInverseMomentum() const
HResolution * hPull_08
Definition: HTrack.h:83
Power< A, B >::type pow(const A &a, const B &b)
Definition: Power.h:40
void FillDeltaR(double deltaR)
Definition: Histograms.h:86
HResolution * hResolution_12_21_minus
Definition: HTrack.h:111
HResolution * hPull_12_21_plus
Definition: HTrack.h:103
HResolution * hTDRResolution_12_21_plus
Definition: HTrack.h:102