CMS 3D CMS Logo

/data/refman/pasoursint/CMSSW_5_3_3/src/RecoTracker/DebugTools/interface/TestSmoothHits.h

Go to the documentation of this file.
00001 #ifndef TESTSMOOTHHITS_H
00002 #define TESTSMOOTHHITS_H
00003 
00004 
00005 // -*- C++ -*-
00006 //
00007 // Package:    TestSmoothHits
00008 // Class:      TestSmoothHits
00009 // 
00017 //
00018 // Original Author:  Giuseppe Cerati
00019 //         Created:  Tue Feb 13 17:29:10 CET 2007
00020 // $Id: TestSmoothHits.h,v 1.4 2010/02/11 00:14:36 wmtan Exp $
00021 //
00022 //
00023 #include <memory>
00024 #include <vector>
00025 #include <string>
00026 #include "FWCore/Framework/interface/Frameworkfwd.h"
00027 #include "FWCore/Framework/interface/EDAnalyzer.h"
00028 #include "FWCore/Framework/interface/Event.h"
00029 #include "FWCore/ParameterSet/interface/ParameterSet.h"
00030 #include "FWCore/Utilities/interface/InputTag.h"
00031 #include "SimTracker/TrackerHitAssociation/interface/TrackerHitAssociator.h"
00032 #include "MagneticField/Engine/interface/MagneticField.h"
00033 #include "Geometry/TrackerGeometryBuilder/interface/TrackerGeometry.h"
00034 #include "Geometry/Records/interface/TrackerDigiGeometryRecord.h"
00035 #include "MagneticField/Records/interface/IdealMagneticFieldRecord.h" 
00036 #include "TrackingTools/Records/interface/TrackingComponentsRecord.h" 
00037 #include "TrackingTools/Records/interface/TransientRecHitRecord.h" 
00038 #include "Geometry/CommonDetUnit/interface/TrackingGeometry.h"
00039 #include "DataFormats/TrackCandidate/interface/TrackCandidateCollection.h"
00040 #include "TrackingTools/GeomPropagators/interface/Propagator.h"
00041 #include "TrackingTools/TransientTrackingRecHit/interface/TransientTrackingRecHitBuilder.h"
00042 #include "RecoTracker/TransientTrackingRecHit/interface/TkTransientTrackingRecHitBuilder.h"
00043 #include "TrackingTools/PatternTools/interface/MeasurementExtractor.h"
00044 #include "TrackingTools/TrackFitters/interface/KFTrajectoryFitter.h"
00045 #include "TrackingTools/TrackFitters/interface/KFTrajectorySmoother.h"
00046 #include <sstream>
00047 #include <TFile.h>
00048 #include <TH1F.h>
00049 #include <TH2F.h>
00050 
00051 class TestSmoothHits : public edm::EDAnalyzer {
00052 public:
00053   explicit TestSmoothHits(const edm::ParameterSet&);
00054   ~TestSmoothHits();
00055 
00056 private:
00057   virtual void beginRun(edm::Run & run, const edm::EventSetup&) ;
00058   virtual void analyze(const edm::Event&, const edm::EventSetup&);
00059   virtual void endJob() ;
00060 
00061   std::pair<LocalPoint,LocalVector> projectHit(const PSimHit&, const StripGeomDetUnit*, const BoundPlane&);
00062 
00063   const edm::ParameterSet conf_;
00064   TrackerHitAssociator * hitAssociator;
00065 
00066   double mineta, maxeta;
00067 
00068   std::string propagatorName;
00069   std::string builderName;
00070   std::string srcName;
00071   std::string fname;
00072   std::string sname;
00073 
00074   edm::ESHandle<TrackerGeometry> theG;
00075   edm::ESHandle<MagneticField> theMF;
00076   edm::ESHandle<Propagator> thePropagator;
00077   edm::ESHandle<TransientTrackingRecHitBuilder> theBuilder;
00078   edm::Handle<TrackCandidateCollection> theTCCollection;
00079   edm::ESHandle<TrajectoryFitter> fit;
00080   edm::ESHandle<TrajectorySmoother> smooth;
00081   
00082   TFile* file;
00083   std::stringstream title;
00084   std::map<std::string,TH1F*> hPullGP_X_ts;
00085   std::map<std::string,TH1F*> hPullGP_Y_ts;
00086   std::map<std::string,TH1F*> hPullGP_Z_ts;
00087   std::map<std::string,TH1F*> hPullGM_X_ts;
00088   std::map<std::string,TH1F*> hPullGM_Y_ts;
00089   std::map<std::string,TH1F*> hPullGM_Z_ts;
00090   std::map<std::string,TH1F*> hPullGP_X_rs;
00091   std::map<std::string,TH1F*> hPullGP_Y_rs;
00092   std::map<std::string,TH1F*> hPullGP_Z_rs;
00093   std::map<std::string,TH1F*> hPullGP_X_tr;
00094   std::map<std::string,TH1F*> hPullGP_Y_tr;
00095   std::map<std::string,TH1F*> hPullGP_Z_tr;
00096   std::map<std::string,TH1F*> hChi2Increment;
00097   TH1F * hTotChi2Increment;
00098   TH2F * hChi2_vs_Process, *hChi2_vs_clsize;
00099 
00100   std::map<std::string,TH1F*> hPullGP_X_ts_mono;
00101   std::map<std::string,TH1F*> hPullGP_Y_ts_mono;
00102   std::map<std::string,TH1F*> hPullGP_Z_ts_mono;
00103   std::map<std::string,TH1F*> hPullGM_X_ts_mono;
00104   std::map<std::string,TH1F*> hPullGM_Y_ts_mono;
00105   std::map<std::string,TH1F*> hPullGM_Z_ts_mono;
00106   std::map<std::string,TH1F*> hPullGP_X_rs_mono;
00107   std::map<std::string,TH1F*> hPullGP_Y_rs_mono;
00108   std::map<std::string,TH1F*> hPullGP_Z_rs_mono;
00109   std::map<std::string,TH1F*> hPullGP_X_tr_mono;
00110   std::map<std::string,TH1F*> hPullGP_Y_tr_mono;
00111   std::map<std::string,TH1F*> hPullGP_Z_tr_mono;
00112 
00113   std::map<std::string,TH1F*> hPullGP_X_ts_stereo;
00114   std::map<std::string,TH1F*> hPullGP_Y_ts_stereo;
00115   std::map<std::string,TH1F*> hPullGP_Z_ts_stereo;
00116   std::map<std::string,TH1F*> hPullGM_X_ts_stereo;
00117   std::map<std::string,TH1F*> hPullGM_Y_ts_stereo;
00118   std::map<std::string,TH1F*> hPullGM_Z_ts_stereo;
00119   std::map<std::string,TH1F*> hPullGP_X_rs_stereo;
00120   std::map<std::string,TH1F*> hPullGP_Y_rs_stereo;
00121   std::map<std::string,TH1F*> hPullGP_Z_rs_stereo;
00122   std::map<std::string,TH1F*> hPullGP_X_tr_stereo;
00123   std::map<std::string,TH1F*> hPullGP_Y_tr_stereo;
00124   std::map<std::string,TH1F*> hPullGP_Z_tr_stereo;
00125 };
00126 
00127 #endif