Go to the documentation of this file.00001 #ifndef TESTSMOOTHHITS_H
00002 #define TESTSMOOTHHITS_H
00003
00004
00005
00006
00007
00008
00009
00017
00018
00019
00020
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