File indexing completed on 2023-03-17 11:20:37
0001 #ifndef MuonIsolation_CaloExtractorByAssociator_H
0002 #define MuonIsolation_CaloExtractorByAssociator_H
0003
0004
0005
0006
0007
0008
0009
0010
0011
0012
0013
0014 #include <string>
0015
0016 #include "PhysicsTools/IsolationAlgos/interface/IsoDepositExtractor.h"
0017
0018 #include "FWCore/Framework/interface/ConsumesCollector.h"
0019
0020 #include "DataFormats/RecoCandidate/interface/IsoDeposit.h"
0021 #include "DataFormats/TrackReco/interface/Track.h"
0022 #include "DataFormats/TrackReco/interface/TrackFwd.h"
0023
0024 #include "DataFormats/CaloTowers/interface/CaloTowerCollection.h"
0025
0026 #include "DataFormats/GeometryVector/interface/GlobalPoint.h"
0027
0028 #include "Geometry/CaloGeometry/interface/CaloGeometry.h"
0029 #include "Geometry/Records/interface/CaloGeometryRecord.h"
0030 #include "MagneticField/Engine/interface/MagneticField.h"
0031 #include "MagneticField/Records/interface/IdealMagneticFieldRecord.h"
0032
0033 class TrackAssociatorParameters;
0034 class TrackDetectorAssociator;
0035 class MuonServiceProxy;
0036
0037 namespace muonisolation {
0038
0039 class CaloExtractorByAssociator : public reco::isodeposit::IsoDepositExtractor {
0040 public:
0041
0042 CaloExtractorByAssociator(){};
0043 CaloExtractorByAssociator(const edm::ParameterSet& par, edm::ConsumesCollector&& iC);
0044
0045
0046 ~CaloExtractorByAssociator() override;
0047
0048
0049 void fillVetos(const edm::Event& ev, const edm::EventSetup& evSetup, const reco::TrackCollection& tracks) override;
0050
0051 reco::IsoDeposit deposit(const edm::Event& ev,
0052 const edm::EventSetup& evSetup,
0053 const reco::Track& track) const override;
0054
0055 std::vector<reco::IsoDeposit> deposits(const edm::Event& ev,
0056 const edm::EventSetup& evSetup,
0057 const reco::Track& track) const override;
0058
0059 private:
0060
0061 bool theUseRecHitsFlag;
0062
0063
0064 std::string theDepositLabel;
0065
0066
0067 std::vector<std::string> theDepositInstanceLabels;
0068
0069
0070 std::string thePropagatorName;
0071
0072
0073
0074 double theThreshold_E;
0075 double theThreshold_H;
0076 double theThreshold_HO;
0077
0078
0079 double theDR_Veto_E;
0080 double theDR_Veto_H;
0081 double theDR_Veto_HO;
0082
0083
0084 bool theCenterConeOnCalIntersection;
0085
0086 double theDR_Max;
0087
0088
0089
0090 double theNoise_EB;
0091 double theNoise_EE;
0092 double theNoise_HB;
0093 double theNoise_HE;
0094 double theNoise_HO;
0095 double theNoiseTow_EB;
0096 double theNoiseTow_EE;
0097
0098
0099 std::vector<DetId> theVetoCollection;
0100
0101
0102 MuonServiceProxy* theService;
0103
0104
0105 TrackAssociatorParameters* theAssociatorParameters;
0106 TrackDetectorAssociator* theAssociator;
0107
0108 edm::ESGetToken<MagneticField, IdealMagneticFieldRecord> bFieldToken_;
0109 edm::ESGetToken<CaloGeometry, CaloGeometryRecord> caloGeomToken_;
0110
0111
0112 bool thePrintTimeReport;
0113
0114
0115 double noiseEcal(const CaloTower& tower) const;
0116 double noiseHcal(const CaloTower& tower) const;
0117 double noiseHOcal(const CaloTower& tower) const;
0118 double noiseRecHit(const DetId& detId) const;
0119 };
0120
0121 }
0122
0123 #endif