00001 #include "Validation/RecoMuon/plugins/MuonTrackValidator.h"
00002 #include "DQMServices/ClientConfig/interface/FitSlicesYTool.h"
00003
00004 #include "FWCore/Framework/interface/MakerMacros.h"
00005 #include "FWCore/MessageLogger/interface/MessageLogger.h"
00006
00007 #include "DataFormats/TrackReco/interface/Track.h"
00008 #include "DataFormats/TrackReco/interface/TrackFwd.h"
00009 #include "DataFormats/GsfTrackReco/interface/GsfTrack.h"
00010 #include "DataFormats/GsfTrackReco/interface/GsfTrackFwd.h"
00011 #include "SimDataFormats/Track/interface/SimTrackContainer.h"
00012 #include "SimDataFormats/Vertex/interface/SimVertexContainer.h"
00013 #include "SimTracker/TrackAssociation/interface/TrackAssociatorByChi2.h"
00014 #include "SimTracker/TrackAssociation/interface/TrackAssociatorByHits.h"
00015 #include "SimTracker/TrackerHitAssociation/interface/TrackerHitAssociator.h"
00016 #include "SimTracker/Records/interface/TrackAssociatorRecord.h"
00017 #include "SimDataFormats/TrackingAnalysis/interface/TrackingParticle.h"
00018 #include "TrackingTools/TrajectoryState/interface/FreeTrajectoryState.h"
00019 #include "TrackingTools/PatternTools/interface/TSCBLBuilderNoMaterial.h"
00020 #include "SimTracker/TrackAssociation/plugins/ParametersDefinerForTPESProducer.h"
00021 #include "SimTracker/TrackAssociation/plugins/CosmicParametersDefinerForTPESProducer.h"
00022
00023 #include "TMath.h"
00024 #include <TF1.h>
00025
00026 using namespace std;
00027 using namespace edm;
00028
00029 void MuonTrackValidator::beginRun(Run const&, EventSetup const& setup) {
00030
00031
00032
00033 int j=0;
00034 for (unsigned int ww=0;ww<associators.size();ww++){
00035 for (unsigned int www=0;www<label.size();www++){
00036
00037 dbe_->cd();
00038 InputTag algo = label[www];
00039 string dirName=dirName_;
00040 if (algo.process()!="")
00041 dirName+=algo.process()+"_";
00042 if(algo.label()!="")
00043 dirName+=algo.label()+"_";
00044 if(algo.instance()!="")
00045 dirName+=algo.instance()+"_";
00046 if (dirName.find("Tracks")<dirName.length()){
00047 dirName.replace(dirName.find("Tracks"),6,"");
00048 }
00049 string assoc= associators[ww];
00050 if (assoc.find("Track")<assoc.length()){
00051 assoc.replace(assoc.find("Track"),5,"");
00052 }
00053 dirName+=assoc;
00054 std::replace(dirName.begin(), dirName.end(), ':', '_');
00055 dbe_->setCurrentFolder(dirName.c_str());
00056
00057 setUpVectors();
00058
00059 dbe_->goUp();
00060 string subDirName = dirName + "/simulation";
00061 dbe_->setCurrentFolder(subDirName.c_str());
00062 h_ptSIM.push_back( dbe_->book1D("ptSIM", "generated p_{t}", 5500, 0, 110 ) );
00063 h_etaSIM.push_back( dbe_->book1D("etaSIM", "generated pseudorapidity", 500, -2.5, 2.5 ) );
00064 h_tracksSIM.push_back( dbe_->book1D("tracksSIM","number of simulated tracks",200,-0.5,99.5) );
00065 h_vertposSIM.push_back( dbe_->book1D("vertposSIM","Transverse position of sim vertices",100,0.,120.) );
00066
00067 dbe_->cd();
00068 dbe_->setCurrentFolder(dirName.c_str());
00069 h_tracks.push_back( dbe_->book1D("tracks","number of reconstructed tracks",200,-0.5,19.5) );
00070 h_fakes.push_back( dbe_->book1D("fakes","number of fake reco tracks",20,-0.5,19.5) );
00071 h_charge.push_back( dbe_->book1D("charge","charge",3,-1.5,1.5) );
00072 h_hits.push_back( dbe_->book1D("hits", "number of hits per track", nintHit,minHit,maxHit ) );
00073 h_losthits.push_back( dbe_->book1D("losthits", "number of lost hits per track", nintHit,minHit,maxHit) );
00074 h_nchi2.push_back( dbe_->book1D("chi2", "normalized #chi^{2}", 200, 0, 20 ) );
00075 h_nchi2_prob.push_back( dbe_->book1D("chi2_prob", "normalized #chi^{2} probability",100,0,1));
00076
00078 h_recoeta.push_back( dbe_->book1D("num_reco_eta","N of reco track vs eta",nint,min,max) );
00079 h_assoceta.push_back( dbe_->book1D("num_assoc(simToReco)_eta","N of associated tracks (simToReco) vs eta",nint,min,max) );
00080 h_assoc2eta.push_back( dbe_->book1D("num_assoc(recoToSim)_eta","N of associated (recoToSim) tracks vs eta",nint,min,max) );
00081 h_simuleta.push_back( dbe_->book1D("num_simul_eta","N of simulated tracks vs eta",nint,min,max) );
00082 h_recopT.push_back( dbe_->book1D("num_reco_pT","N of reco track vs pT",nintpT,minpT,maxpT) );
00083 h_assocpT.push_back( dbe_->book1D("num_assoc(simToReco)_pT","N of associated tracks (simToReco) vs pT",nintpT,minpT,maxpT) );
00084 h_assoc2pT.push_back( dbe_->book1D("num_assoc(recoToSim)_pT","N of associated (recoToSim) tracks vs pT",nintpT,minpT,maxpT) );
00085 h_simulpT.push_back( dbe_->book1D("num_simul_pT","N of simulated tracks vs pT",nintpT,minpT,maxpT) );
00086
00087 h_recohit.push_back( dbe_->book1D("num_reco_hit","N of reco track vs hit",nintHit,minHit,maxHit) );
00088 h_assochit.push_back( dbe_->book1D("num_assoc(simToReco)_hit","N of associated tracks (simToReco) vs hit",nintHit,minHit,maxHit) );
00089 h_assoc2hit.push_back( dbe_->book1D("num_assoc(recoToSim)_hit","N of associated (recoToSim) tracks vs hit",nintHit,minHit,maxHit) );
00090 h_simulhit.push_back( dbe_->book1D("num_simul_hit","N of simulated tracks vs hit",nintHit,minHit,maxHit) );
00091
00092 h_recophi.push_back( dbe_->book1D("num_reco_phi","N of reco track vs phi",nintPhi,minPhi,maxPhi) );
00093 h_assocphi.push_back( dbe_->book1D("num_assoc(simToReco)_phi","N of associated tracks (simToReco) vs phi",nintPhi,minPhi,maxPhi) );
00094 h_assoc2phi.push_back( dbe_->book1D("num_assoc(recoToSim)_phi","N of associated (recoToSim) tracks vs phi",nintPhi,minPhi,maxPhi) );
00095 h_simulphi.push_back( dbe_->book1D("num_simul_phi","N of simulated tracks vs phi",nintPhi,minPhi,maxPhi) );
00096
00097 h_recodxy.push_back( dbe_->book1D("num_reco_dxy","N of reco track vs dxy",nintDxy,minDxy,maxDxy) );
00098 h_assocdxy.push_back( dbe_->book1D("num_assoc(simToReco)_dxy","N of associated tracks (simToReco) vs dxy",nintDxy,minDxy,maxDxy) );
00099 h_assoc2dxy.push_back( dbe_->book1D("num_assoc(recoToSim)_dxy","N of associated (recoToSim) tracks vs dxy",nintDxy,minDxy,maxDxy) );
00100 h_simuldxy.push_back( dbe_->book1D("num_simul_dxy","N of simulated tracks vs dxy",nintDxy,minDxy,maxDxy) );
00101
00102 h_recodz.push_back( dbe_->book1D("num_reco_dz","N of reco track vs dz",nintDz,minDz,maxDz) );
00103 h_assocdz.push_back( dbe_->book1D("num_assoc(simToReco)_dz","N of associated tracks (simToReco) vs dz",nintDz,minDz,maxDz) );
00104 h_assoc2dz.push_back( dbe_->book1D("num_assoc(recoToSim)_dz","N of associated (recoToSim) tracks vs dz",nintDz,minDz,maxDz) );
00105 h_simuldz.push_back( dbe_->book1D("num_simul_dz","N of simulated tracks vs dz",nintDz,minDz,maxDz) );
00106
00107 h_assocvertpos.push_back( dbe_->book1D("num_assoc(simToReco)_vertpos","N of associated tracks (simToReco) vs transverse vert position",nintVertpos,minVertpos,maxVertpos) );
00108 h_simulvertpos.push_back( dbe_->book1D("num_simul_vertpos","N of simulated tracks vs transverse vert position",nintVertpos,minVertpos,maxVertpos) );
00109
00110 h_assoczpos.push_back( dbe_->book1D("num_assoc(simToReco)_zpos","N of associated tracks (simToReco) vs z vert position",nintZpos,minZpos,maxZpos) );
00111 h_simulzpos.push_back( dbe_->book1D("num_simul_zpos","N of simulated tracks vs z vert position",nintZpos,minZpos,maxZpos) );
00112
00113
00115
00116 h_eta.push_back( dbe_->book1D("eta", "pseudorapidity residue", 1000, -0.1, 0.1 ) );
00117 h_pt.push_back( dbe_->book1D("pullPt", "pull of p_{t}", 100, -10, 10 ) );
00118 h_pullTheta.push_back( dbe_->book1D("pullTheta","pull of #theta parameter",250,-25,25) );
00119 h_pullPhi.push_back( dbe_->book1D("pullPhi","pull of #phi parameter",250,-25,25) );
00120 h_pullDxy.push_back( dbe_->book1D("pullDxy","pull of dxy parameter",250,-25,25) );
00121 h_pullDz.push_back( dbe_->book1D("pullDz","pull of dz parameter",250,-25,25) );
00122 h_pullQoverp.push_back( dbe_->book1D("pullQoverp","pull of qoverp parameter",250,-25,25) );
00123
00124 if (associators[ww]=="TrackAssociatorByChi2"){
00125 h_assochi2.push_back( dbe_->book1D("assocChi2","track association #chi^{2}",1000000,0,100000) );
00126 h_assochi2_prob.push_back(dbe_->book1D("assocChi2_prob","probability of association #chi^{2}",100,0,1));
00127 } else if (associators[ww]=="TrackAssociatorByHits"){
00128 h_assocFraction.push_back( dbe_->book1D("assocFraction","fraction of shared hits",200,0,2) );
00129 h_assocSharedHit.push_back(dbe_->book1D("assocSharedHit","number of shared hits",20,0,20));
00130 }
00131
00132 chi2_vs_nhits.push_back( dbe_->book2D("chi2_vs_nhits","#chi^{2} vs nhits",25,0,25,100,0,10) );
00133 h_chi2meanhitsh.push_back( dbe_->bookProfile("chi2mean_vs_nhits","mean #chi^{2} vs nhits",25,0,25,100,0,10) );
00134
00135 etares_vs_eta.push_back( dbe_->book2D("etares_vs_eta","etaresidue vs eta",nint,min,max,200,-0.1,0.1) );
00136 nrec_vs_nsim.push_back( dbe_->book2D("nrec_vs_nsim","nrec vs nsim",20,-0.5,19.5,20,-0.5,19.5) );
00137
00138 chi2_vs_eta.push_back( dbe_->book2D("chi2_vs_eta","chi2_vs_eta",nint,min,max, 200, 0, 20 ));
00139 h_chi2meanh.push_back( dbe_->bookProfile("chi2mean","mean #chi^{2} vs #eta",nint,min,max, 200, 0, 20) );
00140 chi2_vs_phi.push_back( dbe_->book2D("chi2_vs_phi","#chi^{2} vs #phi",nintPhi,minPhi,maxPhi, 200, 0, 20 ) );
00141 h_chi2mean_vs_phi.push_back( dbe_->bookProfile("chi2mean_vs_phi","mean of #chi^{2} vs #phi",nintPhi,minPhi,maxPhi, 200, 0, 20) );
00142
00143 nhits_vs_eta.push_back( dbe_->book2D("nhits_vs_eta","nhits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00144 nDThits_vs_eta.push_back( dbe_->book2D("nDThits_vs_eta","# DT hits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00145 nCSChits_vs_eta.push_back( dbe_->book2D("nCSChits_vs_eta","# CSC hits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00146 nRPChits_vs_eta.push_back( dbe_->book2D("nRPChits_vs_eta","# RPC hits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00147
00148 h_DThits_eta.push_back( dbe_->bookProfile("DThits_eta","mean # DT hits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00149 h_CSChits_eta.push_back( dbe_->bookProfile("CSChits_eta","mean # CSC hits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00150 h_RPChits_eta.push_back( dbe_->bookProfile("RPChits_eta","mean # RPC hits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00151 h_hits_eta.push_back( dbe_->bookProfile("hits_eta","mean #hits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00152 nhits_vs_phi.push_back( dbe_->book2D("nhits_vs_phi","#hits vs #phi",nintPhi,minPhi,maxPhi,nintHit,minHit,maxHit) );
00153 h_hits_phi.push_back( dbe_->bookProfile("hits_phi","mean #hits vs #phi",nintPhi,minPhi,maxPhi, nintHit,minHit,maxHit) );
00154
00155 nlosthits_vs_eta.push_back( dbe_->book2D("nlosthits_vs_eta","nlosthits vs eta",nint,min,max,nintHit,minHit,maxHit) );
00156 h_losthits_eta.push_back( dbe_->bookProfile("losthits_eta","losthits_eta",nint,min,max,nintHit,minHit,maxHit) );
00157
00158 ptres_vs_eta.push_back(dbe_->book2D("ptres_vs_eta","ptres_vs_eta",nint,min,max, ptRes_nbin, ptRes_rangeMin, ptRes_rangeMax));
00159 ptres_vs_phi.push_back( dbe_->book2D("ptres_vs_phi","p_{t} res vs #phi",nintPhi,minPhi,maxPhi, ptRes_nbin, ptRes_rangeMin, ptRes_rangeMax));
00160 ptres_vs_pt.push_back(dbe_->book2D("ptres_vs_pt","ptres_vs_pt",nintpT,minpT,maxpT, ptRes_nbin, ptRes_rangeMin, ptRes_rangeMax));
00161
00162 cotThetares_vs_eta.push_back(dbe_->book2D("cotThetares_vs_eta","cotThetares_vs_eta",nint,min,max,cotThetaRes_nbin, cotThetaRes_rangeMin, cotThetaRes_rangeMax));
00163 cotThetares_vs_pt.push_back(dbe_->book2D("cotThetares_vs_pt","cotThetares_vs_pt",nintpT,minpT,maxpT, cotThetaRes_nbin, cotThetaRes_rangeMin, cotThetaRes_rangeMax));
00164
00165 phires_vs_eta.push_back(dbe_->book2D("phires_vs_eta","phires_vs_eta",nint,min,max, phiRes_nbin, phiRes_rangeMin, phiRes_rangeMax));
00166 phires_vs_pt.push_back(dbe_->book2D("phires_vs_pt","phires_vs_pt",nintpT,minpT,maxpT, phiRes_nbin, phiRes_rangeMin, phiRes_rangeMax));
00167 phires_vs_phi.push_back(dbe_->book2D("phires_vs_phi","#phi res vs #phi",nintPhi,minPhi,maxPhi,phiRes_nbin, phiRes_rangeMin, phiRes_rangeMax));
00168
00169 dxyres_vs_eta.push_back(dbe_->book2D("dxyres_vs_eta","dxyres_vs_eta",nint,min,max,dxyRes_nbin, dxyRes_rangeMin, dxyRes_rangeMax));
00170 dxyres_vs_pt.push_back( dbe_->book2D("dxyres_vs_pt","dxyres_vs_pt",nintpT,minpT,maxpT,dxyRes_nbin, dxyRes_rangeMin, dxyRes_rangeMax));
00171
00172 dzres_vs_eta.push_back(dbe_->book2D("dzres_vs_eta","dzres_vs_eta",nint,min,max,dzRes_nbin, dzRes_rangeMin, dzRes_rangeMax));
00173 dzres_vs_pt.push_back(dbe_->book2D("dzres_vs_pt","dzres_vs_pt",nintpT,minpT,maxpT,dzRes_nbin, dzRes_rangeMin, dzRes_rangeMax));
00174
00175 ptmean_vs_eta_phi.push_back(dbe_->bookProfile2D("ptmean_vs_eta_phi","mean p_{t} vs #eta and #phi",nintPhi,minPhi,maxPhi,nint,min,max,1000,0,1000));
00176 phimean_vs_eta_phi.push_back(dbe_->bookProfile2D("phimean_vs_eta_phi","mean #phi vs #eta and #phi",nintPhi,minPhi,maxPhi,nint,min,max,nintPhi,minPhi,maxPhi));
00177
00178
00179 dxypull_vs_eta.push_back(dbe_->book2D("dxypull_vs_eta","dxypull_vs_eta",nint,min,max,100,-10,10));
00180 ptpull_vs_eta.push_back(dbe_->book2D("ptpull_vs_eta","ptpull_vs_eta",nint,min,max,100,-10,10));
00181 dzpull_vs_eta.push_back(dbe_->book2D("dzpull_vs_eta","dzpull_vs_eta",nint,min,max,100,-10,10));
00182 phipull_vs_eta.push_back(dbe_->book2D("phipull_vs_eta","phipull_vs_eta",nint,min,max,100,-10,10));
00183 thetapull_vs_eta.push_back(dbe_->book2D("thetapull_vs_eta","thetapull_vs_eta",nint,min,max,100,-10,10));
00184
00185
00186 ptpull_vs_phi.push_back(dbe_->book2D("ptpull_vs_phi","p_{t} pull vs #phi",nintPhi,minPhi,maxPhi,100,-10,10));
00187 phipull_vs_phi.push_back(dbe_->book2D("phipull_vs_phi","#phi pull vs #phi",nintPhi,minPhi,maxPhi,100,-10,10));
00188 thetapull_vs_phi.push_back(dbe_->book2D("thetapull_vs_phi","#theta pull vs #phi",nintPhi,minPhi,maxPhi,100,-10,10));
00189
00190 nrecHit_vs_nsimHit_sim2rec.push_back( dbe_->book2D("nrecHit_vs_nsimHit_sim2rec","nrecHit vs nsimHit (Sim2RecAssoc)",nintHit,minHit,maxHit, nintHit,minHit,maxHit ));
00191 nrecHit_vs_nsimHit_rec2sim.push_back( dbe_->book2D("nrecHit_vs_nsimHit_rec2sim","nrecHit vs nsimHit (Rec2simAssoc)",nintHit,minHit,maxHit, nintHit,minHit,maxHit ));
00192
00193 if (MABH) {
00194 h_PurityVsQuality.push_back( dbe_->book2D("PurityVsQuality","Purity vs Quality (MABH)",20,0.01,1.01,20,0.01,1.01) );
00195 h_assoceta_Quality05.push_back( dbe_->book1D("num_assoc(simToReco)_eta_Q05","N of associated tracks (simToReco) vs eta (Quality>0.5)",nint,min,max) );
00196 h_assoceta_Quality075.push_back( dbe_->book1D("num_assoc(simToReco)_eta_Q075","N of associated tracks (simToReco) vs eta (Quality>0.75)",nint,min,max) );
00197 h_assocpT_Quality05.push_back( dbe_->book1D("num_assoc(simToReco)_pT_Q05","N of associated tracks (simToReco) vs pT (Quality>0.5)",nintpT,minpT,maxpT) );
00198 h_assocpT_Quality075.push_back( dbe_->book1D("num_assoc(simToReco)_pT_Q075","N of associated tracks (simToReco) vs pT (Quality>0.75)",nintpT,minpT,maxpT) );
00199 h_assocphi_Quality05.push_back( dbe_->book1D("num_assoc(simToReco)_phi_Q05","N of associated tracks (simToReco) vs phi (Quality>0.5)",nintPhi,minPhi,maxPhi) );
00200 h_assocphi_Quality075.push_back( dbe_->book1D("num_assoc(simToReco)_phi_Q075","N of associated tracks (simToReco) vs phi (Quality>0.75)",nintPhi,minPhi,maxPhi) );
00201 }
00202
00203 if(useLogPt){
00204 BinLogX(dzres_vs_pt[j]->getTH2F());
00205 BinLogX(dxyres_vs_pt[j]->getTH2F());
00206 BinLogX(phires_vs_pt[j]->getTH2F());
00207 BinLogX(cotThetares_vs_pt[j]->getTH2F());
00208 BinLogX(ptres_vs_pt[j]->getTH2F());
00209 BinLogX(h_recopT[j]->getTH1F());
00210 BinLogX(h_assocpT[j]->getTH1F());
00211 BinLogX(h_assoc2pT[j]->getTH1F());
00212 BinLogX(h_simulpT[j]->getTH1F());
00213 if (MABH) {
00214 BinLogX(h_assocpT_Quality05[j]->getTH1F());
00215 BinLogX(h_assocpT_Quality075[j]->getTH1F());
00216 }
00217 j++;
00218 }
00219
00220 }
00221 }
00222 if (UseAssociators) {
00223 edm::ESHandle<TrackAssociatorBase> theAssociator;
00224 for (unsigned int w=0;w<associators.size();w++) {
00225 setup.get<TrackAssociatorRecord>().get(associators[w],theAssociator);
00226 associator.push_back( theAssociator.product() );
00227 }
00228 }
00229 }
00230
00231 void MuonTrackValidator::analyze(const edm::Event& event, const edm::EventSetup& setup){
00232 using namespace reco;
00233
00234 edm::LogInfo("MuonTrackValidator") << "\n====================================================" << "\n"
00235 << "Analyzing new event" << "\n"
00236 << "====================================================\n" << "\n";
00237 edm::ESHandle<ParametersDefinerForTP> parametersDefinerTP;
00238 setup.get<TrackAssociatorRecord>().get(parametersDefiner,parametersDefinerTP);
00239
00240 edm::Handle<TrackingParticleCollection> TPCollectionHeff ;
00241 event.getByLabel(label_tp_effic,TPCollectionHeff);
00242 const TrackingParticleCollection tPCeff = *(TPCollectionHeff.product());
00243
00244 edm::Handle<TrackingParticleCollection> TPCollectionHfake ;
00245 event.getByLabel(label_tp_fake,TPCollectionHfake);
00246 const TrackingParticleCollection tPCfake = *(TPCollectionHfake.product());
00247
00248 edm::Handle<reco::BeamSpot> recoBeamSpotHandle;
00249 event.getByLabel(bsSrc,recoBeamSpotHandle);
00250 reco::BeamSpot bs = *recoBeamSpotHandle;
00251
00252 int w=0;
00253 for (unsigned int ww=0;ww<associators.size();ww++){
00254 for (unsigned int www=0;www<label.size();www++){
00255
00256
00257
00258 edm::Handle<View<Track> > trackCollection;
00259
00260 reco::RecoToSimCollection recSimColl;
00261 reco::SimToRecoCollection simRecColl;
00262 unsigned int trackCollectionSize = 0;
00263
00264
00265 if(!event.getByLabel(label[www], trackCollection)&&ignoremissingtkcollection_) {
00266
00267 recSimColl.post_insert();
00268 simRecColl.post_insert();
00269
00270 }
00271
00272 else {
00273
00274 trackCollectionSize = trackCollection->size();
00275
00276 if(UseAssociators){
00277 edm::LogVerbatim("MuonTrackValidator") << "Analyzing "
00278 << label[www].process()<<":"
00279 << label[www].label()<<":"
00280 << label[www].instance()<<" with "
00281 << associators[ww].c_str() <<"\n";
00282
00283 LogTrace("MuonTrackValidator") << "Calling associateRecoToSim method" << "\n";
00284 recSimColl=associator[ww]->associateRecoToSim(trackCollection,
00285 TPCollectionHfake,
00286 &event);
00287 LogTrace("MuonTrackValidator") << "Calling associateSimToReco method" << "\n";
00288 simRecColl=associator[ww]->associateSimToReco(trackCollection,
00289 TPCollectionHeff,
00290 &event);
00291 }
00292 else{
00293 edm::LogVerbatim("MuonTrackValidator") << "Analyzing "
00294 << label[www].process()<<":"
00295 << label[www].label()<<":"
00296 << label[www].instance()<<" with "
00297 << associatormap.process()<<":"
00298 << associatormap.label()<<":"
00299 << associatormap.instance()<<"\n";
00300
00301 Handle<reco::SimToRecoCollection > simtorecoCollectionH;
00302 event.getByLabel(associatormap,simtorecoCollectionH);
00303 simRecColl= *(simtorecoCollectionH.product());
00304
00305 Handle<reco::RecoToSimCollection > recotosimCollectionH;
00306 event.getByLabel(associatormap,recotosimCollectionH);
00307 recSimColl= *(recotosimCollectionH.product());
00308 }
00309
00310 }
00311
00312
00313
00314
00315
00316
00317 edm::LogVerbatim("MuonTrackValidator") << "\n# of TrackingParticles: " << tPCeff.size() << "\n";
00318 int ats = 0;
00319 int st=0;
00320 for (TrackingParticleCollection::size_type i=0; i<tPCeff.size(); i++){
00321 bool TP_is_matched = false;
00322 double quality = 0.;
00323 bool Quality05 = false;
00324 bool Quality075 = false;
00325
00326 TrackingParticleRef tpr(TPCollectionHeff, i);
00327 TrackingParticle* tp=const_cast<TrackingParticle*>(tpr.get());
00328 ParticleBase::Vector momentumTP;
00329 ParticleBase::Point vertexTP;
00330 double dxySim = 0;
00331 double dzSim = 0;
00332
00333
00334 if(parametersDefiner=="LhcParametersDefinerForTP")
00335 {
00336 if(! tpSelector(*tp)) continue;
00337 momentumTP = tp->momentum();
00338 vertexTP = tp->vertex();
00339
00340 ParticleBase::Vector momentum = parametersDefinerTP->momentum(event,setup,*tp);
00341 ParticleBase::Point vertex = parametersDefinerTP->vertex(event,setup,*tp);
00342 dxySim = (-vertex.x()*sin(momentum.phi())+vertex.y()*cos(momentum.phi()));
00343 dzSim = vertex.z() - (vertex.x()*momentum.x()+vertex.y()*momentum.y())/sqrt(momentum.perp2()) * momentum.z()/sqrt(momentum.perp2());
00344 }
00345
00346 if(parametersDefiner=="CosmicParametersDefinerForTP")
00347 {
00348 if(! cosmictpSelector(*tp,&bs,event,setup)) continue;
00349 momentumTP = parametersDefinerTP->momentum(event,setup,*tp);
00350 vertexTP = parametersDefinerTP->vertex(event,setup,*tp);
00351 dxySim = (-vertexTP.x()*sin(momentumTP.phi())+vertexTP.y()*cos(momentumTP.phi()));
00352 dzSim = vertexTP.z() - (vertexTP.x()*momentumTP.x()+vertexTP.y()*momentumTP.y())/sqrt(momentumTP.perp2()) * momentumTP.z()/sqrt(momentumTP.perp2());
00353 }
00354 edm::LogVerbatim("MuonTrackValidator") <<"--------------------Selected TrackingParticle #"<<tpr.key();
00355 st++;
00356
00357 h_ptSIM[w]->Fill(sqrt(momentumTP.perp2()));
00358 h_etaSIM[w]->Fill(momentumTP.eta());
00359 h_vertposSIM[w]->Fill(sqrt(vertexTP.perp2()));
00360
00361 std::vector<std::pair<RefToBase<Track>, double> > rt;
00362 if(simRecColl.find(tpr) != simRecColl.end()){
00363 rt = (std::vector<std::pair<RefToBase<Track>, double> >) simRecColl[tpr];
00364 if (rt.size()!=0) {
00365 RefToBase<Track> assoc_recoTrack = rt.begin()->first;
00366 edm::LogVerbatim("MuonTrackValidator")<<"-----------------------------associated Track #"<<assoc_recoTrack.key();
00367 TP_is_matched = true;
00368 ats++;
00369 quality = rt.begin()->second;
00370 edm::LogVerbatim("MuonTrackValidator") << "TrackingParticle #" <<tpr.key()
00371 << " with pt=" << sqrt(momentumTP.perp2())
00372 << " associated with quality:" << quality <<"\n";
00373 if (MABH) {
00374 if (quality > 0.75) {
00375 Quality075 = true;
00376 Quality05 = true;
00377 }
00378 else if (quality > 0.5) {
00379 Quality05 = true;
00380 }
00381 }
00382 }
00383 }else{
00384 edm::LogVerbatim("MuonTrackValidator")
00385 << "TrackingParticle #" << tpr.key()
00386 << " with pt,eta,phi: "
00387 << sqrt(momentumTP.perp2()) << " , "
00388 << momentumTP.eta() << " , "
00389 << momentumTP.phi() << " , "
00390 << " NOT associated to any reco::Track" << "\n";
00391 }
00392
00393 for (unsigned int f=0; f<etaintervals[w].size()-1; f++){
00394 if (getEta(momentumTP.eta())>etaintervals[w][f]&&
00395 getEta(momentumTP.eta())<etaintervals[w][f+1]) {
00396 totSIMeta[w][f]++;
00397 if (TP_is_matched) {
00398 totASSeta[w][f]++;
00399
00400 if (MABH) {
00401 if (Quality075) {
00402 totASSeta_Quality075[w][f]++;
00403 totASSeta_Quality05[w][f]++;
00404 }
00405 else if (Quality05) {
00406 totASSeta_Quality05[w][f]++;
00407 }
00408 }
00409 }
00410 }
00411 }
00412
00413 for (unsigned int f=0; f<phiintervals[w].size()-1; f++){
00414 if (momentumTP.phi() > phiintervals[w][f]&&
00415 momentumTP.phi() <phiintervals[w][f+1]) {
00416 totSIM_phi[w][f]++;
00417 if (TP_is_matched) {
00418 totASS_phi[w][f]++;
00419
00420 if (MABH) {
00421 if (Quality075) {
00422 totASS_phi_Quality075[w][f]++;
00423 totASS_phi_Quality05[w][f]++;
00424 }
00425 else if (Quality05) {
00426 totASS_phi_Quality05[w][f]++;
00427 }
00428 }
00429 }
00430 }
00431 }
00432
00433
00434 for (unsigned int f=0; f<pTintervals[w].size()-1; f++){
00435 if (getPt(sqrt(momentumTP.perp2()))>pTintervals[w][f]&&
00436 getPt(sqrt(momentumTP.perp2()))<pTintervals[w][f+1]) {
00437 totSIMpT[w][f]++;
00438 if (TP_is_matched) {
00439 totASSpT[w][f]++;
00440
00441 if (MABH) {
00442 if (Quality075) {
00443 totASSpT_Quality075[w][f]++;
00444 totASSpT_Quality05[w][f]++;
00445 }
00446 else if (Quality05) {
00447 totASSpT_Quality05[w][f]++;
00448 }
00449 }
00450 }
00451 }
00452 }
00453
00454 for (unsigned int f=0; f<dxyintervals[w].size()-1; f++){
00455 if (dxySim>dxyintervals[w][f]&&
00456 dxySim<dxyintervals[w][f+1]) {
00457 totSIM_dxy[w][f]++;
00458 if (TP_is_matched) {
00459 totASS_dxy[w][f]++;
00460 }
00461 }
00462 }
00463
00464 for (unsigned int f=0; f<dzintervals[w].size()-1; f++){
00465 if (dzSim>dzintervals[w][f]&&
00466 dzSim<dzintervals[w][f+1]) {
00467 totSIM_dz[w][f]++;
00468 if (TP_is_matched) {
00469 totASS_dz[w][f]++;
00470 }
00471 }
00472 }
00473
00474 for (unsigned int f=0; f<vertposintervals[w].size()-1; f++){
00475 if (sqrt(vertexTP.perp2())>vertposintervals[w][f]&&
00476 sqrt(vertexTP.perp2())<vertposintervals[w][f+1]) {
00477 totSIM_vertpos[w][f]++;
00478 if (TP_is_matched) {
00479 totASS_vertpos[w][f]++;
00480 }
00481 }
00482 }
00483
00484 for (unsigned int f=0; f<zposintervals[w].size()-1; f++){
00485 if (vertexTP.z()>zposintervals[w][f]&&
00486 vertexTP.z()<zposintervals[w][f+1]) {
00487 totSIM_zpos[w][f]++;
00488 if (TP_is_matched) {
00489 totASS_zpos[w][f]++;
00490 }
00491 }
00492 }
00493
00494 std::vector<PSimHit> simhits;
00495
00496 if (usetracker && usemuon) {
00497 simhits=tp->trackPSimHit();
00498 }
00499 else if (!usetracker && usemuon) {
00500 simhits=tp->trackPSimHit(DetId::Muon);
00501 }
00502 else if (usetracker && !usemuon) {
00503 simhits=tp->trackPSimHit(DetId::Tracker);
00504 }
00505
00506 int tmp = std::min((int)(simhits.end()-simhits.begin()),int(maxHit-1));
00507 edm::LogVerbatim("MuonTrackValidator") << "\t N simhits = "<< (int)(simhits.end()-simhits.begin())<<"\n";
00508
00509 totSIM_hit[w][tmp]++;
00510 if (TP_is_matched) totASS_hit[w][tmp]++;
00511
00512 if (TP_is_matched)
00513 {
00514 RefToBase<Track> assoctrack = rt.begin()->first;
00515 nrecHit_vs_nsimHit_sim2rec[w]->Fill( assoctrack->numberOfValidHits(),(int)(simhits.end()-simhits.begin() ));
00516 }
00517 }
00518 if (st!=0) h_tracksSIM[w]->Fill(st);
00519
00520
00521
00522
00523
00524 edm::LogVerbatim("MuonTrackValidator") << "\n# of reco::Tracks with "
00525 << label[www].process()<<":"
00526 << label[www].label()<<":"
00527 << label[www].instance()
00528 << ": " << trackCollectionSize << "\n";
00529 int at=0;
00530 int rT=0;
00531 for(View<Track>::size_type i=0; i<trackCollectionSize; ++i){
00532 bool Track_is_matched = false;
00533 RefToBase<Track> track(trackCollection, i);
00534 rT++;
00535
00536 std::vector<std::pair<TrackingParticleRef, double> > tp;
00537 TrackingParticleRef tpr;
00538
00539
00540 if (BiDirectional_RecoToSim_association) {
00541 edm::LogVerbatim("MuonTrackValidator")<<"----------------------------------------Track #"<< track.key();
00542
00543 if(recSimColl.find(track) != recSimColl.end()) {
00544 tp = recSimColl[track];
00545 if (tp.size() != 0) {
00546 tpr = tp.begin()->first;
00547
00548 if(simRecColl.find(tpr) != simRecColl.end()) {
00549 std::vector<std::pair<RefToBase<Track>, double> > track_checkback = simRecColl[tpr];
00550 RefToBase<Track> assoc_track_checkback;
00551 assoc_track_checkback = track_checkback.begin()->first;
00552
00553 if ( assoc_track_checkback.key() == track.key() ) {
00554 edm::LogVerbatim("MuonTrackValidator")<<"------------------associated TrackingParticle #"<<tpr.key();
00555 Track_is_matched = true;
00556 at++;
00557 double Purity = tp.begin()->second;
00558 double Quality = track_checkback.begin()->second;
00559 edm::LogVerbatim("MuonTrackValidator") << "reco::Track #" << track.key() << " with pt=" << track->pt()
00560 << " associated with quality:" << Purity <<"\n";
00561 if (MABH) h_PurityVsQuality[w]->Fill(Quality,Purity);
00562 }
00563 }
00564 }
00565 }
00566
00567 if (!Track_is_matched) edm::LogVerbatim("MuonTrackValidator")
00568 << "reco::Track #" << track.key() << " with pt=" << track->pt() << " NOT associated to any TrackingParticle" << "\n";
00569 }
00570
00571 else {
00572 if(recSimColl.find(track) != recSimColl.end()){
00573 tp = recSimColl[track];
00574 if (tp.size()!=0) {
00575 Track_is_matched = true;
00576 tpr = tp.begin()->first;
00577 at++;
00578 edm::LogVerbatim("MuonTrackValidator") << "reco::Track #" << track.key() << " with pt=" << track->pt()
00579 << " associated with quality:" << tp.begin()->second <<"\n";
00580 }
00581 } else {
00582 edm::LogVerbatim("MuonTrackValidator") << "reco::Track #" << track.key() << " with pt=" << track->pt()
00583 << " NOT associated to any TrackingParticle" << "\n";
00584 }
00585 }
00586
00587
00588 for (unsigned int f=0; f<etaintervals[w].size()-1; f++){
00589 if (getEta(track->momentum().eta())>etaintervals[w][f]&&
00590 getEta(track->momentum().eta())<etaintervals[w][f+1]) {
00591 totRECeta[w][f]++;
00592 if (Track_is_matched) {
00593 totASS2eta[w][f]++;
00594 }
00595 }
00596 }
00597
00598 for (unsigned int f=0; f<phiintervals[w].size()-1; f++){
00599 if (track->momentum().phi()>phiintervals[w][f]&&
00600 track->momentum().phi()<phiintervals[w][f+1]) {
00601 totREC_phi[w][f]++;
00602 if (Track_is_matched) {
00603 totASS2_phi[w][f]++;
00604 }
00605 }
00606 }
00607
00608
00609 for (unsigned int f=0; f<pTintervals[w].size()-1; f++){
00610 if (getPt(sqrt(track->momentum().perp2()))>pTintervals[w][f]&&
00611 getPt(sqrt(track->momentum().perp2()))<pTintervals[w][f+1]) {
00612 totRECpT[w][f]++;
00613 if (Track_is_matched) {
00614 totASS2pT[w][f]++;
00615 }
00616 }
00617 }
00618
00619 for (unsigned int f=0; f<dxyintervals[w].size()-1; f++){
00620 if (track->dxy(bs.position())>dxyintervals[w][f]&&
00621 track->dxy(bs.position())<dxyintervals[w][f+1]) {
00622 totREC_dxy[w][f]++;
00623 if (Track_is_matched) {
00624 totASS2_dxy[w][f]++;
00625 }
00626 }
00627 }
00628
00629 for (unsigned int f=0; f<dzintervals[w].size()-1; f++){
00630 if (track->dz(bs.position())>dzintervals[w][f]&&
00631 track->dz(bs.position())<dzintervals[w][f+1]) {
00632 totREC_dz[w][f]++;
00633 if (Track_is_matched) {
00634 totASS2_dz[w][f]++;
00635 }
00636 }
00637 }
00638
00639 int tmp = std::min((int)track->found(),int(maxHit-1));
00640 totREC_hit[w][tmp]++;
00641 if (Track_is_matched) totASS2_hit[w][tmp]++;
00642
00643 edm::LogVerbatim("MuonTrackValidator") << "\t N valid rechits = "<< (int)track->found() <<"\n";
00644
00645
00646 try{
00647 if (!Track_is_matched) continue;
00648
00649 if (associators[ww]=="TrackAssociatorByChi2"){
00650
00651 double assocChi2 = -tp.begin()->second;
00652 h_assochi2[www]->Fill(assocChi2);
00653 h_assochi2_prob[www]->Fill(TMath::Prob((assocChi2)*5,5));
00654 }
00655 else if (associators[ww]=="TrackAssociatorByHits"){
00656 double fraction = tp.begin()->second;
00657 h_assocFraction[www]->Fill(fraction);
00658 h_assocSharedHit[www]->Fill(fraction*track->numberOfValidHits());
00659 }
00660
00661
00662 h_nchi2[w]->Fill(track->normalizedChi2());
00663 h_nchi2_prob[w]->Fill(TMath::Prob(track->chi2(),(int)track->ndof()));
00664 h_hits[w]->Fill(track->numberOfValidHits());
00665 h_losthits[w]->Fill(track->numberOfLostHits());
00666 chi2_vs_nhits[w]->Fill(track->numberOfValidHits(),track->normalizedChi2());
00667 h_charge[w]->Fill( track->charge() );
00668
00669
00670 ParticleBase::Vector momentumTP = parametersDefinerTP->momentum(event,setup,*(tpr.get()));
00671 ParticleBase::Point vertexTP = parametersDefinerTP->vertex(event,setup,*(tpr.get()));
00672 double ptSim = sqrt(momentumTP.perp2());
00673 double qoverpSim = tpr->charge()/sqrt(momentumTP.x()*momentumTP.x()+momentumTP.y()*momentumTP.y()+momentumTP.z()*momentumTP.z());
00674 double thetaSim = momentumTP.theta();
00675 double lambdaSim = M_PI/2-momentumTP.theta();
00676 double phiSim = momentumTP.phi();
00677 double dxySim = (-vertexTP.x()*sin(momentumTP.phi())+vertexTP.y()*cos(momentumTP.phi()));
00678 double dzSim = vertexTP.z() - (vertexTP.x()*momentumTP.x()+vertexTP.y()*momentumTP.y())/sqrt(momentumTP.perp2()) * momentumTP.z()/sqrt(momentumTP.perp2());
00679
00680
00681 track->parameters();
00682
00683 double qoverpRec(0);
00684 double qoverpErrorRec(0);
00685 double ptRec(0);
00686 double ptErrorRec(0);
00687 double lambdaRec(0);
00688 double lambdaErrorRec(0);
00689 double phiRec(0);
00690 double phiErrorRec(0);
00691
00692
00693
00694 const GsfTrack* gsfTrack(0);
00695 if(useGsf){
00696 gsfTrack = dynamic_cast<const GsfTrack*>(&(*track));
00697 if (gsfTrack==0) edm::LogInfo("MuonTrackValidator") << "Trying to access mode for a non-GsfTrack";
00698 }
00699
00700 if (gsfTrack) {
00701
00702 getRecoMomentum(*gsfTrack, ptRec, ptErrorRec, qoverpRec, qoverpErrorRec,
00703 lambdaRec,lambdaErrorRec, phiRec, phiErrorRec);
00704 }
00705
00706 else {
00707
00708 getRecoMomentum(*track, ptRec, ptErrorRec, qoverpRec, qoverpErrorRec,
00709 lambdaRec,lambdaErrorRec, phiRec, phiErrorRec);
00710 }
00711
00712 double thetaRec = track->theta();
00713 double ptError = ptErrorRec;
00714 double ptres = ptRec - ptSim;
00715 double etares = track->eta()-momentumTP.Eta();
00716 double dxyRec = track->dxy(bs.position());
00717 double dzRec = track->dz(bs.position());
00718
00719 double qoverpPull=(qoverpRec-qoverpSim)/qoverpErrorRec;
00720 double thetaPull=(lambdaRec-lambdaSim)/lambdaErrorRec;
00721 double phiDiff = phiRec - phiSim;
00722 if (abs(phiDiff) > M_PI) {
00723 if (phiDiff >0.) phiDiff = phiDiff - 2.*M_PI;
00724 else phiDiff = phiDiff + 2.*M_PI;
00725 }
00726 double phiPull=phiDiff/phiErrorRec;
00727 double dxyPull=(dxyRec-dxySim)/track->dxyError();
00728 double dzPull=(dzRec-dzSim)/track->dzError();
00729
00730 double contrib_Qoverp = ((qoverpRec-qoverpSim)/qoverpErrorRec)*
00731 ((qoverpRec-qoverpSim)/qoverpErrorRec)/5;
00732 double contrib_dxy = ((dxyRec-dxySim)/track->dxyError())*((dxyRec-dxySim)/track->dxyError())/5;
00733 double contrib_dz = ((dzRec-dzSim)/track->dzError())*((dzRec-dzSim)/track->dzError())/5;
00734 double contrib_theta = ((lambdaRec-lambdaSim)/lambdaErrorRec)*
00735 ((lambdaRec-lambdaSim)/lambdaErrorRec)/5;
00736 double contrib_phi = (phiDiff/phiErrorRec)*(phiDiff/phiErrorRec)/5;
00737
00738 LogTrace("MuonTrackValidator") << "assocChi2=" << tp.begin()->second << "\n"
00739 << "" << "\n"
00740 << "ptREC=" << ptRec << "\n"
00741 << "etaREC=" << track->eta() << "\n"
00742 << "qoverpREC=" << qoverpRec << "\n"
00743 << "dxyREC=" << dxyRec << "\n"
00744 << "dzREC=" << dzRec << "\n"
00745 << "thetaREC=" << track->theta() << "\n"
00746 << "phiREC=" << phiRec << "\n"
00747 << "" << "\n"
00748 << "qoverpError()=" << qoverpErrorRec << "\n"
00749 << "dxyError()=" << track->dxyError() << "\n"
00750 << "dzError()=" << track->dzError() << "\n"
00751 << "thetaError()=" << lambdaErrorRec << "\n"
00752 << "phiError()=" << phiErrorRec << "\n"
00753 << "" << "\n"
00754 << "ptSIM=" << ptSim << "\n"
00755 << "etaSIM=" << momentumTP.Eta() << "\n"
00756 << "qoverpSIM=" << qoverpSim << "\n"
00757 << "dxySIM=" << dxySim << "\n"
00758 << "dzSIM=" << dzSim << "\n"
00759 << "thetaSIM=" << M_PI/2-lambdaSim << "\n"
00760 << "phiSIM=" << phiSim << "\n"
00761 << "" << "\n"
00762 << "contrib_Qoverp=" << contrib_Qoverp << "\n"
00763 << "contrib_dxy=" << contrib_dxy << "\n"
00764 << "contrib_dz=" << contrib_dz << "\n"
00765 << "contrib_theta=" << contrib_theta << "\n"
00766 << "contrib_phi=" << contrib_phi << "\n"
00767 << "" << "\n"
00768 <<"chi2PULL="<<contrib_Qoverp+contrib_dxy+contrib_dz+contrib_theta+contrib_phi<<"\n";
00769
00770 h_pullQoverp[w]->Fill(qoverpPull);
00771 h_pullTheta[w]->Fill(thetaPull);
00772 h_pullPhi[w]->Fill(phiPull);
00773 h_pullDxy[w]->Fill(dxyPull);
00774 h_pullDz[w]->Fill(dzPull);
00775
00776
00777 h_pt[w]->Fill(ptres/ptError);
00778 h_eta[w]->Fill(etares);
00779 etares_vs_eta[w]->Fill(getEta(track->eta()),etares);
00780
00781
00782
00783 chi2_vs_eta[w]->Fill(getEta(track->eta()),track->normalizedChi2());
00784 nhits_vs_eta[w]->Fill(getEta(track->eta()),track->numberOfValidHits());
00785 nDThits_vs_eta[w]->Fill(getEta(track->eta()),track->hitPattern().numberOfValidMuonDTHits());
00786 nCSChits_vs_eta[w]->Fill(getEta(track->eta()),track->hitPattern().numberOfValidMuonCSCHits());
00787 nRPChits_vs_eta[w]->Fill(getEta(track->eta()),track->hitPattern().numberOfValidMuonRPCHits());
00788
00789 nlosthits_vs_eta[w]->Fill(getEta(track->eta()),track->numberOfLostHits());
00790
00791
00792 dxyres_vs_eta[w]->Fill(getEta(track->eta()),dxyRec-dxySim);
00793 ptres_vs_eta[w]->Fill(getEta(track->eta()),(ptRec-ptSim)/ptRec);
00794 dzres_vs_eta[w]->Fill(getEta(track->eta()),dzRec-dzSim);
00795 phires_vs_eta[w]->Fill(getEta(track->eta()),phiDiff);
00796 cotThetares_vs_eta[w]->Fill(getEta(track->eta()), cos(thetaRec)/sin(thetaRec) - cos(thetaSim)/sin(thetaSim));
00797
00798
00799 dxyres_vs_pt[w]->Fill(getPt(ptRec),dxyRec-dxySim);
00800 ptres_vs_pt[w]->Fill(getPt(ptRec),(ptRec-ptSim)/ptRec);
00801 dzres_vs_pt[w]->Fill(getPt(ptRec),dzRec-dzSim);
00802 phires_vs_pt[w]->Fill(getPt(ptRec),phiDiff);
00803 cotThetares_vs_pt[w]->Fill(getPt(ptRec), cos(thetaRec)/sin(thetaRec) - cos(thetaSim)/sin(thetaSim));
00804
00805
00806 dxypull_vs_eta[w]->Fill(getEta(track->eta()),dxyPull);
00807 ptpull_vs_eta[w]->Fill(getEta(track->eta()),ptres/ptError);
00808 dzpull_vs_eta[w]->Fill(getEta(track->eta()),dzPull);
00809 phipull_vs_eta[w]->Fill(getEta(track->eta()),phiPull);
00810 thetapull_vs_eta[w]->Fill(getEta(track->eta()),thetaPull);
00811
00812
00813 nhits_vs_phi[w]->Fill(phiRec,track->numberOfValidHits());
00814 chi2_vs_phi[w]->Fill(phiRec,track->normalizedChi2());
00815 ptmean_vs_eta_phi[w]->Fill(phiRec,getEta(track->eta()),ptRec);
00816 phimean_vs_eta_phi[w]->Fill(phiRec,getEta(track->eta()),phiRec);
00817 ptres_vs_phi[w]->Fill(phiRec,(ptRec-ptSim)/ptRec);
00818 phires_vs_phi[w]->Fill(phiRec,phiDiff);
00819 ptpull_vs_phi[w]->Fill(phiRec,ptres/ptError);
00820 phipull_vs_phi[w]->Fill(phiRec,phiPull);
00821 thetapull_vs_phi[w]->Fill(phiRec,thetaPull);
00822
00823 std::vector<PSimHit> simhits;
00824
00825 if (usetracker && usemuon) {
00826 simhits=tpr.get()->trackPSimHit();
00827 }
00828 else if (!usetracker && usemuon) {
00829 simhits=tpr.get()->trackPSimHit(DetId::Muon);
00830 }
00831 else if (usetracker && !usemuon) {
00832 simhits=tpr.get()->trackPSimHit(DetId::Tracker);
00833 }
00834
00835 nrecHit_vs_nsimHit_rec2sim[w]->Fill(track->numberOfValidHits(), (int)(simhits.end()-simhits.begin() ));
00836
00837 }
00838 catch (cms::Exception e){
00839 LogTrace("MuonTrackValidator") << "exception found: " << e.what() << "\n";
00840 }
00841 }
00842 if (at!=0) h_tracks[w]->Fill(at);
00843 h_fakes[w]->Fill(rT-at);
00844 edm::LogVerbatim("MuonTrackValidator") << "Total Simulated: " << st << "\n"
00845 << "Total Associated (simToReco): " << ats << "\n"
00846 << "Total Reconstructed: " << rT << "\n"
00847 << "Total Associated (recoToSim): " << at << "\n"
00848 << "Total Fakes: " << rT-at << "\n";
00849 nrec_vs_nsim[w]->Fill(rT,st);
00850 w++;
00851 }
00852 }
00853 }
00854
00855 void MuonTrackValidator::endRun(Run const&, EventSetup const&) {
00856
00857 int w=0;
00858 for (unsigned int ww=0;ww<associators.size();ww++){
00859 for (unsigned int www=0;www<label.size();www++){
00860
00861
00862 doProfileX(chi2_vs_eta[w],h_chi2meanh[w]);
00863 doProfileX(nhits_vs_eta[w],h_hits_eta[w]);
00864 doProfileX(nDThits_vs_eta[w],h_DThits_eta[w]);
00865 doProfileX(nCSChits_vs_eta[w],h_CSChits_eta[w]);
00866 doProfileX(nRPChits_vs_eta[w],h_RPChits_eta[w]);
00867
00868 doProfileX(nlosthits_vs_eta[w],h_losthits_eta[w]);
00869
00870 doProfileX(chi2_vs_nhits[w],h_chi2meanhitsh[w]);
00871 doProfileX(chi2_vs_phi[w],h_chi2mean_vs_phi[w]);
00872 doProfileX(nhits_vs_phi[w],h_hits_phi[w]);
00873
00874 fillPlotFromVector(h_recoeta[w],totRECeta[w]);
00875 fillPlotFromVector(h_simuleta[w],totSIMeta[w]);
00876 fillPlotFromVector(h_assoceta[w],totASSeta[w]);
00877 fillPlotFromVector(h_assoc2eta[w],totASS2eta[w]);
00878
00879 fillPlotFromVector(h_recopT[w],totRECpT[w]);
00880 fillPlotFromVector(h_simulpT[w],totSIMpT[w]);
00881 fillPlotFromVector(h_assocpT[w],totASSpT[w]);
00882 fillPlotFromVector(h_assoc2pT[w],totASS2pT[w]);
00883
00884 fillPlotFromVector(h_recohit[w],totREC_hit[w]);
00885 fillPlotFromVector(h_simulhit[w],totSIM_hit[w]);
00886 fillPlotFromVector(h_assochit[w],totASS_hit[w]);
00887 fillPlotFromVector(h_assoc2hit[w],totASS2_hit[w]);
00888
00889 fillPlotFromVector(h_recophi[w],totREC_phi[w]);
00890 fillPlotFromVector(h_simulphi[w],totSIM_phi[w]);
00891 fillPlotFromVector(h_assocphi[w],totASS_phi[w]);
00892 fillPlotFromVector(h_assoc2phi[w],totASS2_phi[w]);
00893
00894 fillPlotFromVector(h_recodxy[w],totREC_dxy[w]);
00895 fillPlotFromVector(h_simuldxy[w],totSIM_dxy[w]);
00896 fillPlotFromVector(h_assocdxy[w],totASS_dxy[w]);
00897 fillPlotFromVector(h_assoc2dxy[w],totASS2_dxy[w]);
00898
00899 fillPlotFromVector(h_recodz[w],totREC_dz[w]);
00900 fillPlotFromVector(h_simuldz[w],totSIM_dz[w]);
00901 fillPlotFromVector(h_assocdz[w],totASS_dz[w]);
00902 fillPlotFromVector(h_assoc2dz[w],totASS2_dz[w]);
00903
00904 fillPlotFromVector(h_simulvertpos[w],totSIM_vertpos[w]);
00905 fillPlotFromVector(h_assocvertpos[w],totASS_vertpos[w]);
00906
00907 fillPlotFromVector(h_simulzpos[w],totSIM_zpos[w]);
00908 fillPlotFromVector(h_assoczpos[w],totASS_zpos[w]);
00909
00910 if (MABH) {
00911 fillPlotFromVector(h_assoceta_Quality05[w] ,totASSeta_Quality05[w]);
00912 fillPlotFromVector(h_assoceta_Quality075[w],totASSeta_Quality075[w]);
00913 fillPlotFromVector(h_assocpT_Quality05[w] ,totASSpT_Quality05[w]);
00914 fillPlotFromVector(h_assocpT_Quality075[w],totASSpT_Quality075[w]);
00915 fillPlotFromVector(h_assocphi_Quality05[w] ,totASS_phi_Quality05[w]);
00916 fillPlotFromVector(h_assocphi_Quality075[w],totASS_phi_Quality075[w]);
00917 }
00918
00919 w++;
00920 }
00921 }
00922
00923 if ( out.size() != 0 && dbe_ ) dbe_->save(out);
00924 }
00925
00926
00927 void
00928 MuonTrackValidator::getRecoMomentum (const reco::Track& track, double& pt, double& ptError,
00929 double& qoverp, double& qoverpError, double& lambda,double& lambdaError, double& phi, double& phiError ) const {
00930 pt = track.pt();
00931 ptError = track.ptError();
00932 qoverp = track.qoverp();
00933 qoverpError = track.qoverpError();
00934 lambda = track.lambda();
00935 lambdaError = track.lambdaError();
00936 phi = track.phi();
00937 phiError = track.phiError();
00938
00939 }
00940
00941 void
00942 MuonTrackValidator::getRecoMomentum (const reco::GsfTrack& gsfTrack, double& pt, double& ptError,
00943 double& qoverp, double& qoverpError, double& lambda,double& lambdaError, double& phi, double& phiError ) const {
00944
00945 pt = gsfTrack.ptMode();
00946 ptError = gsfTrack.ptModeError();
00947 qoverp = gsfTrack.qoverpMode();
00948 qoverpError = gsfTrack.qoverpModeError();
00949 lambda = gsfTrack.lambdaMode();
00950 lambdaError = gsfTrack.lambdaModeError();
00951 phi = gsfTrack.phiMode();
00952 phiError = gsfTrack.phiModeError();
00953
00954 }
00955