CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes
IsoTrig Class Reference

#include <IsoTrig/IsoTrig/src/IsoTrig.cc>

Inheritance diagram for IsoTrig:
edm::one::EDAnalyzer< edm::one::WatchRuns, edm::one::SharedResources > edm::one::EDAnalyzerBase edm::EDConsumerBase

Public Member Functions

 IsoTrig (const edm::ParameterSet &)
 
 ~IsoTrig () override
 
- Public Member Functions inherited from edm::one::EDAnalyzer< edm::one::WatchRuns, edm::one::SharedResources >
 EDAnalyzer ()=default
 
 EDAnalyzer (const EDAnalyzer &)=delete
 
SerialTaskQueueglobalLuminosityBlocksQueue () final
 
SerialTaskQueueglobalRunsQueue () final
 
const EDAnalyzeroperator= (const EDAnalyzer &)=delete
 
bool wantsGlobalLuminosityBlocks () const final
 
bool wantsGlobalRuns () const final
 
bool wantsInputProcessBlocks () const final
 
bool wantsProcessBlocks () const final
 
- Public Member Functions inherited from edm::one::EDAnalyzerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
 EDAnalyzerBase ()
 
ModuleDescription const & moduleDescription () const
 
bool wantsStreamLuminosityBlocks () const
 
bool wantsStreamRuns () const
 
 ~EDAnalyzerBase () override
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
void convertCurrentProcessAlias (std::string const &processName)
 Convert "@currentProcess" in InputTag process names to the actual current process name. More...
 
 EDConsumerBase ()
 
 EDConsumerBase (EDConsumerBase const &)=delete
 
 EDConsumerBase (EDConsumerBase &&)=default
 
ESResolverIndex const * esGetTokenIndices (edm::Transition iTrans) const
 
std::vector< ESResolverIndex > const & esGetTokenIndicesVector (edm::Transition iTrans) const
 
std::vector< ESRecordIndex > const & esGetTokenRecordIndicesVector (edm::Transition iTrans) const
 
ProductResolverIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductResolverIndexAndSkipBit > &) const
 
std::vector< ProductResolverIndexAndSkipBit > const & itemsToGetFrom (BranchType iType) const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesWhoseProductsAreConsumed (std::array< std::vector< ModuleDescription const *> *, NumBranchTypes > &modulesAll, std::vector< ModuleProcessName > &modulesInPreviousProcesses, ProductRegistry const &preg, std::map< std::string, ModuleDescription const *> const &labelsToDesc, std::string const &processName) const
 
EDConsumerBase const & operator= (EDConsumerBase const &)=delete
 
EDConsumerBaseoperator= (EDConsumerBase &&)=default
 
bool registeredToConsume (ProductResolverIndex, bool, BranchType) const
 
void selectInputProcessBlocks (ProductRegistry const &productRegistry, ProcessBlockHelperBase const &processBlockHelperBase)
 
ProductResolverIndexAndSkipBit uncheckedIndexFrom (EDGetToken) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
void updateLookup (eventsetup::ESRecordsToProductResolverIndices const &)
 
virtual ~EDConsumerBase () noexcept(false)
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 
- Static Public Member Functions inherited from edm::one::EDAnalyzerBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 

Private Member Functions

void analyze (const edm::Event &, const edm::EventSetup &) override
 
void beginJob () override
 
void beginRun (edm::Run const &, edm::EventSetup const &) override
 
void chgIsolation (double &etaTriggered, double &phiTriggered, edm::Handle< reco::TrackCollection > &trkCollection, const edm::Event &theEvent)
 
void clearChgIsolnTreeVectors ()
 
void clearMipCutTreeVectors ()
 
double dEta (math::XYZTLorentzVector &, math::XYZTLorentzVector &)
 
double dinvPt (math::XYZTLorentzVector &, math::XYZTLorentzVector &)
 
double dP (math::XYZTLorentzVector &, math::XYZTLorentzVector &)
 
double dPhi (math::XYZTLorentzVector &, math::XYZTLorentzVector &)
 
double dPt (math::XYZTLorentzVector &, math::XYZTLorentzVector &)
 
double dR (math::XYZTLorentzVector &, math::XYZTLorentzVector &)
 
void endJob () override
 
void endRun (edm::Run const &, edm::EventSetup const &) override
 
std::pair< double, double > etaPhiTrigger ()
 
void fillCuts (int, double, double, double, math::XYZTLorentzVector &, int, bool)
 
void fillDifferences (int, math::XYZTLorentzVector &, math::XYZTLorentzVector &, bool)
 
void fillEnergy (int, int, double, double, math::XYZTLorentzVector &)
 
void fillHist (int, math::XYZTLorentzVector &)
 
double getDistInCM (double eta1, double phi1, double eta2, double phi2)
 
std::pair< double, double > GetEtaPhiAtEcal (double etaIP, double phiIP, double pT, int charge, double vtxZ)
 
void getGoodTracks (const edm::Event &, edm::Handle< reco::TrackCollection > &)
 
void pushChgIsolnTreeVecs (math::XYZTLorentzVector &Pixcand, math::XYZTLorentzVector &Trkcand, std::vector< double > &PixMaxP, double &TrkMaxP, bool &selTk)
 
void pushMipCutTreeVecs (math::XYZTLorentzVector &NFcand, math::XYZTLorentzVector &Trkcand, double &EmipNFcand, double &EmipTrkcand, double &mindR, double &mindP1, std::vector< bool > &Flags, double hCone)
 
void studyIsolation (edm::Handle< reco::TrackCollection > &, std::vector< reco::TrackCollection::const_iterator > &)
 
void studyMipCut (edm::Handle< reco::TrackCollection > &trkCollection, edm::Handle< reco::IsolatedPixelTrackCandidateCollection > &L2cands)
 
void studyTiming (const edm::Event &theEvent)
 
void studyTrigger (edm::Handle< reco::TrackCollection > &, std::vector< reco::TrackCollection::const_iterator > &)
 
void StudyTrkEbyP (edm::Handle< reco::TrackCollection > &trkCollection)
 

Private Attributes

const double a_charIsoR_
 
const double a_coneR_
 
const double a_mipR_
 
const double a_neutIsoR_
 
const double a_neutR1_
 
const double a_neutR2_
 
edm::Handle< EcalRecHitCollectionbarrelRecHitsHandle_
 
edm::Handle< reco::BeamSpotbeamSpotH_
 
const MagneticFieldbField_
 
double bfVal_
 
bool changed_
 
TTree * ChgIsolnTree_
 
const double cutCharge_
 
const double cutMip_
 
const double cutNeutral_
 
const bool doChgIsolTree_
 
const bool doL2L3_
 
const bool doMipCutTree_
 
const bool doStudyIsol_
 
const bool doTiming_
 
const bool doTrkResTree_
 
const double dr_L1_
 
edm::Handle< EcalRecHitCollectionendcapRecHitsHandle_
 
edm::Service< TFileServicefs_
 
TH1I * g_Accepts
 
TH1D * g_Pre
 
TH1D * g_PreHLT
 
TH1D * g_PreL1
 
const CaloGeometrygeo_
 
TH1D * h_dEta [9]
 
TH1D * h_dEtaL1 [2]
 
TH1D * h_dinvPt [9]
 
TH1D * h_dP [9]
 
TH1D * h_dPhi [9]
 
TH1D * h_dPhiL1 [2]
 
TH1D * h_dPt [9]
 
TH1D * h_dRL1 [2]
 
TH1D * h_eCalo [5][6][48]
 
TH1D * h_eHcal [5][6][48]
 
TH1D * h_eMaxNearP [2]
 
TH1D * h_eMip [2]
 
TH1D * h_eNeutIso [2]
 
TH1D * h_EnIn
 
TH1D * h_EnOut
 
TH1D * h_eta [20]
 
TH1D * h_etaCalibTracks [5][2][2]
 
TH1D * h_etaMipTracks [5][2][2]
 
TH1I * h_Filters
 
TH1I * h_HLT
 
TH1D * h_L1ObjEnergy
 
TH1D * h_mindR [9]
 
TH2D * h_MipEnMatch
 
TH2D * h_MipEnNoMatch
 
TH1I * h_nHLT
 
TH1I * h_nL3Objs
 
TH1D * h_p [20]
 
TH1D * h_phi [20]
 
TH1I * h_Pre
 
TH1I * h_PreHLT
 
TH1D * h_PreHLTwt
 
TH1I * h_PreL1
 
TH1D * h_PreL1wt
 
TH1D * h_pt [20]
 
edm::Handle< HBHERecHitCollectionhbhe_
 
HLTPrescaleProvider hltPrescaleProvider_
 
const edm::InputTag l1CandTag_
 
const edm::InputTag l2CandTag_
 
math::XYZPoint leadPV_
 
const int maxRunNo_
 
const double minPTrackValue_
 
const int minRunNo_
 
TTree * MipCutTree_
 
const edm::InputTag pixCandTag_
 
const std::vector< double > pixelIsolationConeSizeAtEC_
 
std::vector< reco::TrackRefpixelTrackRefsHB_
 
std::vector< reco::TrackRefpixelTrackRefsHE_
 
const std::vector< edm::InputTagpixelTracksSources_
 
double pLimits_ [6]
 
const double prelimCone_
 
const std::string processName_
 
double rEB_
 
edm::Handle< reco::VertexCollectionrecVtxs_
 
spr::trackSelectionParameters selectionParameters_
 
std::vector< double > * t_ECone
 
std::vector< double > * t_NFcandEmip
 
std::vector< double > * t_NFcandEta
 
std::vector< double > * t_NFcandP
 
std::vector< double > * t_NFcandPhi
 
std::vector< double > * t_NFcandPt
 
std::vector< double > * t_NFTrkcandEmip
 
std::vector< double > * t_NFTrkcandEta
 
std::vector< double > * t_NFTrkcandP
 
std::vector< double > * t_NFTrkcandPhi
 
std::vector< double > * t_NFTrkcandPt
 
std::vector< bool > * t_NFTrkChgIsoFlag
 
std::vector< double > * t_NFTrkMinDP1
 
std::vector< double > * t_NFTrkMinDR
 
std::vector< bool > * t_NFTrkMipFlag
 
std::vector< bool > * t_NFTrkMissFlag
 
std::vector< bool > * t_NFTrkNeuIsoFlag
 
std::vector< bool > * t_NFTrkPropFlag
 
std::vector< bool > * t_NFTrkPVFlag
 
std::vector< bool > * t_NFTrkqltyFlag
 
std::vector< bool > * t_NFTrkselTkFlag
 
std::vector< int > * t_nGoodTk
 
std::vector< int > * t_nPixCand
 
std::vector< int > * t_nPixSeed
 
std::vector< double > * t_PixcandEta
 
std::vector< std::vector< double > > * t_PixcandMaxP
 
std::vector< double > * t_PixcandP
 
std::vector< double > * t_PixcandPhi
 
std::vector< double > * t_PixcandPt
 
std::vector< double > * t_PixTrkcandEta
 
std::vector< double > * t_PixTrkcandMaxP
 
std::vector< double > * t_PixTrkcandP
 
std::vector< double > * t_PixTrkcandPhi
 
std::vector< double > * t_PixTrkcandPt
 
std::vector< bool > * t_PixTrkcandselTk
 
std::vector< double > * t_timeL2Prod
 
std::vector< double > * t_TrkhCone
 
std::vector< bool > * t_TrkMissFlag
 
std::vector< bool > * t_TrkNuIsolFlag
 
std::vector< double > * t_TrkP
 
std::vector< bool > * t_TrkPVFlag
 
std::vector< bool > * t_TrkqltyFlag
 
std::vector< bool > * t_TrkselTkFlag
 
const double tauUnbiasCone_
 
std::string theTrackQuality_
 
TTree * TimingTree_
 
edm::EDGetTokenT< reco::BeamSpottok_bs_
 
edm::EDGetTokenT< EcalRecHitCollectiontok_EB_
 
edm::EDGetTokenT< EcalRecHitCollectiontok_EE_
 
edm::EDGetTokenT< reco::TrackCollectiontok_genTrack_
 
edm::ESGetToken< CaloGeometry, CaloGeometryRecordtok_geom_
 
edm::EDGetTokenT< HBHERecHitCollectiontok_hbhe_
 
edm::EDGetTokenT< trigger::TriggerFilterObjectWithRefstok_hlt_
 
edm::EDGetTokenT< trigger::TriggerFilterObjectWithRefstok_l1cand_
 
edm::EDGetTokenT< reco::IsolatedPixelTrackCandidateCollectiontok_l2cand_
 
edm::EDGetTokenT< LumiDetailstok_lumi_
 
edm::ESGetToken< MagneticField, IdealMagneticFieldRecordtok_magField_
 
edm::EDGetTokenT< reco::IsolatedPixelTrackCandidateCollectiontok_pixtk_
 
std::vector< edm::EDGetTokenT< reco::TrackCollection > > tok_pixtks_
 
edm::EDGetTokenT< reco::VertexCollectiontok_recVtx_
 
edm::EDGetTokenT< SeedingLayerSetsHitstok_SeedingLayerHB_
 
edm::EDGetTokenT< SeedingLayerSetsHitstok_SeedingLayerHE_
 
edm::EDGetTokenT< SiPixelRecHitCollectiontok_SiPixelRecHits_
 
edm::EDGetTokenT< trigger::TriggerEventtok_trigEvt_
 
edm::EDGetTokenT< edm::TriggerResultstok_trigRes_
 
edm::EDGetTokenT< reco::VertexCollectiontok_verthb_
 
edm::EDGetTokenT< reco::VertexCollectiontok_verthe_
 
std::unordered_map< unsigned int, unsigned int > trigList_
 
const std::vector< std::string > trigNames_
 
std::unordered_map< unsigned int, const std::pair< double, double > > trigPreList_
 
TTree * TrkResTree_
 
std::vector< math::XYZTLorentzVectorvec_ [3]
 
const int verbosity_
 
const double vtxCutIsol_
 
const double vtxCutSeed_
 
double zEE_
 

Additional Inherited Members

- Public Types inherited from edm::one::EDAnalyzerBase
typedef EDAnalyzerBase ModuleType
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Protected Member Functions inherited from edm::EDConsumerBase
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > consumes (edm::InputTag const &tag)
 
template<BranchType B = InEvent>
EDConsumerBaseAdaptor< Bconsumes (edm::InputTag tag) noexcept
 
EDGetToken consumes (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken consumes (TypeToGet const &id, edm::InputTag const &tag)
 
ConsumesCollector consumesCollector ()
 Use a ConsumesCollector to gather consumes information from helper functions. More...
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes ()
 
template<typename ESProduct , typename ESRecord , Transition Tr = Transition::Event>
auto esConsumes (ESInputTag const &tag)
 
template<Transition Tr = Transition::Event>
constexpr auto esConsumes ()
 
template<Transition Tr = Transition::Event>
auto esConsumes (ESInputTag tag)
 
template<Transition Tr = Transition::Event>
ESGetTokenGeneric esConsumes (eventsetup::EventSetupRecordKey const &iRecord, eventsetup::DataKey const &iKey)
 Used with EventSetupRecord::doGet. More...
 
template<typename ProductType , BranchType B = InEvent>
EDGetTokenT< ProductType > mayConsume (edm::InputTag const &tag)
 
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
template<BranchType B>
EDGetToken mayConsume (const TypeToGet &id, edm::InputTag const &tag)
 
void resetItemsToGetFrom (BranchType iType)
 

Detailed Description

Description: [one line class summary]

Implementation: [Notes on implementation]

Definition at line 96 of file IsoTrig.cc.

Constructor & Destructor Documentation

◆ IsoTrig()

IsoTrig::IsoTrig ( const edm::ParameterSet iConfig)
explicit

Definition at line 272 of file IsoTrig.cc.

References a_charIsoR_, a_coneR_, a_mipR_, a_neutIsoR_, a_neutR1_, a_neutR2_, cutCharge_, cutMip_, cutNeutral_, doChgIsolTree_, doTiming_, edm::ParameterSet::getUntrackedParameter(), mps_fire::i, ProducerED_cfi::InputTag, dqmdumpme::k, TFileService::kSharedResource, l1CandTag_, l2CandTag_, spr::trackSelectionParameters::maxChi2, spr::trackSelectionParameters::maxDpOverP, spr::trackSelectionParameters::maxDxyPV, spr::trackSelectionParameters::maxDzPV, spr::trackSelectionParameters::maxInMiss, spr::trackSelectionParameters::maxOutMiss, spr::trackSelectionParameters::minLayerCrossed, spr::trackSelectionParameters::minOuterHit, spr::trackSelectionParameters::minPt, minPTrackValue_, spr::trackSelectionParameters::minQuality, pixCandTag_, pixelIsolationConeSizeAtEC_, pixelTracksSources_, pLimits_, prelimCone_, processName_, reco::TrackBase::qualityByName(), rEB_, selectionParameters_, tauUnbiasCone_, theTrackQuality_, tok_bs_, tok_EB_, tok_EE_, tok_genTrack_, tok_geom_, tok_hbhe_, tok_hlt_, tok_l1cand_, tok_l2cand_, tok_lumi_, tok_magField_, tok_pixtk_, tok_pixtks_, tok_recVtx_, tok_SeedingLayerHB_, tok_SeedingLayerHE_, tok_SiPixelRecHits_, tok_trigEvt_, tok_trigRes_, tok_verthb_, tok_verthe_, verbosity_, vtxCutIsol_, vtxCutSeed_, and zEE_.

273  : hltPrescaleProvider_(iConfig, consumesCollector(), *this),
274  trigNames_(iConfig.getUntrackedParameter<std::vector<std::string>>("Triggers")),
275  pixCandTag_(iConfig.getUntrackedParameter<edm::InputTag>("pixCandTag")),
276  l1CandTag_(iConfig.getUntrackedParameter<edm::InputTag>("l1CandTag")),
277  l2CandTag_(iConfig.getUntrackedParameter<edm::InputTag>("l2CandTag")),
278  pixelTracksSources_(iConfig.getUntrackedParameter<std::vector<edm::InputTag>>("pixelTracksSources")),
279  doL2L3_(iConfig.getUntrackedParameter<bool>("doL2L3", true)),
280  doTiming_(iConfig.getUntrackedParameter<bool>("doTimingTree", true)),
281  doMipCutTree_(iConfig.getUntrackedParameter<bool>("doMipCutTree", true)),
282  doTrkResTree_(iConfig.getUntrackedParameter<bool>("doTrkResTree", true)),
283  doChgIsolTree_(iConfig.getUntrackedParameter<bool>("doChgIsolTree", true)),
284  doStudyIsol_(iConfig.getUntrackedParameter<bool>("doStudyIsol", true)),
285  verbosity_(iConfig.getUntrackedParameter<int>("verbosity", 0)),
286  pixelIsolationConeSizeAtEC_(iConfig.getUntrackedParameter<std::vector<double>>("pixelIsolationConeSizeAtEC")),
287  minPTrackValue_(iConfig.getUntrackedParameter<double>("minPTrackValue")),
288  vtxCutSeed_(iConfig.getUntrackedParameter<double>("vertexCutSeed")),
289  vtxCutIsol_(iConfig.getUntrackedParameter<double>("vertexCutIsol")),
290  tauUnbiasCone_(iConfig.getUntrackedParameter<double>("tauUnbiasCone")),
291  prelimCone_(iConfig.getUntrackedParameter<double>("prelimCone")),
292  theTrackQuality_(iConfig.getUntrackedParameter<std::string>("trackQuality", "highPurity")),
293  processName_(iConfig.getUntrackedParameter<std::string>("processName", "HLT")),
294  dr_L1_(iConfig.getUntrackedParameter<double>("isolationL1", 1.0)),
295  a_coneR_(iConfig.getUntrackedParameter<double>("coneRadius", 34.98)),
296  a_charIsoR_(a_coneR_ + 28.9),
297  a_neutIsoR_(a_charIsoR_ * 0.726),
298  a_mipR_(iConfig.getUntrackedParameter<double>("coneRadiusMIP", 14.0)),
299  a_neutR1_(iConfig.getUntrackedParameter<double>("coneRadiusNeut1", 21.0)),
300  a_neutR2_(iConfig.getUntrackedParameter<double>("coneRadiusNeut2", 29.0)),
301  cutMip_(iConfig.getUntrackedParameter<double>("cutMIP", 1.0)),
302  cutCharge_(iConfig.getUntrackedParameter<double>("chargeIsolation", 2.0)),
303  cutNeutral_(iConfig.getUntrackedParameter<double>("neutralIsolation", 2.0)),
304  minRunNo_(iConfig.getUntrackedParameter<int>("minRun")),
305  maxRunNo_(iConfig.getUntrackedParameter<int>("maxRun")),
306  changed_(false),
307  t_timeL2Prod(nullptr),
308  t_nPixCand(nullptr),
309  t_nPixSeed(nullptr),
310  t_nGoodTk(nullptr),
311  t_TrkhCone(nullptr),
312  t_TrkP(nullptr),
313  t_TrkselTkFlag(nullptr),
314  t_TrkqltyFlag(nullptr),
315  t_TrkMissFlag(nullptr),
316  t_TrkPVFlag(nullptr),
317  t_TrkNuIsolFlag(nullptr),
318  t_PixcandP(nullptr),
319  t_PixcandPt(nullptr),
320  t_PixcandEta(nullptr),
321  t_PixcandPhi(nullptr),
322  t_PixcandMaxP(nullptr),
323  t_PixTrkcandP(nullptr),
324  t_PixTrkcandPt(nullptr),
325  t_PixTrkcandEta(nullptr),
326  t_PixTrkcandPhi(nullptr),
327  t_PixTrkcandMaxP(nullptr),
328  t_PixTrkcandselTk(nullptr),
329  t_NFcandP(nullptr),
330  t_NFcandPt(nullptr),
331  t_NFcandEta(nullptr),
332  t_NFcandPhi(nullptr),
333  t_NFcandEmip(nullptr),
334  t_NFTrkcandP(nullptr),
335  t_NFTrkcandPt(nullptr),
336  t_NFTrkcandEta(nullptr),
337  t_NFTrkcandPhi(nullptr),
338  t_NFTrkcandEmip(nullptr),
339  t_NFTrkMinDR(nullptr),
340  t_NFTrkMinDP1(nullptr),
341  t_NFTrkselTkFlag(nullptr),
342  t_NFTrkqltyFlag(nullptr),
343  t_NFTrkMissFlag(nullptr),
344  t_NFTrkPVFlag(nullptr),
345  t_NFTrkPropFlag(nullptr),
346  t_NFTrkChgIsoFlag(nullptr),
347  t_NFTrkNeuIsoFlag(nullptr),
348  t_NFTrkMipFlag(nullptr),
349  t_ECone(nullptr) {
350  usesResource(TFileService::kSharedResource);
351 
352  //now do whatever initialization is needed
354  selectionParameters_.minPt = iConfig.getUntrackedParameter<double>("minTrackPt", 10.0);
355  selectionParameters_.minQuality = trackQuality_;
356  selectionParameters_.maxDxyPV = iConfig.getUntrackedParameter<double>("maxDxyPV", 0.2);
357  selectionParameters_.maxDzPV = iConfig.getUntrackedParameter<double>("maxDzPV", 5.0);
358  selectionParameters_.maxChi2 = iConfig.getUntrackedParameter<double>("maxChi2", 5.0);
359  selectionParameters_.maxDpOverP = iConfig.getUntrackedParameter<double>("maxDpOverP", 0.1);
360  selectionParameters_.minOuterHit = iConfig.getUntrackedParameter<int>("minOuterHit", 4);
361  selectionParameters_.minLayerCrossed = iConfig.getUntrackedParameter<int>("minLayerCrossed", 8);
362  selectionParameters_.maxInMiss = iConfig.getUntrackedParameter<int>("maxInMiss", 0);
363  selectionParameters_.maxOutMiss = iConfig.getUntrackedParameter<int>("maxOutMiss", 0);
364 
365  // define tokens for access
366  tok_lumi_ = consumes<LumiDetails, edm::InLumi>(edm::InputTag("lumiProducer"));
367  edm::InputTag triggerEvent_("hltTriggerSummaryAOD", "", processName_);
368  tok_trigEvt_ = consumes<trigger::TriggerEvent>(triggerEvent_);
369  edm::InputTag theTriggerResultsLabel("TriggerResults", "", processName_);
370  tok_trigRes_ = consumes<edm::TriggerResults>(theTriggerResultsLabel);
371  tok_genTrack_ = consumes<reco::TrackCollection>(edm::InputTag("generalTracks"));
372  tok_recVtx_ = consumes<reco::VertexCollection>(edm::InputTag("offlinePrimaryVertices"));
373  tok_bs_ = consumes<reco::BeamSpot>(edm::InputTag("offlineBeamSpot"));
374  tok_EB_ = consumes<EcalRecHitCollection>(edm::InputTag("ecalRecHit", "EcalRecHitsEB"));
375  tok_EE_ = consumes<EcalRecHitCollection>(edm::InputTag("ecalRecHit", "EcalRecHitsEE"));
376  tok_hbhe_ = consumes<HBHERecHitCollection>(edm::InputTag("hbhereco"));
377  tok_pixtk_ = consumes<reco::IsolatedPixelTrackCandidateCollection>(pixCandTag_);
378  tok_l1cand_ = consumes<trigger::TriggerFilterObjectWithRefs>(l1CandTag_);
379  tok_l2cand_ = consumes<reco::IsolatedPixelTrackCandidateCollection>(l2CandTag_);
380  if (doTiming_) {
381  tok_verthb_ = consumes<reco::VertexCollection>(edm::InputTag("hltHITPixelVerticesHB"));
382  tok_verthe_ = consumes<reco::VertexCollection>(edm::InputTag("hltHITPixelVerticesHB"));
383  tok_hlt_ = consumes<trigger::TriggerFilterObjectWithRefs>(edm::InputTag("hltL1sL1SingleJet68"));
384  tok_SeedingLayerHB_ = consumes<SeedingLayerSetsHits>(edm::InputTag("hltPixelLayerTripletsHITHB"));
385  tok_SeedingLayerHE_ = consumes<SeedingLayerSetsHits>(edm::InputTag("hltPixelLayerTripletsHITHE"));
386  tok_SiPixelRecHits_ = consumes<SiPixelRecHitCollection>(edm::InputTag("hltSiPixelRecHits"));
387  }
388  if (doChgIsolTree_) {
389  for (unsigned int k = 0; k < pixelTracksSources_.size(); ++k) {
390  // edm::InputTag pix (pixelTracksSources_[k],"",processName_);
391  // tok_pixtks_.push_back(consumes<reco::TrackCollection>(pix));
392  tok_pixtks_.push_back(consumes<reco::TrackCollection>(pixelTracksSources_[k]));
393  }
394  }
395  if (verbosity_ >= 0) {
396  edm::LogVerbatim("IsoTrack") << "Parameters read from config file \n"
397  << "\t minPt " << selectionParameters_.minPt << "\t theTrackQuality "
398  << theTrackQuality_ << "\t minQuality " << selectionParameters_.minQuality
399  << "\t maxDxyPV " << selectionParameters_.maxDxyPV << "\t maxDzPV "
401  << "\t maxDpOverP " << selectionParameters_.maxDpOverP << "\t minOuterHit "
402  << selectionParameters_.minOuterHit << "\t minLayerCrossed "
403  << selectionParameters_.minLayerCrossed << "\t maxInMiss "
404  << selectionParameters_.maxInMiss << "\t maxOutMiss "
405  << selectionParameters_.maxOutMiss << "\t a_coneR " << a_coneR_ << "\t a_charIsoR "
406  << a_charIsoR_ << "\t a_neutIsoR " << a_neutIsoR_ << "\t a_mipR " << a_mipR_
407  << "\t a_neutR " << a_neutR1_ << ":" << a_neutR2_ << "\t cuts (MIP " << cutMip_
408  << " : Charge " << cutCharge_ << " : Neutral " << cutNeutral_ << ")";
409  edm::LogVerbatim("IsoTrack") << "Charge Isolation parameters:"
410  << "\t minPTrackValue " << minPTrackValue_ << "\t vtxCutSeed " << vtxCutSeed_
411  << "\t vtxCutIsol " << vtxCutIsol_ << "\t tauUnbiasCone " << tauUnbiasCone_
412  << "\t prelimCone " << prelimCone_ << "\t pixelIsolationConeSizeAtEC";
413  for (unsigned int k = 0; k < pixelIsolationConeSizeAtEC_.size(); ++k)
414  edm::LogVerbatim("IsoTrack") << "[" << k << "] " << pixelIsolationConeSizeAtEC_[k];
415  }
416  double pl[] = {20, 30, 40, 60, 80, 120};
417  for (int i = 0; i < 6; ++i)
418  pLimits_[i] = pl[i];
419  rEB_ = 123.8;
420  zEE_ = 317.0;
421 
422  tok_geom_ = esConsumes<CaloGeometry, CaloGeometryRecord>();
423  tok_magField_ = esConsumes<MagneticField, IdealMagneticFieldRecord>();
424 }
bool changed_
Definition: IsoTrig.cc:204
static const std::string kSharedResource
Definition: TFileService.h:76
Log< level::Info, true > LogVerbatim
std::vector< bool > * t_NFTrkPVFlag
Definition: IsoTrig.cc:248
std::vector< double > * t_PixTrkcandPhi
Definition: IsoTrig.cc:229
std::vector< double > * t_PixTrkcandP
Definition: IsoTrig.cc:226
const double a_coneR_
Definition: IsoTrig.cc:165
std::string theTrackQuality_
Definition: IsoTrig.cc:161
edm::EDGetTokenT< reco::IsolatedPixelTrackCandidateCollection > tok_l2cand_
Definition: IsoTrig.cc:185
const edm::InputTag l2CandTag_
Definition: IsoTrig.cc:153
std::vector< double > * t_NFTrkMinDR
Definition: IsoTrig.cc:243
std::vector< bool > * t_NFTrkMissFlag
Definition: IsoTrig.cc:247
const bool doChgIsolTree_
Definition: IsoTrig.cc:156
edm::EDGetTokenT< LumiDetails > tok_lumi_
Definition: IsoTrig.cc:169
std::vector< bool > * t_PixTrkcandselTk
Definition: IsoTrig.cc:231
const double a_charIsoR_
Definition: IsoTrig.cc:165
const double a_neutR2_
Definition: IsoTrig.cc:166
TrackQuality
track quality
Definition: TrackBase.h:150
std::vector< double > * t_NFTrkcandEta
Definition: IsoTrig.cc:240
std::vector< double > * t_NFcandP
Definition: IsoTrig.cc:233
const int verbosity_
Definition: IsoTrig.cc:157
const int maxRunNo_
Definition: IsoTrig.cc:168
edm::EDGetTokenT< EcalRecHitCollection > tok_EB_
Definition: IsoTrig.cc:176
const double a_neutIsoR_
Definition: IsoTrig.cc:165
std::vector< int > * t_nPixSeed
Definition: IsoTrig.cc:210
std::vector< double > * t_TrkhCone
Definition: IsoTrig.cc:213
double rEB_
Definition: IsoTrig.cc:163
edm::EDGetTokenT< reco::IsolatedPixelTrackCandidateCollection > tok_pixtk_
Definition: IsoTrig.cc:183
std::vector< bool > * t_NFTrkqltyFlag
Definition: IsoTrig.cc:246
std::vector< double > * t_PixTrkcandMaxP
Definition: IsoTrig.cc:230
const double minPTrackValue_
Definition: IsoTrig.cc:159
std::vector< bool > * t_NFTrkselTkFlag
Definition: IsoTrig.cc:245
const double a_mipR_
Definition: IsoTrig.cc:166
std::vector< double > * t_PixcandP
Definition: IsoTrig.cc:221
edm::EDGetTokenT< trigger::TriggerEvent > tok_trigEvt_
Definition: IsoTrig.cc:170
const double tauUnbiasCone_
Definition: IsoTrig.cc:160
std::vector< bool > * t_NFTrkMipFlag
Definition: IsoTrig.cc:252
const double dr_L1_
Definition: IsoTrig.cc:165
T getUntrackedParameter(std::string const &, T const &) const
std::vector< double > * t_NFTrkMinDP1
Definition: IsoTrig.cc:244
const std::vector< edm::InputTag > pixelTracksSources_
Definition: IsoTrig.cc:154
HLTPrescaleProvider hltPrescaleProvider_
Definition: IsoTrig.cc:151
const bool doMipCutTree_
Definition: IsoTrig.cc:155
edm::EDGetTokenT< edm::TriggerResults > tok_trigRes_
Definition: IsoTrig.cc:171
std::vector< double > * t_NFTrkcandP
Definition: IsoTrig.cc:238
edm::EDGetTokenT< SeedingLayerSetsHits > tok_SeedingLayerHB_
Definition: IsoTrig.cc:180
std::vector< bool > * t_TrkNuIsolFlag
Definition: IsoTrig.cc:219
edm::ESGetToken< MagneticField, IdealMagneticFieldRecord > tok_magField_
Definition: IsoTrig.cc:189
edm::EDGetTokenT< reco::BeamSpot > tok_bs_
Definition: IsoTrig.cc:175
const double prelimCone_
Definition: IsoTrig.cc:160
std::vector< bool > * t_TrkPVFlag
Definition: IsoTrig.cc:218
std::vector< double > * t_ECone
Definition: IsoTrig.cc:253
ConsumesCollector consumesCollector()
Use a ConsumesCollector to gather consumes information from helper functions.
edm::EDGetTokenT< reco::TrackCollection > tok_genTrack_
Definition: IsoTrig.cc:173
const double a_neutR1_
Definition: IsoTrig.cc:166
double zEE_
Definition: IsoTrig.cc:163
std::vector< bool > * t_NFTrkChgIsoFlag
Definition: IsoTrig.cc:250
std::vector< edm::EDGetTokenT< reco::TrackCollection > > tok_pixtks_
Definition: IsoTrig.cc:186
std::vector< double > * t_TrkP
Definition: IsoTrig.cc:214
spr::trackSelectionParameters selectionParameters_
Definition: IsoTrig.cc:164
std::vector< double > * t_NFcandEta
Definition: IsoTrig.cc:235
edm::EDGetTokenT< SeedingLayerSetsHits > tok_SeedingLayerHE_
Definition: IsoTrig.cc:181
std::vector< double > * t_timeL2Prod
Definition: IsoTrig.cc:208
edm::EDGetTokenT< EcalRecHitCollection > tok_EE_
Definition: IsoTrig.cc:177
std::vector< double > * t_PixcandPt
Definition: IsoTrig.cc:222
std::vector< double > * t_NFcandEmip
Definition: IsoTrig.cc:237
const bool doTrkResTree_
Definition: IsoTrig.cc:156
std::vector< bool > * t_NFTrkPropFlag
Definition: IsoTrig.cc:249
std::vector< double > * t_NFTrkcandPhi
Definition: IsoTrig.cc:241
const double cutCharge_
Definition: IsoTrig.cc:167
std::vector< bool > * t_TrkMissFlag
Definition: IsoTrig.cc:217
edm::EDGetTokenT< reco::VertexCollection > tok_recVtx_
Definition: IsoTrig.cc:174
std::vector< int > * t_nPixCand
Definition: IsoTrig.cc:209
static TrackQuality qualityByName(const std::string &name)
Definition: TrackBase.cc:126
std::vector< double > * t_NFTrkcandPt
Definition: IsoTrig.cc:239
const bool doStudyIsol_
Definition: IsoTrig.cc:156
const edm::InputTag pixCandTag_
Definition: IsoTrig.cc:153
std::vector< double > * t_PixTrkcandPt
Definition: IsoTrig.cc:227
edm::EDGetTokenT< reco::VertexCollection > tok_verthb_
Definition: IsoTrig.cc:179
std::vector< double > * t_NFcandPt
Definition: IsoTrig.cc:234
const int minRunNo_
Definition: IsoTrig.cc:168
std::vector< bool > * t_TrkqltyFlag
Definition: IsoTrig.cc:216
const std::string processName_
Definition: IsoTrig.cc:162
std::vector< std::vector< double > > * t_PixcandMaxP
Definition: IsoTrig.cc:225
std::vector< double > * t_NFTrkcandEmip
Definition: IsoTrig.cc:242
edm::EDGetTokenT< trigger::TriggerFilterObjectWithRefs > tok_l1cand_
Definition: IsoTrig.cc:184
const double vtxCutIsol_
Definition: IsoTrig.cc:159
const edm::InputTag l1CandTag_
Definition: IsoTrig.cc:153
edm::EDGetTokenT< SiPixelRecHitCollection > tok_SiPixelRecHits_
Definition: IsoTrig.cc:182
edm::EDGetTokenT< HBHERecHitCollection > tok_hbhe_
Definition: IsoTrig.cc:178
std::vector< double > * t_PixcandEta
Definition: IsoTrig.cc:223
reco::TrackBase::TrackQuality minQuality
std::vector< bool > * t_NFTrkNeuIsoFlag
Definition: IsoTrig.cc:251
std::vector< double > * t_PixcandPhi
Definition: IsoTrig.cc:224
const bool doTiming_
Definition: IsoTrig.cc:155
std::vector< double > * t_PixTrkcandEta
Definition: IsoTrig.cc:228
std::vector< int > * t_nGoodTk
Definition: IsoTrig.cc:211
edm::EDGetTokenT< reco::VertexCollection > tok_verthe_
Definition: IsoTrig.cc:179
const std::vector< double > pixelIsolationConeSizeAtEC_
Definition: IsoTrig.cc:158
const double cutMip_
Definition: IsoTrig.cc:166
edm::EDGetTokenT< trigger::TriggerFilterObjectWithRefs > tok_hlt_
Definition: IsoTrig.cc:172
const double cutNeutral_
Definition: IsoTrig.cc:167
double pLimits_[6]
Definition: IsoTrig.cc:205
std::vector< bool > * t_TrkselTkFlag
Definition: IsoTrig.cc:215
const std::vector< std::string > trigNames_
Definition: IsoTrig.cc:152
const double vtxCutSeed_
Definition: IsoTrig.cc:159
const bool doL2L3_
Definition: IsoTrig.cc:155
std::vector< double > * t_NFcandPhi
Definition: IsoTrig.cc:236
edm::ESGetToken< CaloGeometry, CaloGeometryRecord > tok_geom_
Definition: IsoTrig.cc:188

◆ ~IsoTrig()

IsoTrig::~IsoTrig ( )
override

Definition at line 426 of file IsoTrig.cc.

References t_ECone, t_NFcandEmip, t_NFcandEta, t_NFcandP, t_NFcandPhi, t_NFcandPt, t_NFTrkcandEmip, t_NFTrkcandEta, t_NFTrkcandP, t_NFTrkcandPhi, t_NFTrkcandPt, t_NFTrkChgIsoFlag, t_NFTrkMinDP1, t_NFTrkMinDR, t_NFTrkMipFlag, t_NFTrkMissFlag, t_NFTrkNeuIsoFlag, t_NFTrkPropFlag, t_NFTrkPVFlag, t_NFTrkqltyFlag, t_NFTrkselTkFlag, t_nGoodTk, t_nPixCand, t_nPixSeed, t_PixcandEta, t_PixcandMaxP, t_PixcandP, t_PixcandPhi, t_PixcandPt, t_PixTrkcandEta, t_PixTrkcandMaxP, t_PixTrkcandP, t_PixTrkcandPhi, t_PixTrkcandPt, t_PixTrkcandselTk, t_timeL2Prod, t_TrkhCone, t_TrkMissFlag, t_TrkNuIsolFlag, t_TrkP, t_TrkPVFlag, t_TrkqltyFlag, and t_TrkselTkFlag.

426  {
427  // do anything here that needs to be done at desctruction time
428  // (e.g. close files, deallocate resources etc.)
429  if (t_timeL2Prod)
430  delete t_timeL2Prod;
431  if (t_nPixCand)
432  delete t_nPixCand;
433  if (t_nPixSeed)
434  delete t_nPixSeed;
435  if (t_nGoodTk)
436  delete t_nGoodTk;
437  if (t_TrkhCone)
438  delete t_TrkhCone;
439  if (t_TrkP)
440  delete t_TrkP;
441  if (t_TrkselTkFlag)
442  delete t_TrkselTkFlag;
443  if (t_TrkqltyFlag)
444  delete t_TrkqltyFlag;
445  if (t_TrkMissFlag)
446  delete t_TrkMissFlag;
447  if (t_TrkPVFlag)
448  delete t_TrkPVFlag;
449  if (t_TrkNuIsolFlag)
450  delete t_TrkNuIsolFlag;
451  if (t_PixcandP)
452  delete t_PixcandP;
453  if (t_PixcandPt)
454  delete t_PixcandPt;
455  if (t_PixcandEta)
456  delete t_PixcandEta;
457  if (t_PixcandPhi)
458  delete t_PixcandPhi;
459  if (t_PixcandMaxP)
460  delete t_PixcandMaxP;
461  if (t_PixTrkcandP)
462  delete t_PixTrkcandP;
463  if (t_PixTrkcandPt)
464  delete t_PixTrkcandPt;
465  if (t_PixTrkcandEta)
466  delete t_PixTrkcandEta;
467  if (t_PixTrkcandPhi)
468  delete t_PixTrkcandPhi;
469  if (t_PixTrkcandMaxP)
470  delete t_PixTrkcandMaxP;
471  if (t_PixTrkcandselTk)
472  delete t_PixTrkcandselTk;
473  if (t_NFcandP)
474  delete t_NFcandP;
475  if (t_NFcandPt)
476  delete t_NFcandPt;
477  if (t_NFcandEta)
478  delete t_NFcandEta;
479  if (t_NFcandPhi)
480  delete t_NFcandPhi;
481  if (t_NFcandEmip)
482  delete t_NFcandEmip;
483  if (t_NFTrkcandP)
484  delete t_NFTrkcandP;
485  if (t_NFTrkcandPt)
486  delete t_NFTrkcandPt;
487  if (t_NFTrkcandEta)
488  delete t_NFTrkcandEta;
489  if (t_NFTrkcandPhi)
490  delete t_NFTrkcandPhi;
491  if (t_NFTrkcandEmip)
492  delete t_NFTrkcandEmip;
493  if (t_NFTrkMinDR)
494  delete t_NFTrkMinDR;
495  if (t_NFTrkMinDP1)
496  delete t_NFTrkMinDP1;
497  if (t_NFTrkselTkFlag)
498  delete t_NFTrkselTkFlag;
499  if (t_NFTrkqltyFlag)
500  delete t_NFTrkqltyFlag;
501  if (t_NFTrkMissFlag)
502  delete t_NFTrkMissFlag;
503  if (t_NFTrkPVFlag)
504  delete t_NFTrkPVFlag;
505  if (t_NFTrkPropFlag)
506  delete t_NFTrkPropFlag;
507  if (t_NFTrkChgIsoFlag)
508  delete t_NFTrkChgIsoFlag;
509  if (t_NFTrkNeuIsoFlag)
510  delete t_NFTrkNeuIsoFlag;
511  if (t_NFTrkMipFlag)
512  delete t_NFTrkMipFlag;
513  if (t_ECone)
514  delete t_ECone;
515 }
std::vector< bool > * t_NFTrkPVFlag
Definition: IsoTrig.cc:248
std::vector< double > * t_PixTrkcandPhi
Definition: IsoTrig.cc:229
std::vector< double > * t_PixTrkcandP
Definition: IsoTrig.cc:226
std::vector< double > * t_NFTrkMinDR
Definition: IsoTrig.cc:243
std::vector< bool > * t_NFTrkMissFlag
Definition: IsoTrig.cc:247
std::vector< bool > * t_PixTrkcandselTk
Definition: IsoTrig.cc:231
std::vector< double > * t_NFTrkcandEta
Definition: IsoTrig.cc:240
std::vector< double > * t_NFcandP
Definition: IsoTrig.cc:233
std::vector< int > * t_nPixSeed
Definition: IsoTrig.cc:210
std::vector< double > * t_TrkhCone
Definition: IsoTrig.cc:213
std::vector< bool > * t_NFTrkqltyFlag
Definition: IsoTrig.cc:246
std::vector< double > * t_PixTrkcandMaxP
Definition: IsoTrig.cc:230
std::vector< bool > * t_NFTrkselTkFlag
Definition: IsoTrig.cc:245
std::vector< double > * t_PixcandP
Definition: IsoTrig.cc:221
std::vector< bool > * t_NFTrkMipFlag
Definition: IsoTrig.cc:252
std::vector< double > * t_NFTrkMinDP1
Definition: IsoTrig.cc:244
std::vector< double > * t_NFTrkcandP
Definition: IsoTrig.cc:238
std::vector< bool > * t_TrkNuIsolFlag
Definition: IsoTrig.cc:219
std::vector< bool > * t_TrkPVFlag
Definition: IsoTrig.cc:218
std::vector< double > * t_ECone
Definition: IsoTrig.cc:253
std::vector< bool > * t_NFTrkChgIsoFlag
Definition: IsoTrig.cc:250
std::vector< double > * t_TrkP
Definition: IsoTrig.cc:214
std::vector< double > * t_NFcandEta
Definition: IsoTrig.cc:235
std::vector< double > * t_timeL2Prod
Definition: IsoTrig.cc:208
std::vector< double > * t_PixcandPt
Definition: IsoTrig.cc:222
std::vector< double > * t_NFcandEmip
Definition: IsoTrig.cc:237
std::vector< bool > * t_NFTrkPropFlag
Definition: IsoTrig.cc:249
std::vector< double > * t_NFTrkcandPhi
Definition: IsoTrig.cc:241
std::vector< bool > * t_TrkMissFlag
Definition: IsoTrig.cc:217
std::vector< int > * t_nPixCand
Definition: IsoTrig.cc:209
std::vector< double > * t_NFTrkcandPt
Definition: IsoTrig.cc:239
std::vector< double > * t_PixTrkcandPt
Definition: IsoTrig.cc:227
std::vector< double > * t_NFcandPt
Definition: IsoTrig.cc:234
std::vector< bool > * t_TrkqltyFlag
Definition: IsoTrig.cc:216
std::vector< std::vector< double > > * t_PixcandMaxP
Definition: IsoTrig.cc:225
std::vector< double > * t_NFTrkcandEmip
Definition: IsoTrig.cc:242
std::vector< double > * t_PixcandEta
Definition: IsoTrig.cc:223
std::vector< bool > * t_NFTrkNeuIsoFlag
Definition: IsoTrig.cc:251
std::vector< double > * t_PixcandPhi
Definition: IsoTrig.cc:224
std::vector< double > * t_PixTrkcandEta
Definition: IsoTrig.cc:228
std::vector< int > * t_nGoodTk
Definition: IsoTrig.cc:211
std::vector< bool > * t_TrkselTkFlag
Definition: IsoTrig.cc:215
std::vector< double > * t_NFcandPhi
Definition: IsoTrig.cc:236

Member Function Documentation

◆ analyze()

void IsoTrig::analyze ( const edm::Event iEvent,
const edm::EventSetup iSetup 
)
overrideprivatevirtual

Implements edm::one::EDAnalyzerBase.

Definition at line 565 of file IsoTrig.cc.

References barrelRecHitsHandle_, beamSpotH_, ProducerSetup_cfi::BField, bField_, bfVal_, changed_, chgIsolation(), l1ct::clear(), doChgIsolTree_, doL2L3_, doMipCutTree_, doStudyIsol_, doTiming_, doTrkResTree_, endcapRecHitsHandle_, trigger::TriggerObject::energy(), trigger::TriggerObject::eta(), fastmath::etaphi(), etaPhiTrigger(), spr::find(), geo_, edm::EventSetup::getData(), getGoodTracks(), h_Filters, h_HLT, h_L1ObjEnergy, h_nHLT, h_nL3Objs, h_Pre, h_PreHLT, h_PreHLTwt, h_PreL1, h_PreL1wt, hbhe_, ValidationMatrix::hlt, HltComparatorCreateWorkflow::hltConfig, HLTPrescaleProvider::hltConfigProvider(), hltPrescaleProvider_, mps_fire::i, trigger::TriggerObject::id(), iEvent, recoMuon::in, MagneticField::inTesla(), edm::HandleBase::isValid(), gpuVertexFinder::iv, LumiDetails::kOCC1, label, leadPV_, spclusmultlumicorr_cfi::lumiProducer, LumiDetails::lumiValue(), trigger::TriggerObject::mass(), LogMessageMonitor_cff::modules, dqmiodumpmetadata::n, trigger::TriggerObject::phi(), pixelTrackRefsHB_, pixelTrackRefsHE_, pixelTracksSources_, reco::BeamSpot::position(), hltrates_dqm_sourceclient-live_cfg::prescales, HLTPrescaleProvider::prescaleValues(), edm::Handle< T >::product(), trigger::TriggerObject::pt(), trigger::TriggerObject::px(), trigger::TriggerObject::py(), trigger::TriggerObject::pz(), recVtxs_, findQualityFiles::size, AlCaHLTBitMon_QueryRunRegistry::string, studyIsolation(), studyMipCut(), studyTiming(), studyTrigger(), StudyTrkEbyP(), tok_bs_, tok_EB_, tok_EE_, tok_genTrack_, tok_geom_, tok_hbhe_, tok_l1cand_, tok_l2cand_, tok_lumi_, tok_magField_, tok_pixtk_, tok_pixtks_, tok_recVtx_, tok_trigEvt_, tok_trigRes_, PDWG_DiPhoton_SD_cff::triggerEvent, L1TEGammaOffline_cfi::triggerNames, triggerResults, trigList_, trigNames_, trigPreList_, vec_, verbosity_, x, y, and z.

565  {
566  if (verbosity_ % 10 > 0)
567  edm::LogVerbatim("IsoTrack") << "Event starts====================================";
568 
569  int RunNo = iEvent.id().run();
570 
572 
573  bField_ = &iSetup.getData(tok_magField_);
574  geo_ = &iSetup.getData(tok_geom_);
576  bfVal_ = BField.mag();
577 
579  edm::Handle<trigger::TriggerEvent> triggerEventHandle;
580  iEvent.getByToken(tok_trigEvt_, triggerEventHandle);
581  if (!triggerEventHandle.isValid()) {
582  edm::LogWarning("IsoTrack") << "Error! Can't get the product hltTriggerSummaryAOD";
583 
584  } else {
585  triggerEvent = *(triggerEventHandle.product());
586  }
587  const trigger::TriggerObjectCollection &TOC(triggerEvent.getObjects());
590  iEvent.getByToken(tok_trigRes_, triggerResults);
591 
593  iEvent.getByToken(tok_genTrack_, trkCollection);
594 
595  iEvent.getByToken(tok_EB_, barrelRecHitsHandle_);
596  iEvent.getByToken(tok_EE_, endcapRecHitsHandle_);
597 
598  iEvent.getByToken(tok_hbhe_, hbhe_);
599 
600  iEvent.getByToken(tok_recVtx_, recVtxs_);
601  iEvent.getByToken(tok_bs_, beamSpotH_);
602  if (!recVtxs_->empty() && !((*recVtxs_)[0].isFake())) {
603  leadPV_ = math::XYZPoint((*recVtxs_)[0].x(), (*recVtxs_)[0].y(), (*recVtxs_)[0].z());
604  } else if (beamSpotH_.isValid()) {
606  }
607 
608  if ((verbosity_ / 100) % 10 > 0) {
609  edm::LogVerbatim("IsoTrack") << "Primary Vertex " << leadPV_;
610  if (beamSpotH_.isValid())
611  edm::LogVerbatim("IsoTrack") << "Beam Spot " << beamSpotH_->position();
612  }
613  pixelTrackRefsHE_.clear();
614  pixelTrackRefsHB_.clear();
615  for (unsigned int iPix = 0; iPix < pixelTracksSources_.size(); iPix++) {
617  iEvent.getByToken(tok_pixtks_[iPix], iPixCol);
618  if (iPixCol.isValid()) {
619  for (reco::TrackCollection::const_iterator pit = iPixCol->begin(); pit != iPixCol->end(); pit++) {
620  if (iPix == 0)
621  pixelTrackRefsHB_.push_back(reco::TrackRef(iPixCol, pit - iPixCol->begin()));
622  pixelTrackRefsHE_.push_back(reco::TrackRef(iPixCol, pit - iPixCol->begin()));
623  }
624  }
625  }
626  if (doTiming_)
627  getGoodTracks(iEvent, trkCollection);
628 
629  for (unsigned int ifilter = 0; ifilter < triggerEvent.sizeFilters(); ++ifilter) {
630  std::string FilterNames[7] = {"hltL1sL1SingleJet68",
631  "hltIsolPixelTrackL2FilterHE",
632  "ecalIsolPixelTrackFilterHE",
633  "hltIsolPixelTrackL3FilterHE",
634  "hltIsolPixelTrackL2FilterHB",
635  "ecalIsolPixelTrackFilterHB",
636  "hltIsolPixelTrackL3FilterHB"};
637  std::string label = triggerEvent.filterTag(ifilter).label();
638  for (int i = 0; i < 7; i++) {
639  if (label == FilterNames[i])
640  h_Filters->Fill(i);
641  }
642  }
643  edm::InputTag lumiProducer("LumiProducer", "", "RECO");
645  iEvent.getLuminosityBlock().getByToken(tok_lumi_, Lumid);
646  float mybxlumi = -1;
647  if (Lumid.isValid())
648  mybxlumi = Lumid->lumiValue(LumiDetails::kOCC1, iEvent.bunchCrossing()) * 6.37;
649  if (verbosity_ % 10 > 0)
650  edm::LogVerbatim("IsoTrack") << "RunNo " << RunNo << " EvtNo " << iEvent.id().event() << " Lumi "
651  << iEvent.luminosityBlock() << " Bunch " << iEvent.bunchCrossing() << " mybxlumi "
652  << mybxlumi;
653  if (!triggerResults.isValid()) {
654  edm::LogWarning("IsoTrack") << "Error! Can't get the product triggerResults";
655  // std::shared_ptr<cms::Exception> const & error = triggerResults.whyFailed();
656  // edm::LogWarning(error->category()) << error->what();
657  } else {
658  std::vector<std::string> modules;
659  h_nHLT->Fill(triggerResults->size());
660  const edm::TriggerNames &triggerNames = iEvent.triggerNames(*triggerResults);
661 
662  const std::vector<std::string> &triggerNames_ = triggerNames.triggerNames();
663  if (verbosity_ % 10 > 1)
664  edm::LogVerbatim("IsoTrack") << "number of HLTs " << triggerNames_.size();
665  double preL1(-1), preHLT(-1), prescale(-1);
666  int hlt(-1);
667  for (unsigned int i = 0; i < triggerResults->size(); i++) {
668  unsigned int triggerindx = hltConfig.triggerIndex(triggerNames_[i]);
669  const std::vector<std::string> &moduleLabels(hltConfig.moduleLabels(triggerindx));
670 
671  for (unsigned int in = 0; in < trigNames_.size(); ++in) {
672  // if (triggerNames_[i].find(trigNames_[in].c_str())!=std::string::npos || triggerNames_[i]==" ") {
673  if (triggerNames_[i].find(trigNames_[in]) != std::string::npos) {
674  if (verbosity_ % 10 > 0)
675  edm::LogVerbatim("IsoTrack") << "trigger that i want " << triggerNames_[i] << " accept "
676  << triggerResults->accept(i);
677  hlt = triggerResults->accept(i);
678  h_HLT->Fill(hlt);
679  // if (hlt>0 || triggerNames_[i]==" ") {
680  if (hlt > 0) {
682  iEvent.getByToken(tok_pixtk_, Pixcands);
684  iEvent.getByToken(tok_l1cand_, L1cands);
685 
686  auto const prescales = hltPrescaleProvider_.prescaleValues<double>(iEvent, iSetup, triggerNames_[i]);
687  preL1 = prescales.first;
688  preHLT = prescales.second;
689  prescale = preL1 * preHLT;
690  if (verbosity_ % 10 > 0)
691  edm::LogVerbatim("IsoTrack")
692  << triggerNames_[i] << " accept " << hlt << " preL1 " << preL1 << " preHLT " << preHLT;
693  for (int iv = 0; iv < 3; ++iv)
694  vec_[iv].clear();
695  if (trigList_.find(RunNo) != trigList_.end()) {
696  trigList_[RunNo] += 1;
697  } else {
698  trigList_.insert({RunNo, 1});
699  trigPreList_.insert({RunNo, prescales});
700  }
701  //loop over all trigger filters in event (i.e. filters passed)
702  for (unsigned int ifilter = 0; ifilter < triggerEvent.sizeFilters(); ++ifilter) {
703  std::vector<int> Keys;
704  std::string label = triggerEvent.filterTag(ifilter).label();
705  //loop over keys to objects passing this filter
706  for (unsigned int imodule = 0; imodule < moduleLabels.size(); imodule++) {
707  if (label.find(moduleLabels[imodule]) != std::string::npos) {
708  if (verbosity_ % 10 > 0)
709  edm::LogVerbatim("IsoTrack") << "FILTERNAME " << label;
710  for (unsigned int ifiltrKey = 0; ifiltrKey < triggerEvent.filterKeys(ifilter).size(); ++ifiltrKey) {
711  Keys.push_back(triggerEvent.filterKeys(ifilter)[ifiltrKey]);
712  const trigger::TriggerObject &TO(TOC[Keys[ifiltrKey]]);
713  math::XYZTLorentzVector v4(TO.px(), TO.py(), TO.pz(), TO.energy());
714  if (label.find("L2Filter") != std::string::npos) {
715  vec_[1].push_back(v4);
716  } else if (label.find("L3Filter") != std::string::npos) {
717  vec_[2].push_back(v4);
718  } else {
719  vec_[0].push_back(v4);
720  h_L1ObjEnergy->Fill(TO.energy());
721  }
722  if (verbosity_ % 10 > 0)
723  edm::LogVerbatim("IsoTrack") << "key " << ifiltrKey << " : pt " << TO.pt() << " eta " << TO.eta()
724  << " phi " << TO.phi() << " mass " << TO.mass() << " Id " << TO.id();
725  }
726  }
727  }
728  }
729  std::vector<reco::TrackCollection::const_iterator> goodTks;
730  if (doL2L3_) {
731  h_nL3Objs->Fill(vec_[2].size());
732  studyTrigger(trkCollection, goodTks);
733  } else {
734  if (trkCollection.isValid()) {
735  reco::TrackCollection::const_iterator trkItr;
736  for (trkItr = trkCollection->begin(); trkItr != trkCollection->end(); trkItr++)
737  goodTks.push_back(trkItr);
738  }
739  }
740  // Now study isolation etc
741  if (doStudyIsol_)
742  studyIsolation(trkCollection, goodTks);
743  if (doTrkResTree_)
744  StudyTrkEbyP(trkCollection);
745 
746  std::pair<double, double> etaphi = etaPhiTrigger();
748  iEvent.getByToken(tok_l2cand_, L2cands);
749  if (!L2cands.isValid()) {
750  if (verbosity_ % 10 > 0)
751  edm::LogVerbatim("IsoTrack") << " trigCand is not valid ";
752  } else {
753  if (doMipCutTree_)
754  studyMipCut(trkCollection, L2cands);
755  }
756  if (!pixelTracksSources_.empty())
757  if (doChgIsolTree_ && !pixelTrackRefsHE_.empty())
758  chgIsolation(etaphi.first, etaphi.second, trkCollection, iEvent);
759  }
760  break;
761  }
762  }
763  }
764  h_PreL1->Fill(preL1);
765  h_PreHLT->Fill(preHLT);
766  h_Pre->Fill(prescale);
767  h_PreL1wt->Fill(preL1, mybxlumi);
768  h_PreHLTwt->Fill(preHLT, mybxlumi);
769 
770  // check if trigger names in (new) config
771  // edm::LogVerbatim("IsoTrack") << "changed " << changed_;
772  if (changed_) {
773  changed_ = false;
774  if ((verbosity_ / 10) % 10 > 1) {
775  edm::LogVerbatim("IsoTrack") << "New trigger menu found !!!";
776  const unsigned int n(hltConfig.size());
777  for (unsigned itrig = 0; itrig < triggerNames_.size(); itrig++) {
778  unsigned int triggerindx = hltConfig.triggerIndex(triggerNames_[itrig]);
779  if (triggerindx >= n)
780  edm::LogVerbatim("IsoTrack") << triggerNames_[itrig] << " " << triggerindx << " does not exist in"
781  << " the current menu";
782  else
783  edm::LogVerbatim("IsoTrack") << triggerNames_[itrig] << " " << triggerindx << " exists";
784  }
785  }
786  }
787  }
788  if (doTiming_)
790 }
size
Write out results.
std::pair< T, T > etaphi(T x, T y, T z)
Definition: FastMath.h:162
bool changed_
Definition: IsoTrig.cc:204
Log< level::Info, true > LogVerbatim
edm::EDGetTokenT< reco::IsolatedPixelTrackCandidateCollection > tok_l2cand_
Definition: IsoTrig.cc:185
edm::Handle< EcalRecHitCollection > endcapRecHitsHandle_
Definition: IsoTrig.cc:194
T const & getData(const ESGetToken< T, R > &iToken) const noexcept(false)
Definition: EventSetup.h:119
int32_t *__restrict__ iv
The single EDProduct to be saved for each event (AOD case)
Definition: TriggerEvent.h:25
void chgIsolation(double &etaTriggered, double &phiTriggered, edm::Handle< reco::TrackCollection > &trkCollection, const edm::Event &theEvent)
Definition: IsoTrig.cc:1825
const Point & position() const
position
Definition: BeamSpot.h:59
const bool doChgIsolTree_
Definition: IsoTrig.cc:156
edm::EDGetTokenT< LumiDetails > tok_lumi_
Definition: IsoTrig.cc:169
edm::Handle< HBHERecHitCollection > hbhe_
Definition: IsoTrig.cc:192
std::unordered_map< unsigned int, unsigned int > trigList_
Definition: IsoTrig.cc:202
std::vector< reco::TrackRef > pixelTrackRefsHB_
Definition: IsoTrig.cc:191
void studyIsolation(edm::Handle< reco::TrackCollection > &, std::vector< reco::TrackCollection::const_iterator > &)
Definition: IsoTrig.cc:1688
virtual GlobalVector inTesla(const GlobalPoint &gp) const =0
Field value ad specified global point, in Tesla.
const int verbosity_
Definition: IsoTrig.cc:157
std::unordered_map< unsigned int, const std::pair< double, double > > trigPreList_
Definition: IsoTrig.cc:203
edm::EDGetTokenT< EcalRecHitCollection > tok_EB_
Definition: IsoTrig.cc:176
T const * product() const
Definition: Handle.h:70
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
edm::Handle< EcalRecHitCollection > barrelRecHitsHandle_
Definition: IsoTrig.cc:193
edm::EDGetTokenT< reco::IsolatedPixelTrackCandidateCollection > tok_pixtk_
Definition: IsoTrig.cc:183
HLTConfigProvider const & hltConfigProvider() const
edm::Handle< reco::BeamSpot > beamSpotH_
Definition: IsoTrig.cc:195
std::vector< math::XYZTLorentzVector > vec_[3]
Definition: IsoTrig.cc:269
TH1I * h_HLT
Definition: IsoTrig.cc:257
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:19
std::pair< double, double > etaPhiTrigger()
Definition: IsoTrig.cc:2133
edm::EDGetTokenT< trigger::TriggerEvent > tok_trigEvt_
Definition: IsoTrig.cc:170
Single trigger physics object (e.g., an isolated muon)
Definition: TriggerObject.h:21
TH1D * h_L1ObjEnergy
Definition: IsoTrig.cc:259
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
const std::vector< edm::InputTag > pixelTracksSources_
Definition: IsoTrig.cc:154
void studyMipCut(edm::Handle< reco::TrackCollection > &trkCollection, edm::Handle< reco::IsolatedPixelTrackCandidateCollection > &L2cands)
Definition: IsoTrig.cc:1441
char const * label
HLTPrescaleProvider hltPrescaleProvider_
Definition: IsoTrig.cc:151
const bool doMipCutTree_
Definition: IsoTrig.cc:155
int iEvent
Definition: GenABIO.cc:224
edm::EDGetTokenT< edm::TriggerResults > tok_trigRes_
Definition: IsoTrig.cc:171
void studyTrigger(edm::Handle< reco::TrackCollection > &, std::vector< reco::TrackCollection::const_iterator > &)
Definition: IsoTrig.cc:1574
TH1I * h_nHLT
Definition: IsoTrig.cc:257
edm::ESGetToken< MagneticField, IdealMagneticFieldRecord > tok_magField_
Definition: IsoTrig.cc:189
edm::EDGetTokenT< reco::BeamSpot > tok_bs_
Definition: IsoTrig.cc:175
std::pair< TL1, THLT > prescaleValues(const edm::Event &iEvent, const edm::EventSetup &iSetup, const std::string &trigger)
Combined L1T (pair.first) and HLT (pair.second) prescales per HLT path.
edm::EDGetTokenT< reco::TrackCollection > tok_genTrack_
Definition: IsoTrig.cc:173
TH1I * h_Pre
Definition: IsoTrig.cc:258
TH1I * h_PreHLT
Definition: IsoTrig.cc:257
std::vector< edm::EDGetTokenT< reco::TrackCollection > > tok_pixtks_
Definition: IsoTrig.cc:186
TH1I * h_Filters
Definition: IsoTrig.cc:258
edm::EDGetTokenT< EcalRecHitCollection > tok_EE_
Definition: IsoTrig.cc:177
static std::string const triggerResults
Definition: EdmProvDump.cc:47
const CaloGeometry * geo_
Definition: IsoTrig.cc:199
TH1D * h_PreL1wt
Definition: IsoTrig.cc:259
float lumiValue(AlgoType algo, unsigned int bx) const
Definition: LumiDetails.cc:72
void studyTiming(const edm::Event &theEvent)
Definition: IsoTrig.cc:1330
const bool doTrkResTree_
Definition: IsoTrig.cc:156
std::vector< reco::TrackRef > pixelTrackRefsHE_
Definition: IsoTrig.cc:191
TH1I * h_PreL1
Definition: IsoTrig.cc:257
std::vector< TriggerObject > TriggerObjectCollection
collection of trigger physics objects (e.g., all isolated muons)
Definition: TriggerObject.h:75
edm::EDGetTokenT< reco::VertexCollection > tok_recVtx_
Definition: IsoTrig.cc:174
void StudyTrkEbyP(edm::Handle< reco::TrackCollection > &trkCollection)
Definition: IsoTrig.cc:1206
const bool doStudyIsol_
Definition: IsoTrig.cc:156
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:12
std::vector< size_type > Keys
edm::Handle< reco::VertexCollection > recVtxs_
Definition: IsoTrig.cc:196
bool isValid() const
Definition: HandleBase.h:70
edm::EDGetTokenT< trigger::TriggerFilterObjectWithRefs > tok_l1cand_
Definition: IsoTrig.cc:184
edm::EDGetTokenT< HBHERecHitCollection > tok_hbhe_
Definition: IsoTrig.cc:178
const MagneticField * bField_
Definition: IsoTrig.cc:198
const bool doTiming_
Definition: IsoTrig.cc:155
void clear(EGIsoObj &c)
Definition: egamma.h:82
Log< level::Warning, false > LogWarning
math::XYZPoint leadPV_
Definition: IsoTrig.cc:200
TH1I * h_nL3Objs
Definition: IsoTrig.cc:258
void getGoodTracks(const edm::Event &, edm::Handle< reco::TrackCollection > &)
Definition: IsoTrig.cc:1952
const std::vector< std::string > trigNames_
Definition: IsoTrig.cc:152
double bfVal_
Definition: IsoTrig.cc:163
TH1D * h_PreHLTwt
Definition: IsoTrig.cc:259
const bool doL2L3_
Definition: IsoTrig.cc:155
edm::ESGetToken< CaloGeometry, CaloGeometryRecord > tok_geom_
Definition: IsoTrig.cc:188

◆ beginJob()

void IsoTrig::beginJob ( )
overrideprivatevirtual

Reimplemented from edm::one::EDAnalyzerBase.

Definition at line 881 of file IsoTrig.cc.

References ChgIsolnTree_, doChgIsolTree_, doL2L3_, doMipCutTree_, doTiming_, doTrkResTree_, fs_, h_dEta, h_dEtaL1, h_dinvPt, h_dP, h_dPhi, h_dPhiL1, h_dPt, h_dRL1, h_eCalo, h_eHcal, h_eMaxNearP, h_eMip, h_eNeutIso, h_EnIn, h_EnOut, h_eta, h_etaCalibTracks, h_etaMipTracks, h_Filters, h_HLT, h_L1ObjEnergy, h_mindR, h_MipEnMatch, h_MipEnNoMatch, h_nHLT, h_nL3Objs, h_p, h_phi, h_Pre, h_PreHLT, h_PreHLTwt, h_PreL1, h_PreL1wt, h_pt, mps_fire::i, testProducerWithPsetDescEmpty_cfi::i1, testProducerWithPsetDescEmpty_cfi::i2, GCP_tree_cfg::levels, TFileService::make(), MipCutTree_, pLimits_, AlCaHLTBitMon_QueryRunRegistry::string, t_ECone, t_NFcandEmip, t_NFcandEta, t_NFcandP, t_NFcandPhi, t_NFcandPt, t_NFTrkcandEmip, t_NFTrkcandEta, t_NFTrkcandP, t_NFTrkcandPhi, t_NFTrkcandPt, t_NFTrkChgIsoFlag, t_NFTrkMinDP1, t_NFTrkMinDR, t_NFTrkMipFlag, t_NFTrkMissFlag, t_NFTrkNeuIsoFlag, t_NFTrkPropFlag, t_NFTrkPVFlag, t_NFTrkqltyFlag, t_NFTrkselTkFlag, t_nGoodTk, t_nPixCand, t_nPixSeed, t_PixcandEta, t_PixcandMaxP, t_PixcandP, t_PixcandPhi, t_PixcandPt, t_PixTrkcandEta, t_PixTrkcandMaxP, t_PixTrkcandP, t_PixTrkcandPhi, t_PixTrkcandPt, t_PixTrkcandselTk, t_timeL2Prod, t_TrkhCone, t_TrkMissFlag, t_TrkNuIsolFlag, t_TrkP, t_TrkPVFlag, t_TrkqltyFlag, t_TrkselTkFlag, TimingTree_, and TrkResTree_.

881  {
882  char hname[100], htit[100];
883  std::string levels[20] = {"L1", "L2", "L3", "Reco", "RecoMatch", "RecoNoMatch",
884  "L2Match", "L2NoMatch", "L3Match", "L3NoMatch", "HLTTrk", "HLTGoodTrk",
885  "HLTIsoTrk", "HLTMip", "HLTSelect", "nonHLTTrk", "nonHLTGoodTrk", "nonHLTIsoTrk",
886  "nonHLTMip", "nonHLTSelect"};
887  if (doTiming_) {
888  TimingTree_ = fs_->make<TTree>("TimingTree", "TimingTree");
889  t_timeL2Prod = new std::vector<double>();
890  t_nPixCand = new std::vector<int>();
891  t_nPixSeed = new std::vector<int>();
892  t_nGoodTk = new std::vector<int>();
893 
894  TimingTree_->Branch("t_timeL2Prod", "std::vector<double>", &t_timeL2Prod);
895  TimingTree_->Branch("t_nPixCand", "std::vector<int>", &t_nPixCand);
896  TimingTree_->Branch("t_nPixSeed", "std::vector<int>", &t_nPixSeed);
897  TimingTree_->Branch("t_nGoodTk", "std::vector<int>", &t_nGoodTk);
898  }
899  if (doTrkResTree_) {
900  TrkResTree_ = fs_->make<TTree>("TrkRestree", "TrkResTree");
901  t_TrkhCone = new std::vector<double>();
902  t_TrkP = new std::vector<double>();
903  t_TrkselTkFlag = new std::vector<bool>();
904  t_TrkqltyFlag = new std::vector<bool>();
905  t_TrkMissFlag = new std::vector<bool>();
906  t_TrkPVFlag = new std::vector<bool>();
907  t_TrkNuIsolFlag = new std::vector<bool>();
908 
909  TrkResTree_->Branch("t_TrkhCone", "std::vector<double>", &t_TrkhCone);
910  TrkResTree_->Branch("t_TrkP", "std::vector<double>", &t_TrkP);
911  TrkResTree_->Branch("t_TrkselTkFlag", "std::vector<bool>", &t_TrkselTkFlag);
912  TrkResTree_->Branch("t_TrkqltyFlag", "std::vector<bool>", &t_TrkqltyFlag);
913  TrkResTree_->Branch("t_TrkMissFlag", "std::vector<bool>", &t_TrkMissFlag);
914  TrkResTree_->Branch("t_TrkPVFlag", "std::vector<bool>", &t_TrkPVFlag);
915  TrkResTree_->Branch("t_TrkNuIsolFlag", "std::vector<bool>", &t_TrkNuIsolFlag);
916  }
917  if (doChgIsolTree_) {
918  ChgIsolnTree_ = fs_->make<TTree>("ChgIsolnTree", "ChgIsolnTree");
919  t_PixcandP = new std::vector<double>();
920  t_PixcandPt = new std::vector<double>();
921  t_PixcandEta = new std::vector<double>();
922  t_PixcandPhi = new std::vector<double>();
923  t_PixcandMaxP = new std::vector<std::vector<double>>();
924  t_PixTrkcandP = new std::vector<double>();
925  t_PixTrkcandPt = new std::vector<double>();
926  t_PixTrkcandEta = new std::vector<double>();
927  t_PixTrkcandPhi = new std::vector<double>();
928  t_PixTrkcandMaxP = new std::vector<double>();
929  t_PixTrkcandselTk = new std::vector<bool>();
930 
931  ChgIsolnTree_->Branch("t_PixcandP", "std::vector<double>", &t_PixcandP);
932  ChgIsolnTree_->Branch("t_PixcandPt", "std::vector<double>", &t_PixcandPt);
933  ChgIsolnTree_->Branch("t_PixcandEta", "std::vector<double>", &t_PixcandEta);
934  ChgIsolnTree_->Branch("t_PixcandPhi", "std::vector<double>", &t_PixcandPhi);
935  ChgIsolnTree_->Branch("t_PixcandMaxP", "std::vector<std::vector<double> >", &t_PixcandMaxP);
936  ChgIsolnTree_->Branch("t_PixTrkcandP", "std::vector<double>", &t_PixTrkcandP);
937  ChgIsolnTree_->Branch("t_PixTrkcandPt", "std::vector<double>", &t_PixTrkcandPt);
938  ChgIsolnTree_->Branch("t_PixTrkcandEta", "std::vector<double>", &t_PixTrkcandEta);
939  ChgIsolnTree_->Branch("t_PixTrkcandPhi", "std::vector<double>", &t_PixTrkcandPhi);
940  ChgIsolnTree_->Branch("t_PixTrkcandMaxP", "std::vector<double>", &t_PixTrkcandMaxP);
941  ChgIsolnTree_->Branch("t_PixTrkcandselTk", "std::vector<bool>", &t_PixTrkcandselTk);
942  }
943  if (doMipCutTree_) {
944  MipCutTree_ = fs_->make<TTree>("MipCutTree", "MipCutTree");
945  t_NFcandP = new std::vector<double>();
946  t_NFcandPt = new std::vector<double>();
947  t_NFcandEta = new std::vector<double>();
948  t_NFcandPhi = new std::vector<double>();
949  t_NFcandEmip = new std::vector<double>();
950  t_NFTrkcandP = new std::vector<double>();
951  t_NFTrkcandPt = new std::vector<double>();
952  t_NFTrkcandEta = new std::vector<double>();
953  t_NFTrkcandPhi = new std::vector<double>();
954  t_NFTrkcandEmip = new std::vector<double>();
955  t_NFTrkMinDR = new std::vector<double>();
956  t_NFTrkMinDP1 = new std::vector<double>();
957  t_NFTrkselTkFlag = new std::vector<bool>();
958  t_NFTrkqltyFlag = new std::vector<bool>();
959  t_NFTrkMissFlag = new std::vector<bool>();
960  t_NFTrkPVFlag = new std::vector<bool>();
961  t_NFTrkPropFlag = new std::vector<bool>();
962  t_NFTrkChgIsoFlag = new std::vector<bool>();
963  t_NFTrkNeuIsoFlag = new std::vector<bool>();
964  t_NFTrkMipFlag = new std::vector<bool>();
965  t_ECone = new std::vector<double>();
966 
967  MipCutTree_->Branch("t_NFcandP", "std::vector<double>", &t_NFcandP);
968  MipCutTree_->Branch("t_NFcandPt", "std::vector<double>", &t_NFcandPt);
969  MipCutTree_->Branch("t_NFcandEta", "std::vector<double>", &t_NFcandEta);
970  MipCutTree_->Branch("t_NFcandPhi", "std::vector<double>", &t_NFcandPhi);
971  MipCutTree_->Branch("t_NFcandEmip", "std::vector<double>", &t_NFcandEmip);
972  MipCutTree_->Branch("t_NFTrkcandP", "std::vector<double>", &t_NFTrkcandP);
973  MipCutTree_->Branch("t_NFTrkcandPt", "std::vector<double>", &t_NFTrkcandPt);
974  MipCutTree_->Branch("t_NFTrkcandEta", "std::vector<double>", &t_NFTrkcandEta);
975  MipCutTree_->Branch("t_NFTrkcandPhi", "std::vector<double>", &t_NFTrkcandPhi);
976  MipCutTree_->Branch("t_NFTrkcandEmip", "std::vector<double>", &t_NFTrkcandEmip);
977  MipCutTree_->Branch("t_NFTrkMinDR", "std::vector<double>", &t_NFTrkMinDR);
978  MipCutTree_->Branch("t_NFTrkMinDP1", "std::vector<double>", &t_NFTrkMinDP1);
979  MipCutTree_->Branch("t_NFTrkselTkFlag", "std::vector<bool>", &t_NFTrkselTkFlag);
980  MipCutTree_->Branch("t_NFTrkqltyFlag", "std::vector<bool>", &t_NFTrkqltyFlag);
981  MipCutTree_->Branch("t_NFTrkMissFlag", "std::vector<bool>", &t_NFTrkMissFlag);
982  MipCutTree_->Branch("t_NFTrkPVFlag", "std::vector<bool>", &t_NFTrkPVFlag);
983  MipCutTree_->Branch("t_NFTrkPropFlag", "std::vector<bool>", &t_NFTrkPropFlag);
984  MipCutTree_->Branch("t_NFTrkChgIsoFlag", "std::vector<bool>", &t_NFTrkChgIsoFlag);
985  MipCutTree_->Branch("t_NFTrkNeuIsoFlag", "std::vector<bool>", &t_NFTrkNeuIsoFlag);
986  MipCutTree_->Branch("t_NFTrkMipFlag", "std::vector<bool>", &t_NFTrkMipFlag);
987  MipCutTree_->Branch("t_ECone", "std::vector<double>", &t_ECone);
988  }
989  h_Filters = fs_->make<TH1I>("h_Filters", "Filter Accepts", 10, 0, 10);
990  std::string FilterNames[7] = {"hltL1sL1SingleJet68",
991  "hltIsolPixelTrackL2FilterHE",
992  "ecalIsolPixelTrackFilterHE",
993  "hltIsolPixelTrackL3FilterHE",
994  "hltIsolPixelTrackL2FilterHB",
995  "ecalIsolPixelTrackFilterHB",
996  "hltIsolPixelTrackL3FilterHB"};
997  for (int i = 0; i < 7; i++) {
998  h_Filters->GetXaxis()->SetBinLabel(i + 1, FilterNames[i].c_str());
999  }
1000 
1001  h_nHLT = fs_->make<TH1I>("h_nHLT", "Size of trigger Names", 1000, 1, 1000);
1002  h_HLT = fs_->make<TH1I>("h_HLT", "HLT accept", 3, -1, 2);
1003  h_PreL1 = fs_->make<TH1I>("h_PreL1", "L1 Prescale", 500, 0, 500);
1004  h_PreHLT = fs_->make<TH1I>("h_PreHLT", "HLT Prescale", 50, 0, 50);
1005  h_Pre = fs_->make<TH1I>("h_Pre", "Prescale", 3000, 0, 3000);
1006 
1007  h_PreL1wt = fs_->make<TH1D>("h_PreL1wt", "Weighted L1 Prescale", 500, 0, 500);
1008  h_PreHLTwt = fs_->make<TH1D>("h_PreHLTwt", "Weighted HLT Prescale", 500, 0, 100);
1009  h_L1ObjEnergy = fs_->make<TH1D>("h_L1ObjEnergy", "Energy of L1Object", 500, 0.0, 500.0);
1010 
1011  h_EnIn = fs_->make<TH1D>("h_EnInEcal", "EnergyIn Ecal", 200, 0.0, 20.0);
1012  h_EnOut = fs_->make<TH1D>("h_EnOutEcal", "EnergyOut Ecal", 200, 0.0, 20.0);
1013  h_MipEnMatch =
1014  fs_->make<TH2D>("h_MipEnMatch", "MipEn: HLT level vs Reco Level (Matched)", 200, 0.0, 20.0, 200, 0.0, 20.0);
1015  h_MipEnNoMatch = fs_->make<TH2D>(
1016  "h_MipEnNoMatch", "MipEn: HLT level vs Reco Level (No Match Found)", 200, 0.0, 20.0, 200, 0.0, 20.0);
1017 
1018  if (doL2L3_) {
1019  h_nL3Objs = fs_->make<TH1I>("h_nL3Objs", "Number of L3 objects", 10, 0, 10);
1020 
1021  std::string pairs[9] = {"L2L3",
1022  "L2L3Match",
1023  "L2L3NoMatch",
1024  "L3Reco",
1025  "L3RecoMatch",
1026  "L3RecoNoMatch",
1027  "NewFilterReco",
1028  "NewFilterRecoMatch",
1029  "NewFilterRecoNoMatch"};
1030  for (int ipair = 0; ipair < 9; ipair++) {
1031  sprintf(hname, "h_dEta%s", pairs[ipair].c_str());
1032  sprintf(htit, "#Delta#eta for %s", pairs[ipair].c_str());
1033  h_dEta[ipair] = fs_->make<TH1D>(hname, htit, 200, -10.0, 10.0);
1034  h_dEta[ipair]->GetXaxis()->SetTitle("d#eta");
1035 
1036  sprintf(hname, "h_dPhi%s", pairs[ipair].c_str());
1037  sprintf(htit, "#Delta#phi for %s", pairs[ipair].c_str());
1038  h_dPhi[ipair] = fs_->make<TH1D>(hname, htit, 140, -7.0, 7.0);
1039  h_dPhi[ipair]->GetXaxis()->SetTitle("d#phi");
1040 
1041  sprintf(hname, "h_dPt%s", pairs[ipair].c_str());
1042  sprintf(htit, "#Delta dp_{T} for %s objects", pairs[ipair].c_str());
1043  h_dPt[ipair] = fs_->make<TH1D>(hname, htit, 400, -200.0, 200.0);
1044  h_dPt[ipair]->GetXaxis()->SetTitle("dp_{T} (GeV)");
1045 
1046  sprintf(hname, "h_dP%s", pairs[ipair].c_str());
1047  sprintf(htit, "#Delta p for %s objects", pairs[ipair].c_str());
1048  h_dP[ipair] = fs_->make<TH1D>(hname, htit, 400, -200.0, 200.0);
1049  h_dP[ipair]->GetXaxis()->SetTitle("dP (GeV)");
1050 
1051  sprintf(hname, "h_dinvPt%s", pairs[ipair].c_str());
1052  sprintf(htit, "#Delta (1/p_{T}) for %s objects", pairs[ipair].c_str());
1053  h_dinvPt[ipair] = fs_->make<TH1D>(hname, htit, 500, -0.4, 0.1);
1054  h_dinvPt[ipair]->GetXaxis()->SetTitle("d(1/p_{T})");
1055  sprintf(hname, "h_mindR%s", pairs[ipair].c_str());
1056  sprintf(htit, "min(#Delta R) for %s objects", pairs[ipair].c_str());
1057  h_mindR[ipair] = fs_->make<TH1D>(hname, htit, 500, 0.0, 1.0);
1058  h_mindR[ipair]->GetXaxis()->SetTitle("dR");
1059  }
1060 
1061  for (int lvl = 0; lvl < 2; lvl++) {
1062  sprintf(hname, "h_dEtaL1%s", levels[lvl + 1].c_str());
1063  sprintf(htit, "#Delta#eta for L1 and %s objects", levels[lvl + 1].c_str());
1064  h_dEtaL1[lvl] = fs_->make<TH1D>(hname, htit, 400, -10.0, 10.0);
1065 
1066  sprintf(hname, "h_dPhiL1%s", levels[lvl + 1].c_str());
1067  sprintf(htit, "#Delta#phi for L1 and %s objects", levels[lvl + 1].c_str());
1068  h_dPhiL1[lvl] = fs_->make<TH1D>(hname, htit, 280, -7.0, 7.0);
1069 
1070  sprintf(hname, "h_dRL1%s", levels[lvl + 1].c_str());
1071  sprintf(htit, "#Delta R for L1 and %s objects", levels[lvl + 1].c_str());
1072  h_dRL1[lvl] = fs_->make<TH1D>(hname, htit, 100, 0.0, 10.0);
1073  }
1074  }
1075 
1076  int levmin = (doL2L3_ ? 0 : 10);
1077  for (int ilevel = levmin; ilevel < 20; ilevel++) {
1078  sprintf(hname, "h_p%s", levels[ilevel].c_str());
1079  sprintf(htit, "p for %s objects", levels[ilevel].c_str());
1080  h_p[ilevel] = fs_->make<TH1D>(hname, htit, 100, 0.0, 500.0);
1081  h_p[ilevel]->GetXaxis()->SetTitle("p (GeV)");
1082 
1083  sprintf(hname, "h_pt%s", levels[ilevel].c_str());
1084  sprintf(htit, "p_{T} for %s objects", levels[ilevel].c_str());
1085  h_pt[ilevel] = fs_->make<TH1D>(hname, htit, 100, 0.0, 500.0);
1086  h_pt[ilevel]->GetXaxis()->SetTitle("p_{T} (GeV)");
1087 
1088  sprintf(hname, "h_eta%s", levels[ilevel].c_str());
1089  sprintf(htit, "#eta for %s objects", levels[ilevel].c_str());
1090  h_eta[ilevel] = fs_->make<TH1D>(hname, htit, 100, -5.0, 5.0);
1091  h_eta[ilevel]->GetXaxis()->SetTitle("#eta");
1092 
1093  sprintf(hname, "h_phi%s", levels[ilevel].c_str());
1094  sprintf(htit, "#phi for %s objects", levels[ilevel].c_str());
1095  h_phi[ilevel] = fs_->make<TH1D>(hname, htit, 70, -3.5, 3.50);
1096  h_phi[ilevel]->GetXaxis()->SetTitle("#phi");
1097  }
1098 
1099  std::string cuts[2] = {"HLTMatched", "HLTNotMatched"};
1100  std::string cuts2[2] = {"All", "Away from L1"};
1101  for (int icut = 0; icut < 2; icut++) {
1102  sprintf(hname, "h_eMip%s", cuts[icut].c_str());
1103  sprintf(htit, "eMip for %s tracks", cuts[icut].c_str());
1104  h_eMip[icut] = fs_->make<TH1D>(hname, htit, 200, 0.0, 10.0);
1105  h_eMip[icut]->GetXaxis()->SetTitle("E_{Mip} (GeV)");
1106 
1107  sprintf(hname, "h_eMaxNearP%s", cuts[icut].c_str());
1108  sprintf(htit, "eMaxNearP for %s tracks", cuts[icut].c_str());
1109  h_eMaxNearP[icut] = fs_->make<TH1D>(hname, htit, 240, -2.0, 10.0);
1110  h_eMaxNearP[icut]->GetXaxis()->SetTitle("E_{MaxNearP} (GeV)");
1111 
1112  sprintf(hname, "h_eNeutIso%s", cuts[icut].c_str());
1113  sprintf(htit, "eNeutIso for %s ", cuts[icut].c_str());
1114  h_eNeutIso[icut] = fs_->make<TH1D>(hname, htit, 200, 0.0, 10.0);
1115  h_eNeutIso[icut]->GetXaxis()->SetTitle("E_{NeutIso} (GeV)");
1116 
1117  for (int kcut = 0; kcut < 2; ++kcut) {
1118  for (int lim = 0; lim < 5; ++lim) {
1119  sprintf(hname, "h_etaCalibTracks%sCut%dLim%d", cuts[icut].c_str(), kcut, lim);
1120  sprintf(htit,
1121  "#eta for %s isolated MIP tracks (%4.1f < p < %5.1f Gev/c %s)",
1122  cuts[icut].c_str(),
1123  pLimits_[lim],
1124  pLimits_[lim + 1],
1125  cuts2[kcut].c_str());
1126  h_etaCalibTracks[lim][icut][kcut] = fs_->make<TH1D>(hname, htit, 60, -30.0, 30.0);
1127  h_etaCalibTracks[lim][icut][kcut]->GetXaxis()->SetTitle("i#eta");
1128 
1129  sprintf(hname, "h_etaMipTracks%sCut%dLim%d", cuts[icut].c_str(), kcut, lim);
1130  sprintf(htit,
1131  "#eta for %s charge isolated MIP tracks (%4.1f < p < %5.1f Gev/c %s)",
1132  cuts[icut].c_str(),
1133  pLimits_[lim],
1134  pLimits_[lim + 1],
1135  cuts2[kcut].c_str());
1136  h_etaMipTracks[lim][icut][kcut] = fs_->make<TH1D>(hname, htit, 60, -30.0, 30.0);
1137  h_etaMipTracks[lim][icut][kcut]->GetXaxis()->SetTitle("i#eta");
1138  }
1139  }
1140  }
1141 
1142  std::string ecut1[3] = {"all", "HLTMatched", "HLTNotMatched"};
1143  std::string ecut2[2] = {"without", "with"};
1144  int etac[48] = {-1, -2, -3, -4, -5, -6, -7, -8, -9, -10, -11, -12, -13, -14, -15, -16,
1145  -17, -18, -19, -20, -21, -22, -23, -24, 1, 2, 3, 4, 5, 6, 7, 8,
1146  9, 10, 11, 12, 13, 14, 15, 16, 17, 18, 19, 20, 21, 22, 23, 24};
1147  for (int icut = 0; icut < 6; icut++) {
1148  // int i1 = (icut>3 ? 1 : 0);
1149  int i1 = (icut > 2 ? 1 : 0);
1150  int i2 = icut - i1 * 3;
1151  for (int kcut = 0; kcut < 48; kcut++) {
1152  for (int lim = 0; lim < 5; ++lim) {
1153  sprintf(hname, "h_eta%dEnHcal%s%s%d", etac[kcut], ecut1[i2].c_str(), ecut2[i1].c_str(), lim);
1154  sprintf(htit,
1155  "HCAL energy for #eta=%d for %s tracks (p=%4.1f:%5.1f Gev) %s neutral isolation",
1156  etac[kcut],
1157  ecut1[i2].c_str(),
1158  pLimits_[lim],
1159  pLimits_[lim + 1],
1160  ecut2[i1].c_str());
1161  h_eHcal[lim][icut][kcut] = fs_->make<TH1D>(hname, htit, 750, 0.0, 150.0);
1162  h_eHcal[lim][icut][kcut]->GetXaxis()->SetTitle("Energy (GeV)");
1163  sprintf(hname, "h_eta%dEnCalo%s%s%d", etac[kcut], ecut1[i2].c_str(), ecut2[i1].c_str(), lim);
1164  sprintf(htit,
1165  "Calorimter energy for #eta=%d for %s tracks (p=%4.1f:%5.1f Gev) %s neutral isolation",
1166  etac[kcut],
1167  ecut1[i2].c_str(),
1168  pLimits_[lim],
1169  pLimits_[lim + 1],
1170  ecut2[i1].c_str());
1171  h_eCalo[lim][icut][kcut] = fs_->make<TH1D>(hname, htit, 750, 0.0, 150.0);
1172  h_eCalo[lim][icut][kcut]->GetXaxis()->SetTitle("Energy (GeV)");
1173  }
1174  }
1175  }
1176 }
std::vector< bool > * t_NFTrkPVFlag
Definition: IsoTrig.cc:248
std::vector< double > * t_PixTrkcandPhi
Definition: IsoTrig.cc:229
std::vector< double > * t_PixTrkcandP
Definition: IsoTrig.cc:226
edm::Service< TFileService > fs_
Definition: IsoTrig.cc:206
std::vector< double > * t_NFTrkMinDR
Definition: IsoTrig.cc:243
std::vector< bool > * t_NFTrkMissFlag
Definition: IsoTrig.cc:247
const bool doChgIsolTree_
Definition: IsoTrig.cc:156
TH1D * h_phi[20]
Definition: IsoTrig.cc:260
std::vector< bool > * t_PixTrkcandselTk
Definition: IsoTrig.cc:231
TH1D * h_EnIn
Definition: IsoTrig.cc:255
TH1D * h_dEta[9]
Definition: IsoTrig.cc:262
std::vector< double > * t_NFTrkcandEta
Definition: IsoTrig.cc:240
std::vector< double > * t_NFcandP
Definition: IsoTrig.cc:233
TH1D * h_dEtaL1[2]
Definition: IsoTrig.cc:261
std::vector< int > * t_nPixSeed
Definition: IsoTrig.cc:210
std::vector< double > * t_TrkhCone
Definition: IsoTrig.cc:213
std::vector< bool > * t_NFTrkqltyFlag
Definition: IsoTrig.cc:246
std::vector< double > * t_PixTrkcandMaxP
Definition: IsoTrig.cc:230
std::vector< bool > * t_NFTrkselTkFlag
Definition: IsoTrig.cc:245
TH1I * h_HLT
Definition: IsoTrig.cc:257
std::vector< double > * t_PixcandP
Definition: IsoTrig.cc:221
TH1D * h_dP[9]
Definition: IsoTrig.cc:262
std::vector< bool > * t_NFTrkMipFlag
Definition: IsoTrig.cc:252
std::vector< double > * t_NFTrkMinDP1
Definition: IsoTrig.cc:244
TH1D * h_EnOut
Definition: IsoTrig.cc:255
TH1D * h_dPhiL1[2]
Definition: IsoTrig.cc:261
TH1D * h_L1ObjEnergy
Definition: IsoTrig.cc:259
const bool doMipCutTree_
Definition: IsoTrig.cc:155
TH1D * h_dPhi[9]
Definition: IsoTrig.cc:262
std::vector< double > * t_NFTrkcandP
Definition: IsoTrig.cc:238
std::vector< bool > * t_TrkNuIsolFlag
Definition: IsoTrig.cc:219
TH1I * h_nHLT
Definition: IsoTrig.cc:257
std::vector< bool > * t_TrkPVFlag
Definition: IsoTrig.cc:218
std::vector< double > * t_ECone
Definition: IsoTrig.cc:253
TH1I * h_Pre
Definition: IsoTrig.cc:258
TH1I * h_PreHLT
Definition: IsoTrig.cc:257
TH1D * h_dinvPt[9]
Definition: IsoTrig.cc:263
std::vector< bool > * t_NFTrkChgIsoFlag
Definition: IsoTrig.cc:250
std::vector< double > * t_TrkP
Definition: IsoTrig.cc:214
TH1D * h_eta[20]
Definition: IsoTrig.cc:260
TH1I * h_Filters
Definition: IsoTrig.cc:258
std::vector< double > * t_NFcandEta
Definition: IsoTrig.cc:235
std::vector< double > * t_timeL2Prod
Definition: IsoTrig.cc:208
TH1D * h_eHcal[5][6][48]
Definition: IsoTrig.cc:266
std::vector< double > * t_PixcandPt
Definition: IsoTrig.cc:222
TH1D * h_PreL1wt
Definition: IsoTrig.cc:259
std::vector< double > * t_NFcandEmip
Definition: IsoTrig.cc:237
TH1D * h_eMaxNearP[2]
Definition: IsoTrig.cc:264
const bool doTrkResTree_
Definition: IsoTrig.cc:156
std::vector< bool > * t_NFTrkPropFlag
Definition: IsoTrig.cc:249
std::vector< double > * t_NFTrkcandPhi
Definition: IsoTrig.cc:241
TH2D * h_MipEnMatch
Definition: IsoTrig.cc:256
TH1D * h_p[20]
Definition: IsoTrig.cc:260
TH1D * h_eNeutIso[2]
Definition: IsoTrig.cc:264
TH1I * h_PreL1
Definition: IsoTrig.cc:257
std::vector< bool > * t_TrkMissFlag
Definition: IsoTrig.cc:217
TTree * ChgIsolnTree_
Definition: IsoTrig.cc:207
std::vector< int > * t_nPixCand
Definition: IsoTrig.cc:209
std::vector< double > * t_NFTrkcandPt
Definition: IsoTrig.cc:239
TH1D * h_eCalo[5][6][48]
Definition: IsoTrig.cc:266
std::vector< double > * t_PixTrkcandPt
Definition: IsoTrig.cc:227
std::vector< double > * t_NFcandPt
Definition: IsoTrig.cc:234
TH1D * h_pt[20]
Definition: IsoTrig.cc:260
std::vector< bool > * t_TrkqltyFlag
Definition: IsoTrig.cc:216
TH1D * h_etaMipTracks[5][2][2]
Definition: IsoTrig.cc:265
std::vector< std::vector< double > > * t_PixcandMaxP
Definition: IsoTrig.cc:225
std::vector< double > * t_NFTrkcandEmip
Definition: IsoTrig.cc:242
TTree * MipCutTree_
Definition: IsoTrig.cc:207
TH1D * h_mindR[9]
Definition: IsoTrig.cc:263
std::vector< double > * t_PixcandEta
Definition: IsoTrig.cc:223
TTree * TrkResTree_
Definition: IsoTrig.cc:207
TH1D * h_dPt[9]
Definition: IsoTrig.cc:262
TH2D * h_MipEnNoMatch
Definition: IsoTrig.cc:256
std::vector< bool > * t_NFTrkNeuIsoFlag
Definition: IsoTrig.cc:251
T * make(const Args &...args) const
make new ROOT object
Definition: TFileService.h:64
std::vector< double > * t_PixcandPhi
Definition: IsoTrig.cc:224
const bool doTiming_
Definition: IsoTrig.cc:155
std::vector< double > * t_PixTrkcandEta
Definition: IsoTrig.cc:228
std::vector< int > * t_nGoodTk
Definition: IsoTrig.cc:211
TH1I * h_nL3Objs
Definition: IsoTrig.cc:258
TH1D * h_dRL1[2]
Definition: IsoTrig.cc:261
double pLimits_[6]
Definition: IsoTrig.cc:205
TH1D * h_etaCalibTracks[5][2][2]
Definition: IsoTrig.cc:265
std::vector< bool > * t_TrkselTkFlag
Definition: IsoTrig.cc:215
TH1D * h_PreHLTwt
Definition: IsoTrig.cc:259
TTree * TimingTree_
Definition: IsoTrig.cc:207
const bool doL2L3_
Definition: IsoTrig.cc:155
TH1D * h_eMip[2]
Definition: IsoTrig.cc:263
std::vector< double > * t_NFcandPhi
Definition: IsoTrig.cc:236

◆ beginRun()

void IsoTrig::beginRun ( edm::Run const &  iRun,
edm::EventSetup const &  iSetup 
)
overrideprivate

Definition at line 1201 of file IsoTrig.cc.

References changed_, hltPrescaleProvider_, HLTPrescaleProvider::init(), processName_, and edm::RunBase::run().

1201  {
1202  edm::LogWarning("IsoTrack") << "Run " << iRun.run() << " hltconfig.init "
1203  << hltPrescaleProvider_.init(iRun, iSetup, processName_, changed_);
1204 }
bool changed_
Definition: IsoTrig.cc:204
HLTPrescaleProvider hltPrescaleProvider_
Definition: IsoTrig.cc:151
const std::string processName_
Definition: IsoTrig.cc:162
Log< level::Warning, false > LogWarning
bool init(const edm::Run &iRun, const edm::EventSetup &iSetup, const std::string &processName, bool &changed)

◆ chgIsolation()

void IsoTrig::chgIsolation ( double &  etaTriggered,
double &  phiTriggered,
edm::Handle< reco::TrackCollection > &  trkCollection,
const edm::Event theEvent 
)
private

Definition at line 1825 of file IsoTrig.cc.

References a_charIsoR_, bField_, ALCARECOTkAlJpsiMuMu_cff::charge, spr::chargeIsolationCone(), ChgIsolnTree_, clearChgIsolnTreeVectors(), PbPb_ZMuSkimMuonDPG_cff::deltaR, l1ctLayer1_cff::dr, dR(), PVValHelper::dxy, PVValHelper::dz, PVValHelper::eta, geo_, getDistInCM(), GetEtaPhiAtEcal(), spr::goodTrack(), mps_fire::i, gpuVertexFinder::iv, dqmiolumiharvest::j, dqmdumpme::k, MainPageGenerator::l, leadPV_, RecoMuonValidator_cfi::maxP, minPTrackValue_, beamSpotPI::nTracks, AlCaHLTBitMon_ParallelJobs::p, reco::TrackBase::p(), phi, pixelIsolationConeSizeAtEC_, pixelTrackRefsHE_, position, prelimCone_, spr::propagateCALO(), DiDispStaMuonMonitor_cfi::pt, pushChgIsolnTreeVecs(), multPhiCorr_741_25nsDY_cfi::px, reco::TrackBase::px(), multPhiCorr_741_25nsDY_cfi::py, reco::TrackBase::py(), reco::TrackBase::pz(), dttmaxenums::R, recVtxs_, edm::second(), selectionParameters_, tauUnbiasCone_, theTrackQuality_, verbosity_, vtxCutIsol_, vtxCutSeed_, and z.

Referenced by analyze().

1828  {
1830  if (verbosity_ % 10 > 0)
1831  edm::LogVerbatim("IsoTrack") << "Inside chgIsolation() with eta/phi Triggered: " << etaTriggered << "/"
1832  << phiTriggered;
1833  std::vector<double> maxP;
1834 
1835  std::vector<spr::propagatedTrackDirection>::const_iterator trkDetItr;
1836  std::vector<spr::propagatedTrackDirection> trkCaloDirections1;
1837  spr::propagateCALO(trkCollection, geo_, bField_, theTrackQuality_, trkCaloDirections1, ((verbosity_ / 100) % 10 > 2));
1838  if (verbosity_ % 10 > 0)
1839  edm::LogVerbatim("IsoTrack") << "Propagated TrkCollection";
1840  for (unsigned int k = 0; k < pixelIsolationConeSizeAtEC_.size(); ++k)
1841  maxP.push_back(0);
1842  unsigned i = pixelTrackRefsHE_.size();
1843  std::vector<std::pair<unsigned int, std::pair<double, double>>> VecSeedsatEC;
1844  //loop to select isolated tracks
1845  for (unsigned iS = 0; iS < pixelTrackRefsHE_.size(); iS++) {
1846  if (pixelTrackRefsHE_[iS]->p() > minPTrackValue_) {
1847  bool vtxMatch = false;
1848  //associate to vertex (in Z)
1849  unsigned int ivSel = recVtxs_->size();
1850  double minDZ = 100;
1851  for (unsigned int iv = 0; iv < recVtxs_->size(); ++iv) {
1852  if (fabs(pixelTrackRefsHE_[iS]->dz((*recVtxs_)[iv].position())) < minDZ) {
1853  minDZ = fabs(pixelTrackRefsHE_[iS]->dz((*recVtxs_)[iv].position()));
1854  ivSel = iv;
1855  }
1856  }
1857  //cut on dYX:
1858  if (ivSel == recVtxs_->size()) {
1859  vtxMatch = true;
1860  } else if (fabs(pixelTrackRefsHE_[iS]->dxy((*recVtxs_)[ivSel].position())) < vtxCutSeed_) {
1861  vtxMatch = true;
1862  }
1863  //select tracks not matched to triggered L1 jet
1864  double R = deltaR(etaTriggered, phiTriggered, pixelTrackRefsHE_[iS]->eta(), pixelTrackRefsHE_[iS]->phi());
1865  if (R > tauUnbiasCone_ && vtxMatch) {
1866  //propagate seed track to ECAL surface:
1867  std::pair<double, double> seedCooAtEC;
1868  // in case vertex is found:
1869  if (minDZ != 100)
1870  seedCooAtEC = GetEtaPhiAtEcal(pixelTrackRefsHE_[iS]->eta(),
1871  pixelTrackRefsHE_[iS]->phi(),
1872  pixelTrackRefsHE_[iS]->pt(),
1873  pixelTrackRefsHE_[iS]->charge(),
1874  (*recVtxs_)[ivSel].z());
1875  //in case vertex is not found:
1876  else
1877  seedCooAtEC = GetEtaPhiAtEcal(pixelTrackRefsHE_[iS]->eta(),
1878  pixelTrackRefsHE_[iS]->phi(),
1879  pixelTrackRefsHE_[iS]->pt(),
1880  pixelTrackRefsHE_[iS]->charge(),
1881  0);
1882  VecSeedsatEC.push_back(std::make_pair(iS, seedCooAtEC));
1883  }
1884  }
1885  }
1886  for (unsigned int l = 0; l < VecSeedsatEC.size(); l++) {
1887  unsigned int iSeed = VecSeedsatEC[l].first;
1889  pixelTrackRefsHE_[iSeed]->py(),
1890  pixelTrackRefsHE_[iSeed]->pz(),
1891  pixelTrackRefsHE_[iSeed]->p());
1892 
1893  for (unsigned int j = 0; j < VecSeedsatEC.size(); j++) {
1894  unsigned int iSurr = VecSeedsatEC[j].first;
1895  if (iSeed != iSurr) {
1896  //define preliminary cone around seed track impact point from which tracks will be extrapolated:
1897  // edm::Ref<reco::IsolatedPixelTrackCandidateCollection> cand2ref =
1898  // edm::Ref<reco::IsolatedPixelTrackCandidateCollection>(L2cands, iSurr);
1899  if (deltaR(pixelTrackRefsHE_[iSeed]->eta(),
1900  pixelTrackRefsHE_[iSeed]->phi(),
1901  pixelTrackRefsHE_[iSurr]->eta(),
1902  pixelTrackRefsHE_[iSurr]->phi()) < prelimCone_) {
1903  unsigned int ivSel = recVtxs_->size();
1904  double minDZ2 = 100;
1905  for (unsigned int iv = 0; iv < recVtxs_->size(); ++iv) {
1906  if (fabs(pixelTrackRefsHE_[iSurr]->dz((*recVtxs_)[iv].position())) < minDZ2) {
1907  minDZ2 = fabs(pixelTrackRefsHE_[iSurr]->dz((*recVtxs_)[iv].position()));
1908  ivSel = iv;
1909  }
1910  }
1911  //cut ot dXY:
1912  if (minDZ2 == 100 || fabs(pixelTrackRefsHE_[iSurr]->dxy((*recVtxs_)[ivSel].position())) < vtxCutIsol_) {
1913  //calculate distance at ECAL surface and update isolation:
1914  double dist = getDistInCM(VecSeedsatEC[i].second.first,
1915  VecSeedsatEC[i].second.second,
1916  VecSeedsatEC[j].second.first,
1917  VecSeedsatEC[j].second.second);
1918  for (unsigned int k = 0; k < pixelIsolationConeSizeAtEC_.size(); ++k) {
1919  if (dist < pixelIsolationConeSizeAtEC_[k]) {
1920  if (pixelTrackRefsHE_[iSurr]->p() > maxP[k])
1921  maxP[k] = pixelTrackRefsHE_[iSurr]->p();
1922  }
1923  }
1924  }
1925  }
1926  }
1927  }
1928 
1929  double conehmaxNearP = -1;
1930  bool selectTk = false;
1931  double mindR = 999.9;
1932  int nTracks = 0;
1933  math::XYZTLorentzVector mindRvec;
1934  for (trkDetItr = trkCaloDirections1.begin(); trkDetItr != trkCaloDirections1.end(); trkDetItr++, nTracks++) {
1935  int nNearTRKs = 0;
1936  const reco::Track *pTrack = &(*(trkDetItr->trkItr));
1937  math::XYZTLorentzVector v2(pTrack->px(), pTrack->py(), pTrack->pz(), pTrack->p());
1938  double dr = dR(v1, v2);
1939  if (dr < mindR) {
1940  selectTk = spr::goodTrack(pTrack, leadPV_, selectionParameters_, ((verbosity_ / 100) % 10 > 1));
1941  conehmaxNearP = spr::chargeIsolationCone(
1942  nTracks, trkCaloDirections1, a_charIsoR_, nNearTRKs, ((verbosity_ / 100) % 10 > 1));
1943  mindR = dr;
1944  mindRvec = v2;
1945  }
1946  }
1947  pushChgIsolnTreeVecs(v1, mindRvec, maxP, conehmaxNearP, selectTk);
1948  }
1949  ChgIsolnTree_->Fill();
1950 }
Log< level::Info, true > LogVerbatim
std::string theTrackQuality_
Definition: IsoTrig.cc:161
std::vector< spr::propagatedTrackID > propagateCALO(edm::Handle< reco::TrackCollection > &trkCollection, const CaloGeometry *geo, const MagneticField *bField, const std::string &theTrackQuality, bool debug=false)
int32_t *__restrict__ iv
const double a_charIsoR_
Definition: IsoTrig.cc:165
double px() const
x coordinate of momentum vector
Definition: TrackBase.h:640
double p() const
momentum vector magnitude
Definition: TrackBase.h:631
const int verbosity_
Definition: IsoTrig.cc:157
double py() const
y coordinate of momentum vector
Definition: TrackBase.h:643
std::pair< double, double > GetEtaPhiAtEcal(double etaIP, double phiIP, double pT, int charge, double vtxZ)
Definition: IsoTrig.cc:2149
const double minPTrackValue_
Definition: IsoTrig.cc:159
double chargeIsolationCone(unsigned int trkIndex, std::vector< spr::propagatedTrackDirection > &trkDirs, double dR, int &nNearTRKs, bool debug=false)
const double tauUnbiasCone_
Definition: IsoTrig.cc:160
U second(std::pair< T, U > const &p)
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
bool goodTrack(const reco::Track *pTrack, math::XYZPoint leadPV, trackSelectionParameters parameters, bool debug=false)
const double prelimCone_
Definition: IsoTrig.cc:160
spr::trackSelectionParameters selectionParameters_
Definition: IsoTrig.cc:164
const CaloGeometry * geo_
Definition: IsoTrig.cc:199
void clearChgIsolnTreeVectors()
Definition: IsoTrig.cc:792
std::vector< reco::TrackRef > pixelTrackRefsHE_
Definition: IsoTrig.cc:191
double getDistInCM(double eta1, double phi1, double eta2, double phi2)
Definition: IsoTrig.cc:2212
TTree * ChgIsolnTree_
Definition: IsoTrig.cc:207
double pz() const
z coordinate of momentum vector
Definition: TrackBase.h:646
edm::Handle< reco::VertexCollection > recVtxs_
Definition: IsoTrig.cc:196
const double vtxCutIsol_
Definition: IsoTrig.cc:159
double dR(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2117
static int position[264][3]
Definition: ReadPGInfo.cc:289
const MagneticField * bField_
Definition: IsoTrig.cc:198
math::XYZPoint leadPV_
Definition: IsoTrig.cc:200
const std::vector< double > pixelIsolationConeSizeAtEC_
Definition: IsoTrig.cc:158
const double vtxCutSeed_
Definition: IsoTrig.cc:159
void pushChgIsolnTreeVecs(math::XYZTLorentzVector &Pixcand, math::XYZTLorentzVector &Trkcand, std::vector< double > &PixMaxP, double &TrkMaxP, bool &selTk)
Definition: IsoTrig.cc:832

◆ clearChgIsolnTreeVectors()

void IsoTrig::clearChgIsolnTreeVectors ( )
private

Definition at line 792 of file IsoTrig.cc.

References l1ct::clear(), mps_fire::i, t_PixcandEta, t_PixcandMaxP, t_PixcandP, t_PixcandPhi, t_PixcandPt, t_PixTrkcandEta, t_PixTrkcandMaxP, t_PixTrkcandP, t_PixTrkcandPhi, t_PixTrkcandPt, and t_PixTrkcandselTk.

Referenced by chgIsolation().

792  {
793  t_PixcandP->clear();
794  t_PixcandPt->clear();
795  t_PixcandEta->clear();
796  t_PixcandPhi->clear();
797  for (unsigned int i = 0; i < t_PixcandMaxP->size(); i++)
798  t_PixcandMaxP[i].clear();
799  t_PixcandMaxP->clear();
800  t_PixTrkcandP->clear();
801  t_PixTrkcandPt->clear();
802  t_PixTrkcandEta->clear();
803  t_PixTrkcandPhi->clear();
804  t_PixTrkcandMaxP->clear();
805  t_PixTrkcandselTk->clear();
806 }
std::vector< double > * t_PixTrkcandPhi
Definition: IsoTrig.cc:229
std::vector< double > * t_PixTrkcandP
Definition: IsoTrig.cc:226
std::vector< bool > * t_PixTrkcandselTk
Definition: IsoTrig.cc:231
std::vector< double > * t_PixTrkcandMaxP
Definition: IsoTrig.cc:230
std::vector< double > * t_PixcandP
Definition: IsoTrig.cc:221
std::vector< double > * t_PixcandPt
Definition: IsoTrig.cc:222
std::vector< double > * t_PixTrkcandPt
Definition: IsoTrig.cc:227
std::vector< std::vector< double > > * t_PixcandMaxP
Definition: IsoTrig.cc:225
std::vector< double > * t_PixcandEta
Definition: IsoTrig.cc:223
std::vector< double > * t_PixcandPhi
Definition: IsoTrig.cc:224
std::vector< double > * t_PixTrkcandEta
Definition: IsoTrig.cc:228
void clear(EGIsoObj &c)
Definition: egamma.h:82

◆ clearMipCutTreeVectors()

void IsoTrig::clearMipCutTreeVectors ( )
private

Definition at line 808 of file IsoTrig.cc.

References t_ECone, t_NFcandEmip, t_NFcandEta, t_NFcandP, t_NFcandPhi, t_NFcandPt, t_NFTrkcandEmip, t_NFTrkcandEta, t_NFTrkcandP, t_NFTrkcandPhi, t_NFTrkcandPt, t_NFTrkChgIsoFlag, t_NFTrkMinDP1, t_NFTrkMinDR, t_NFTrkMipFlag, t_NFTrkMissFlag, t_NFTrkNeuIsoFlag, t_NFTrkPropFlag, t_NFTrkPVFlag, t_NFTrkqltyFlag, and t_NFTrkselTkFlag.

Referenced by studyMipCut().

808  {
809  t_NFcandP->clear();
810  t_NFcandPt->clear();
811  t_NFcandEta->clear();
812  t_NFcandPhi->clear();
813  t_NFcandEmip->clear();
814  t_NFTrkcandP->clear();
815  t_NFTrkcandPt->clear();
816  t_NFTrkcandEta->clear();
817  t_NFTrkcandPhi->clear();
818  t_NFTrkcandEmip->clear();
819  t_NFTrkMinDR->clear();
820  t_NFTrkMinDP1->clear();
821  t_NFTrkselTkFlag->clear();
822  t_NFTrkqltyFlag->clear();
823  t_NFTrkMissFlag->clear();
824  t_NFTrkPVFlag->clear();
825  t_NFTrkPropFlag->clear();
826  t_NFTrkChgIsoFlag->clear();
827  t_NFTrkNeuIsoFlag->clear();
828  t_NFTrkMipFlag->clear();
829  t_ECone->clear();
830 }
std::vector< bool > * t_NFTrkPVFlag
Definition: IsoTrig.cc:248
std::vector< double > * t_NFTrkMinDR
Definition: IsoTrig.cc:243
std::vector< bool > * t_NFTrkMissFlag
Definition: IsoTrig.cc:247
std::vector< double > * t_NFTrkcandEta
Definition: IsoTrig.cc:240
std::vector< double > * t_NFcandP
Definition: IsoTrig.cc:233
std::vector< bool > * t_NFTrkqltyFlag
Definition: IsoTrig.cc:246
std::vector< bool > * t_NFTrkselTkFlag
Definition: IsoTrig.cc:245
std::vector< bool > * t_NFTrkMipFlag
Definition: IsoTrig.cc:252
std::vector< double > * t_NFTrkMinDP1
Definition: IsoTrig.cc:244
std::vector< double > * t_NFTrkcandP
Definition: IsoTrig.cc:238
std::vector< double > * t_ECone
Definition: IsoTrig.cc:253
std::vector< bool > * t_NFTrkChgIsoFlag
Definition: IsoTrig.cc:250
std::vector< double > * t_NFcandEta
Definition: IsoTrig.cc:235
std::vector< double > * t_NFcandEmip
Definition: IsoTrig.cc:237
std::vector< bool > * t_NFTrkPropFlag
Definition: IsoTrig.cc:249
std::vector< double > * t_NFTrkcandPhi
Definition: IsoTrig.cc:241
std::vector< double > * t_NFTrkcandPt
Definition: IsoTrig.cc:239
std::vector< double > * t_NFcandPt
Definition: IsoTrig.cc:234
std::vector< double > * t_NFTrkcandEmip
Definition: IsoTrig.cc:242
std::vector< bool > * t_NFTrkNeuIsoFlag
Definition: IsoTrig.cc:251
std::vector< double > * t_NFcandPhi
Definition: IsoTrig.cc:236

◆ dEta()

double IsoTrig::dEta ( math::XYZTLorentzVector vec1,
math::XYZTLorentzVector vec2 
)
private

Definition at line 2100 of file IsoTrig.cc.

Referenced by dR(), fillDifferences(), and studyTrigger().

2100 { return (vec1.eta() - vec2.eta()); }
std::vector< double > vec1
Definition: HCALResponse.h:15
std::vector< vec1 > vec2
Definition: HCALResponse.h:16

◆ dinvPt()

double IsoTrig::dinvPt ( math::XYZTLorentzVector vec1,
math::XYZTLorentzVector vec2 
)
private

Definition at line 2129 of file IsoTrig.cc.

Referenced by fillDifferences().

2129  {
2130  return ((1 / vec1.pt()) - (1 / vec2.pt()));
2131 }
std::vector< double > vec1
Definition: HCALResponse.h:15
std::vector< vec1 > vec2
Definition: HCALResponse.h:16

◆ dP()

double IsoTrig::dP ( math::XYZTLorentzVector vec1,
math::XYZTLorentzVector vec2 
)
private

Definition at line 2125 of file IsoTrig.cc.

References funct::abs().

Referenced by fillDifferences().

2125  {
2126  return (std::abs(vec1.r() - vec2.r()));
2127 }
std::vector< double > vec1
Definition: HCALResponse.h:15
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
std::vector< vec1 > vec2
Definition: HCALResponse.h:16

◆ dPhi()

double IsoTrig::dPhi ( math::XYZTLorentzVector vec1,
math::XYZTLorentzVector vec2 
)
private

Definition at line 2102 of file IsoTrig.cc.

References M_PI.

Referenced by dR(), fillDifferences(), and studyTrigger().

2102  {
2103  double phi1 = vec1.phi();
2104  if (phi1 < 0)
2105  phi1 += 2.0 * M_PI;
2106  double phi2 = vec2.phi();
2107  if (phi2 < 0)
2108  phi2 += 2.0 * M_PI;
2109  double dphi = phi1 - phi2;
2110  if (dphi > M_PI)
2111  dphi -= 2. * M_PI;
2112  else if (dphi < -M_PI)
2113  dphi += 2. * M_PI;
2114  return dphi;
2115 }
std::vector< double > vec1
Definition: HCALResponse.h:15
#define M_PI
std::vector< vec1 > vec2
Definition: HCALResponse.h:16

◆ dPt()

double IsoTrig::dPt ( math::XYZTLorentzVector vec1,
math::XYZTLorentzVector vec2 
)
private

Definition at line 2123 of file IsoTrig.cc.

Referenced by fillDifferences().

2123 { return (vec1.pt() - vec2.pt()); }
std::vector< double > vec1
Definition: HCALResponse.h:15
std::vector< vec1 > vec2
Definition: HCALResponse.h:16

◆ dR()

double IsoTrig::dR ( math::XYZTLorentzVector vec1,
math::XYZTLorentzVector vec2 
)
private

Definition at line 2117 of file IsoTrig.cc.

References dEta(), dPhi(), and mathSSE::sqrt().

Referenced by chgIsolation(), fillDifferences(), getGoodTracks(), studyIsolation(), studyMipCut(), and studyTrigger().

2117  {
2118  double deta = dEta(vec1, vec2);
2119  double dphi = dPhi(vec1, vec2);
2120  return std::sqrt(deta * deta + dphi * dphi);
2121 }
std::vector< double > vec1
Definition: HCALResponse.h:15
T sqrt(T t)
Definition: SSEVec.h:19
double dPhi(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2102
double dEta(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2100
std::vector< vec1 > vec2
Definition: HCALResponse.h:16

◆ endJob()

void IsoTrig::endJob ( void  )
overrideprivatevirtual

Reimplemented from edm::one::EDAnalyzerBase.

Definition at line 1179 of file IsoTrig.cc.

References fs_, g_Accepts, g_Pre, g_PreHLT, g_PreL1, mps_fire::i, TFileService::make(), maxRunNo_, minRunNo_, dqmiodumpmetadata::n, DeadROC_duringRun::runNum, trigList_, trigNames_, and trigPreList_.

Referenced by o2olib.O2ORunMgr::executeJob().

1179  {
1180  edm::LogWarning("IsoTrack") << trigNames_.size() << "Triggers were run. RunNo vs HLT accepts for";
1181  for (unsigned int i = 0; i < trigNames_.size(); ++i)
1182  edm::LogWarning("IsoTrack") << "[" << i << "]: " << trigNames_[i];
1183  unsigned int n = maxRunNo_ - minRunNo_ + 1;
1184  g_Pre = fs_->make<TH1D>("h_PrevsRN", "PreScale Vs Run Number", n, minRunNo_, maxRunNo_);
1185  g_PreL1 = fs_->make<TH1D>("h_PreL1vsRN", "L1 PreScale Vs Run Number", n, minRunNo_, maxRunNo_);
1186  g_PreHLT = fs_->make<TH1D>("h_PreHLTvsRN", "HLT PreScale Vs Run Number", n, minRunNo_, maxRunNo_);
1187  g_Accepts = fs_->make<TH1I>("h_HLTAcceptsvsRN", "HLT Accepts Vs Run Number", n, minRunNo_, maxRunNo_);
1188 
1189  for (auto const &[runNum, nAccept] : trigList_) {
1190  auto const &triggerPrescales = trigPreList_[runNum];
1191  auto const preL1 = triggerPrescales.first;
1192  auto const preHLT = triggerPrescales.second;
1193  edm::LogVerbatim("IsoTrack") << runNum << " " << nAccept << " " << preL1 << " " << preHLT;
1194  g_Accepts->Fill(runNum, nAccept);
1195  g_PreL1->Fill(runNum, preL1);
1196  g_PreHLT->Fill(runNum, preHLT);
1197  g_Pre->Fill(runNum, preL1 * preHLT);
1198  }
1199 }
Log< level::Info, true > LogVerbatim
TH1D * g_PreHLT
Definition: IsoTrig.cc:267
edm::Service< TFileService > fs_
Definition: IsoTrig.cc:206
std::unordered_map< unsigned int, unsigned int > trigList_
Definition: IsoTrig.cc:202
std::unordered_map< unsigned int, const std::pair< double, double > > trigPreList_
Definition: IsoTrig.cc:203
const int maxRunNo_
Definition: IsoTrig.cc:168
TH1D * g_Pre
Definition: IsoTrig.cc:267
TH1D * g_PreL1
Definition: IsoTrig.cc:267
TH1I * g_Accepts
Definition: IsoTrig.cc:268
const int minRunNo_
Definition: IsoTrig.cc:168
T * make(const Args &...args) const
make new ROOT object
Definition: TFileService.h:64
Log< level::Warning, false > LogWarning
const std::vector< std::string > trigNames_
Definition: IsoTrig.cc:152

◆ endRun()

void IsoTrig::endRun ( edm::Run const &  ,
edm::EventSetup const &   
)
inlineoverrideprivate

Definition at line 108 of file IsoTrig.cc.

108 {}

◆ etaPhiTrigger()

std::pair< double, double > IsoTrig::etaPhiTrigger ( )
private

Definition at line 2133 of file IsoTrig.cc.

References PVValHelper::eta, dqmdumpme::k, phi, DiDispStaMuonMonitor_cfi::pt, muonTiming_cfi::ptmax, and vec_.

Referenced by analyze().

2133  {
2134  double eta(0), phi(0), ptmax(0);
2135  for (unsigned int k = 0; k < vec_[0].size(); ++k) {
2136  if (k == 0) {
2137  eta = vec_[0][k].eta();
2138  phi = vec_[0][k].phi();
2139  ptmax = vec_[0][k].pt();
2140  } else if (vec_[0][k].pt() > ptmax) {
2141  eta = vec_[0][k].eta();
2142  phi = vec_[0][k].phi();
2143  ptmax = vec_[0][k].pt();
2144  }
2145  }
2146  return std::pair<double, double>(eta, phi);
2147 }
std::vector< math::XYZTLorentzVector > vec_[3]
Definition: IsoTrig.cc:269

◆ fillCuts()

void IsoTrig::fillCuts ( int  indx,
double  eMipDR,
double  conehmaxNearP,
double  e_inCone,
math::XYZTLorentzVector vec,
int  ieta,
bool  cut 
)
private

Definition at line 2063 of file IsoTrig.cc.

References DMR_cfg::cut, cutCharge_, cutMip_, cutNeutral_, h_eMaxNearP, h_eMip, h_eNeutIso, h_etaCalibTracks, h_etaMipTracks, hcalRecHitTable_cff::ieta, and pLimits_.

Referenced by studyIsolation().

2064  {
2065  h_eMip[indx]->Fill(eMipDR);
2066  h_eMaxNearP[indx]->Fill(conehmaxNearP);
2067  h_eNeutIso[indx]->Fill(e_inCone);
2068  if ((conehmaxNearP < cutCharge_) && (eMipDR < cutMip_)) {
2069  for (int lim = 0; lim < 5; ++lim) {
2070  if ((vec.r() > pLimits_[lim]) && (vec.r() <= pLimits_[lim + 1])) {
2071  h_etaMipTracks[lim][indx][0]->Fill((double)(ieta));
2072  if (cut)
2073  h_etaMipTracks[lim][indx][1]->Fill((double)(ieta));
2074  if (e_inCone < cutNeutral_) {
2075  h_etaCalibTracks[lim][indx][0]->Fill((double)(ieta));
2076  if (cut)
2077  h_etaCalibTracks[lim][indx][1]->Fill((double)(ieta));
2078  }
2079  }
2080  }
2081  }
2082 }
TH1D * h_eMaxNearP[2]
Definition: IsoTrig.cc:264
TH1D * h_eNeutIso[2]
Definition: IsoTrig.cc:264
const double cutCharge_
Definition: IsoTrig.cc:167
TH1D * h_etaMipTracks[5][2][2]
Definition: IsoTrig.cc:265
const double cutMip_
Definition: IsoTrig.cc:166
const double cutNeutral_
Definition: IsoTrig.cc:167
double pLimits_[6]
Definition: IsoTrig.cc:205
TH1D * h_etaCalibTracks[5][2][2]
Definition: IsoTrig.cc:265
TH1D * h_eMip[2]
Definition: IsoTrig.cc:263

◆ fillDescriptions()

void IsoTrig::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
static

Definition at line 517 of file IsoTrig.cc.

References edm::ConfigurationDescriptions::add(), submitPVResolutionJobs::desc, ProducerED_cfi::InputTag, AlCaHLTBitMon_QueryRunRegistry::string, and triggerMatcherToHLTDebug_cfi::tags.

517  {
518  std::vector<std::string> triggers = {"HLT_IsoTrackHB"};
519  std::vector<edm::InputTag> tags = {edm::InputTag("hltHITPixelTracksHB"), edm::InputTag("hltHITPixelTracksHE")};
520  std::vector<double> cones = {35.0, 40.0, 45.0, 50.0, 55.0, 60.0, 63.9, 70.0};
522  desc.addUntracked<std::vector<std::string>>("Triggers", triggers);
523  desc.addUntracked<edm::InputTag>("pixCandTag", edm::InputTag(" "));
524  desc.addUntracked<edm::InputTag>("l1CandTag", edm::InputTag("hltL1sV0SingleJet60"));
525  desc.addUntracked<edm::InputTag>("l2CandTag", edm::InputTag("isolEcalPixelTrackProd"));
526  desc.addUntracked<bool>("doL2L3", false);
527  desc.addUntracked<bool>("doTimingTree", false);
528  desc.addUntracked<bool>("doMipCutTree", false);
529  desc.addUntracked<bool>("doTrkResTree", true);
530  desc.addUntracked<bool>("doChgIsolTree", false);
531  desc.addUntracked<bool>("doStudyIsol", false);
532  desc.addUntracked<int>("verbosity", 0);
533  desc.addUntracked<std::string>("processName", "HLT");
534  desc.addUntracked<std::string>("trackQuality", "highPurity");
535  desc.addUntracked<double>("minTrackPt", 10.0);
536  desc.addUntracked<double>("maxDxyPV", 0.02);
537  desc.addUntracked<double>("maxDzPV", 0.02);
538  desc.addUntracked<double>("maxChi2", 5.0);
539  desc.addUntracked<double>("maxDpOverP", 0.1);
540  desc.addUntracked<int>("minOuterHit", 4);
541  desc.addUntracked<int>("minLayerCrossed", 8);
542  desc.addUntracked<int>("maxInMiss", 0);
543  desc.addUntracked<int>("maxOutMiss", 0);
544  desc.addUntracked<double>("isolationL1", 1.0);
545  desc.addUntracked<double>("coneRadius", 34.98);
546  desc.addUntracked<double>("coneRadiusMIP", 14.0);
547  desc.addUntracked<double>("coneRadiusNeut1", 21.0);
548  desc.addUntracked<double>("coneRadiusNeut2", 29.0);
549  desc.addUntracked<double>("cutMIP", 1.0);
550  desc.addUntracked<double>("chargeIsolation", 2.0);
551  desc.addUntracked<double>("neutralIsolation", 2.0);
552  desc.addUntracked<int>("minRun", 190456);
553  desc.addUntracked<int>("maxRun", 203002);
554  desc.addUntracked<std::vector<edm::InputTag>>("pixelTracksSources", tags);
555  desc.addUntracked<std::vector<double>>("pixelIsolationConeSizeAtEC", cones);
556  desc.addUntracked<double>("minPTrackValue", 0.0);
557  desc.addUntracked<double>("vertexCutSeed", 101.0);
558  desc.addUntracked<double>("vertexCutIsol", 101.0);
559  desc.addUntracked<double>("tauUnbiasCone", 1.2);
560  desc.addUntracked<double>("prelimCone", 1.0);
561  desc.add<unsigned int>("stageL1Trigger", 1);
562  descriptions.add("isoTrigDefault", desc);
563 }
void add(std::string const &label, ParameterSetDescription const &psetDescription)

◆ fillDifferences()

void IsoTrig::fillDifferences ( int  indx,
math::XYZTLorentzVector vec1,
math::XYZTLorentzVector vec2,
bool  debug 
)
private

Definition at line 2045 of file IsoTrig.cc.

References debug, dEta(), dinvPt(), dP(), Calorimetry_cff::dp, dPhi(), dPt(), l1ctLayer1_cff::dr, dR(), h_dEta, h_dinvPt, h_dP, h_dPhi, h_dPt, and h_mindR.

Referenced by studyMipCut(), and studyTrigger().

2045  {
2046  double dr = dR(vec1, vec2);
2047  double deta = dEta(vec1, vec2);
2048  double dphi = dPhi(vec1, vec2);
2049  double dpt = dPt(vec1, vec2);
2050  double dp = dP(vec1, vec2);
2051  double dinvpt = dinvPt(vec1, vec2);
2052  h_dEta[indx]->Fill(deta);
2053  h_dPhi[indx]->Fill(dphi);
2054  h_dPt[indx]->Fill(dpt);
2055  h_dP[indx]->Fill(dp);
2056  h_dinvPt[indx]->Fill(dinvpt);
2057  h_mindR[indx]->Fill(dr);
2058  if (debug)
2059  edm::LogVerbatim("IsoTrack") << "mindR for index " << indx << " is " << dr << " deta " << deta << " dphi " << dphi
2060  << " dpt " << dpt << " dinvpt " << dinvpt;
2061 }
Log< level::Info, true > LogVerbatim
TH1D * h_dEta[9]
Definition: IsoTrig.cc:262
double dP(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2125
TH1D * h_dP[9]
Definition: IsoTrig.cc:262
double dinvPt(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2129
TH1D * h_dPhi[9]
Definition: IsoTrig.cc:262
std::vector< double > vec1
Definition: HCALResponse.h:15
TH1D * h_dinvPt[9]
Definition: IsoTrig.cc:263
double dPhi(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2102
#define debug
Definition: HDRShower.cc:19
double dEta(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2100
double dR(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2117
TH1D * h_mindR[9]
Definition: IsoTrig.cc:263
TH1D * h_dPt[9]
Definition: IsoTrig.cc:262
double dPt(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2123
std::vector< vec1 > vec2
Definition: HCALResponse.h:16

◆ fillEnergy()

void IsoTrig::fillEnergy ( int  indx,
int  ieta,
double  hCone,
double  eMipDR,
math::XYZTLorentzVector vec 
)
private

Definition at line 2084 of file IsoTrig.cc.

References h_eCalo, h_eHcal, hcalRecHitTable_cff::ieta, GetRecoTauVFromDQM_MC_cff::kk, and pLimits_.

Referenced by studyIsolation().

2084  {
2085  int kk(-1);
2086  if (ieta > 0 && ieta < 25)
2087  kk = 23 + ieta;
2088  else if (ieta > -25 && ieta < 0)
2089  kk = -(ieta + 1);
2090  if (kk >= 0 && eMipDR > 0.01 && hCone > 1.0) {
2091  for (int lim = 0; lim < 5; ++lim) {
2092  if ((vec.r() > pLimits_[lim]) && (vec.r() <= pLimits_[lim + 1])) {
2093  h_eHcal[lim][indx][kk]->Fill(hCone);
2094  h_eCalo[lim][indx][kk]->Fill(hCone + eMipDR);
2095  }
2096  }
2097  }
2098 }
TH1D * h_eHcal[5][6][48]
Definition: IsoTrig.cc:266
TH1D * h_eCalo[5][6][48]
Definition: IsoTrig.cc:266
double pLimits_[6]
Definition: IsoTrig.cc:205

◆ fillHist()

void IsoTrig::fillHist ( int  indx,
math::XYZTLorentzVector vec 
)
private

Definition at line 2038 of file IsoTrig.cc.

References h_eta, h_p, h_phi, and h_pt.

Referenced by studyIsolation(), and studyTrigger().

2038  {
2039  h_p[indx]->Fill(vec.r());
2040  h_pt[indx]->Fill(vec.pt());
2041  h_eta[indx]->Fill(vec.eta());
2042  h_phi[indx]->Fill(vec.phi());
2043 }
TH1D * h_phi[20]
Definition: IsoTrig.cc:260
TH1D * h_eta[20]
Definition: IsoTrig.cc:260
TH1D * h_p[20]
Definition: IsoTrig.cc:260
TH1D * h_pt[20]
Definition: IsoTrig.cc:260

◆ getDistInCM()

double IsoTrig::getDistInCM ( double  eta1,
double  phi1,
double  eta2,
double  phi2 
)
private

Definition at line 2212 of file IsoTrig.cc.

References angle(), funct::cos(), HLT_2023v12_cff::eta1, HLT_2023v12_cff::eta2, JetChargeProducer_cfi::exp, M_PI, rEB_, funct::sin(), funct::tan(), and zEE_.

Referenced by chgIsolation().

2212  {
2213  double Rec;
2214  double theta1 = 2 * atan(exp(-eta1));
2215  double theta2 = 2 * atan(exp(-eta2));
2216  if (fabs(eta1) < 1.479)
2217  Rec = rEB_; //radius of ECAL barrel
2218  else if (fabs(eta1) > 1.479 && fabs(eta1) < 7.0)
2219  Rec = tan(theta1) * zEE_; //distance from IP to ECAL endcap
2220  else
2221  return 1000;
2222 
2223  //|vect| times tg of acos(scalar product)
2224  double angle =
2225  acos((sin(theta1) * sin(theta2) * (sin(phi1) * sin(phi2) + cos(phi1) * cos(phi2)) + cos(theta1) * cos(theta2)));
2226  if (angle < 0.5 * M_PI)
2227  return fabs((Rec / sin(theta1)) * tan(angle));
2228  else
2229  return 1000;
2230 }
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
double rEB_
Definition: IsoTrig.cc:163
double zEE_
Definition: IsoTrig.cc:163
Cos< T >::type cos(const T &t)
Definition: Cos.h:22
Tan< T >::type tan(const T &t)
Definition: Tan.h:22
#define M_PI
T angle(T x1, T y1, T z1, T x2, T y2, T z2)
Definition: angle.h:11

◆ GetEtaPhiAtEcal()

std::pair< double, double > IsoTrig::GetEtaPhiAtEcal ( double  etaIP,
double  phiIP,
double  pT,
int  charge,
double  vtxZ 
)
private

Definition at line 2149 of file IsoTrig.cc.

References simBeamSpotPI::alpha, bfVal_, ALCARECOTkAlJpsiMuMu_cff::charge, SiPixelRawToDigiRegional_cfi::deltaPhi, JetChargeProducer_cfi::exp, dqm-mbProfile::log, M_PI, pv::pT, rEB_, funct::sin(), funct::tan(), theta(), z, and zEE_.

Referenced by chgIsolation().

2149  {
2150  double deltaPhi = 0;
2151  double etaEC = 100;
2152  double phiEC = 100;
2153 
2154  double Rcurv = 9999999;
2155  if (bfVal_ != 0)
2156  Rcurv = pT * 33.3 * 100 / (bfVal_ * 10); //r(m)=pT(GeV)*33.3/B(kG)
2157 
2158  double ecDist = zEE_;
2159  double ecRad = rEB_; //radius of ECAL barrel (cm)
2160  double theta = 2 * atan(exp(-etaIP));
2161  double zNew = 0;
2162  if (theta > 0.5 * M_PI)
2163  theta = M_PI - theta;
2164  if (fabs(etaIP) < 1.479) {
2165  if ((0.5 * ecRad / Rcurv) > 1) {
2166  etaEC = 10000;
2167  deltaPhi = 0;
2168  } else {
2169  deltaPhi = -charge * asin(0.5 * ecRad / Rcurv);
2170  double alpha1 = 2 * asin(0.5 * ecRad / Rcurv);
2171  double z = ecRad / tan(theta);
2172  if (etaIP > 0)
2173  zNew = z * (Rcurv * alpha1) / ecRad + vtxZ; //new z-coordinate of track
2174  else
2175  zNew = -z * (Rcurv * alpha1) / ecRad + vtxZ; //new z-coordinate of track
2176  double zAbs = fabs(zNew);
2177  if (zAbs < ecDist) {
2178  etaEC = -log(tan(0.5 * atan(ecRad / zAbs)));
2179  deltaPhi = -charge * asin(0.5 * ecRad / Rcurv);
2180  }
2181  if (zAbs > ecDist) {
2182  zAbs = (fabs(etaIP) / etaIP) * ecDist;
2183  double Zflight = fabs(zAbs - vtxZ);
2184  double alpha = (Zflight * ecRad) / (z * Rcurv);
2185  double Rec = 2 * Rcurv * sin(alpha / 2);
2186  deltaPhi = -charge * alpha / 2;
2187  etaEC = -log(tan(0.5 * atan(Rec / ecDist)));
2188  }
2189  }
2190  } else {
2191  zNew = (fabs(etaIP) / etaIP) * ecDist;
2192  double Zflight = fabs(zNew - vtxZ);
2193  double Rvirt = fabs(Zflight * tan(theta));
2194  double Rec = 2 * Rcurv * sin(Rvirt / (2 * Rcurv));
2195  deltaPhi = -(charge) * (Rvirt / (2 * Rcurv));
2196  etaEC = -log(tan(0.5 * atan(Rec / ecDist)));
2197  }
2198 
2199  if (zNew < 0)
2200  etaEC = -etaEC;
2201  phiEC = phiIP + deltaPhi;
2202 
2203  if (phiEC < -M_PI)
2204  phiEC += 2 * M_PI;
2205  if (phiEC > M_PI)
2206  phiEC -= 2 * M_PI;
2207 
2208  std::pair<double, double> retVal(etaEC, phiEC);
2209  return retVal;
2210 }
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
double rEB_
Definition: IsoTrig.cc:163
double zEE_
Definition: IsoTrig.cc:163
Tan< T >::type tan(const T &t)
Definition: Tan.h:22
#define M_PI
Geom::Theta< T > theta() const
double bfVal_
Definition: IsoTrig.cc:163

◆ getGoodTracks()

void IsoTrig::getGoodTracks ( const edm::Event iEvent,
edm::Handle< reco::TrackCollection > &  trkCollection 
)
private

Definition at line 1952 of file IsoTrig.cc.

References a_charIsoR_, a_mipR_, barrelRecHitsHandle_, bField_, spr::chargeIsolationCone(), funct::cos(), dR(), spr::eCone_ecal(), endcapRecHitsHandle_, geo_, trigger::TriggerRefsCollections::getObjects(), spr::goodTrack(), iEvent, cuy::ii, edm::HandleBase::isValid(), leadPV_, beamSpotPI::nTracks, AlCaHLTBitMon_ParallelJobs::p, reco::TrackBase::p(), spr::propagateCALO(), DiDispStaMuonMonitor_cfi::pt, reco::TrackBase::px(), reco::TrackBase::py(), reco::TrackBase::pz(), selectionParameters_, funct::sin(), t_nGoodTk, nnet::tanh(), theTrackQuality_, tok_l1cand_, trigger::TriggerL1CenJet, trigger::TriggerL1ForJet, trigger::TriggerL1TauJet, and verbosity_.

Referenced by analyze().

1952  {
1953  t_nGoodTk->clear();
1954  std::vector<int> nGood(4, 0);
1955  if (trkCollection.isValid()) {
1956  std::vector<spr::propagatedTrackDirection> trkCaloDirections;
1958  trkCollection, geo_, bField_, theTrackQuality_, trkCaloDirections, ((verbosity_ / 100) % 10 > 2));
1959 
1960  // get the trigger jet
1962  iEvent.getByToken(tok_l1cand_, l1trigobj);
1963 
1964  std::vector<edm::Ref<l1extra::L1JetParticleCollection>> l1tauobjref;
1965  l1trigobj->getObjects(trigger::TriggerL1TauJet, l1tauobjref);
1966  std::vector<edm::Ref<l1extra::L1JetParticleCollection>> l1jetobjref;
1967  l1trigobj->getObjects(trigger::TriggerL1CenJet, l1jetobjref);
1968  std::vector<edm::Ref<l1extra::L1JetParticleCollection>> l1forjetobjref;
1969  l1trigobj->getObjects(trigger::TriggerL1ForJet, l1forjetobjref);
1970 
1971  double ptTriggered(-10), etaTriggered(-100), phiTriggered(-100);
1972  for (unsigned int p = 0; p < l1tauobjref.size(); p++) {
1973  if (l1tauobjref[p]->pt() > ptTriggered) {
1974  ptTriggered = l1tauobjref[p]->pt();
1975  phiTriggered = l1tauobjref[p]->phi();
1976  etaTriggered = l1tauobjref[p]->eta();
1977  }
1978  }
1979  for (unsigned int p = 0; p < l1jetobjref.size(); p++) {
1980  if (l1jetobjref[p]->pt() > ptTriggered) {
1981  ptTriggered = l1jetobjref[p]->pt();
1982  phiTriggered = l1jetobjref[p]->phi();
1983  etaTriggered = l1jetobjref[p]->eta();
1984  }
1985  }
1986  for (unsigned int p = 0; p < l1forjetobjref.size(); p++) {
1987  if (l1forjetobjref[p]->pt() > ptTriggered) {
1988  ptTriggered = l1forjetobjref[p]->pt();
1989  phiTriggered = l1forjetobjref[p]->phi();
1990  etaTriggered = l1forjetobjref[p]->eta();
1991  }
1992  }
1993  double pTriggered = ptTriggered * cosh(etaTriggered);
1994  math::XYZTLorentzVector pTrigger(
1995  ptTriggered * cos(phiTriggered), ptTriggered * sin(phiTriggered), pTriggered * tanh(etaTriggered), pTriggered);
1996 
1997  std::vector<spr::propagatedTrackDirection>::const_iterator trkDetItr;
1998  unsigned int nTracks(0);
1999  for (trkDetItr = trkCaloDirections.begin(); trkDetItr != trkCaloDirections.end(); trkDetItr++, nTracks++) {
2000  const reco::Track *pTrack = &(*(trkDetItr->trkItr));
2001  math::XYZTLorentzVector v4(pTrack->px(), pTrack->py(), pTrack->pz(), pTrack->p());
2002  bool selectTk = spr::goodTrack(pTrack, leadPV_, selectionParameters_, ((verbosity_ / 100) % 10 > 1));
2003  double mindR = dR(v4, pTrigger);
2004  if ((verbosity_ / 100) % 10 > 1)
2005  edm::LogVerbatim("IsoTrack") << "Track ECAL " << trkDetItr->okECAL << " HCAL " << trkDetItr->okHCAL << " Flag "
2006  << selectTk;
2007  if (selectTk && trkDetItr->okECAL && trkDetItr->okHCAL && mindR > 1.0) {
2008  int nRH_eMipDR(0), nNearTRKs(0);
2009  double eMipDR = spr::eCone_ecal(geo_,
2012  trkDetItr->pointHCAL,
2013  trkDetItr->pointECAL,
2014  a_mipR_,
2015  trkDetItr->directionECAL,
2016  nRH_eMipDR);
2017  double conehmaxNearP =
2018  spr::chargeIsolationCone(nTracks, trkCaloDirections, a_charIsoR_, nNearTRKs, ((verbosity_ / 100) % 10 > 1));
2019  if (conehmaxNearP < 2.0 && eMipDR < 1.0) {
2020  if (pTrack->p() >= 20 && pTrack->p() < 30) {
2021  ++nGood[0];
2022  } else if (pTrack->p() >= 30 && pTrack->p() < 40) {
2023  ++nGood[1];
2024  } else if (pTrack->p() >= 40 && pTrack->p() < 60) {
2025  ++nGood[2];
2026  } else if (pTrack->p() >= 60 && pTrack->p() < 100) {
2027  ++nGood[3];
2028  }
2029  }
2030  }
2031  }
2032  }
2033 
2034  for (unsigned int ii = 0; ii < nGood.size(); ++ii)
2035  t_nGoodTk->push_back(nGood[ii]);
2036 }
Log< level::Info, true > LogVerbatim
void getObjects(Vids &ids, VRphoton &refs) const
various physics-level getters:
std::string theTrackQuality_
Definition: IsoTrig.cc:161
std::vector< spr::propagatedTrackID > propagateCALO(edm::Handle< reco::TrackCollection > &trkCollection, const CaloGeometry *geo, const MagneticField *bField, const std::string &theTrackQuality, bool debug=false)
edm::Handle< EcalRecHitCollection > endcapRecHitsHandle_
Definition: IsoTrig.cc:194
void tanh(data_T data[CONFIG_T::n_in], res_T res[CONFIG_T::n_in])
const double a_charIsoR_
Definition: IsoTrig.cc:165
double px() const
x coordinate of momentum vector
Definition: TrackBase.h:640
double p() const
momentum vector magnitude
Definition: TrackBase.h:631
const int verbosity_
Definition: IsoTrig.cc:157
Sin< T >::type sin(const T &t)
Definition: Sin.h:22
edm::Handle< EcalRecHitCollection > barrelRecHitsHandle_
Definition: IsoTrig.cc:193
double py() const
y coordinate of momentum vector
Definition: TrackBase.h:643
double chargeIsolationCone(unsigned int trkIndex, std::vector< spr::propagatedTrackDirection > &trkDirs, double dR, int &nNearTRKs, bool debug=false)
const double a_mipR_
Definition: IsoTrig.cc:166
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
int iEvent
Definition: GenABIO.cc:224
bool goodTrack(const reco::Track *pTrack, math::XYZPoint leadPV, trackSelectionParameters parameters, bool debug=false)
Cos< T >::type cos(const T &t)
Definition: Cos.h:22
spr::trackSelectionParameters selectionParameters_
Definition: IsoTrig.cc:164
double eCone_ecal(const CaloGeometry *geo, edm::Handle< T > &barrelhits, edm::Handle< T > &endcaphits, const GlobalPoint &hpoint1, const GlobalPoint &point1, double dR, const GlobalVector &trackMom, int &nRecHits, double ebThr=-100, double eeThr=-100, double tMin=-500, double tMax=500, bool debug=false)
const CaloGeometry * geo_
Definition: IsoTrig.cc:199
ii
Definition: cuy.py:589
double pz() const
z coordinate of momentum vector
Definition: TrackBase.h:646
bool isValid() const
Definition: HandleBase.h:70
edm::EDGetTokenT< trigger::TriggerFilterObjectWithRefs > tok_l1cand_
Definition: IsoTrig.cc:184
double dR(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2117
const MagneticField * bField_
Definition: IsoTrig.cc:198
std::vector< int > * t_nGoodTk
Definition: IsoTrig.cc:211
math::XYZPoint leadPV_
Definition: IsoTrig.cc:200

◆ pushChgIsolnTreeVecs()

void IsoTrig::pushChgIsolnTreeVecs ( math::XYZTLorentzVector Pixcand,
math::XYZTLorentzVector Trkcand,
std::vector< double > &  PixMaxP,
double &  TrkMaxP,
bool &  selTk 
)
private

Definition at line 832 of file IsoTrig.cc.

References t_PixcandEta, t_PixcandMaxP, t_PixcandP, t_PixcandPhi, t_PixcandPt, t_PixTrkcandEta, t_PixTrkcandMaxP, t_PixTrkcandP, t_PixTrkcandPhi, t_PixTrkcandPt, and t_PixTrkcandselTk.

Referenced by chgIsolation().

836  {
837  t_PixcandP->push_back(Pixcand.r());
838  t_PixcandPt->push_back(Pixcand.pt());
839  t_PixcandEta->push_back(Pixcand.eta());
840  t_PixcandPhi->push_back(Pixcand.phi());
841  t_PixcandMaxP->push_back(PixMaxP);
842  t_PixTrkcandP->push_back(Trkcand.r());
843  t_PixTrkcandPt->push_back(Trkcand.pt());
844  t_PixTrkcandEta->push_back(Trkcand.eta());
845  t_PixTrkcandPhi->push_back(Trkcand.phi());
846  t_PixTrkcandMaxP->push_back(TrkMaxP);
847  t_PixTrkcandselTk->push_back(selTk);
848 }
std::vector< double > * t_PixTrkcandPhi
Definition: IsoTrig.cc:229
std::vector< double > * t_PixTrkcandP
Definition: IsoTrig.cc:226
std::vector< bool > * t_PixTrkcandselTk
Definition: IsoTrig.cc:231
std::vector< double > * t_PixTrkcandMaxP
Definition: IsoTrig.cc:230
std::vector< double > * t_PixcandP
Definition: IsoTrig.cc:221
std::vector< double > * t_PixcandPt
Definition: IsoTrig.cc:222
std::vector< double > * t_PixTrkcandPt
Definition: IsoTrig.cc:227
std::vector< std::vector< double > > * t_PixcandMaxP
Definition: IsoTrig.cc:225
std::vector< double > * t_PixcandEta
Definition: IsoTrig.cc:223
std::vector< double > * t_PixcandPhi
Definition: IsoTrig.cc:224
std::vector< double > * t_PixTrkcandEta
Definition: IsoTrig.cc:228

◆ pushMipCutTreeVecs()

void IsoTrig::pushMipCutTreeVecs ( math::XYZTLorentzVector NFcand,
math::XYZTLorentzVector Trkcand,
double &  EmipNFcand,
double &  EmipTrkcand,
double &  mindR,
double &  mindP1,
std::vector< bool > &  Flags,
double  hCone 
)
private

Definition at line 850 of file IsoTrig.cc.

References t_ECone, t_NFcandEmip, t_NFcandEta, t_NFcandP, t_NFcandPhi, t_NFcandPt, t_NFTrkcandEmip, t_NFTrkcandEta, t_NFTrkcandP, t_NFTrkcandPhi, t_NFTrkcandPt, t_NFTrkChgIsoFlag, t_NFTrkMinDP1, t_NFTrkMinDR, t_NFTrkMipFlag, t_NFTrkMissFlag, t_NFTrkNeuIsoFlag, t_NFTrkPropFlag, t_NFTrkPVFlag, t_NFTrkqltyFlag, and t_NFTrkselTkFlag.

Referenced by studyMipCut().

857  {
858  t_NFcandP->push_back(NFcand.r());
859  t_NFcandPt->push_back(NFcand.pt());
860  t_NFcandEta->push_back(NFcand.eta());
861  t_NFcandPhi->push_back(NFcand.phi());
862  t_NFcandEmip->push_back(EmipNFcand);
863  t_NFTrkcandP->push_back(Trkcand.r());
864  t_NFTrkcandPt->push_back(Trkcand.pt());
865  t_NFTrkcandEta->push_back(Trkcand.eta());
866  t_NFTrkcandPhi->push_back(Trkcand.phi());
867  t_NFTrkcandEmip->push_back(EmipTrkcand);
868  t_NFTrkMinDR->push_back(mindR);
869  t_NFTrkMinDP1->push_back(mindP1);
870  t_NFTrkselTkFlag->push_back(Flags[0]);
871  t_NFTrkqltyFlag->push_back(Flags[1]);
872  t_NFTrkMissFlag->push_back(Flags[2]);
873  t_NFTrkPVFlag->push_back(Flags[3]);
874  t_NFTrkPropFlag->push_back(Flags[4]);
875  t_NFTrkChgIsoFlag->push_back(Flags[5]);
876  t_NFTrkNeuIsoFlag->push_back(Flags[6]);
877  t_NFTrkMipFlag->push_back(Flags[7]);
878  t_ECone->push_back(hCone);
879 }
std::vector< bool > * t_NFTrkPVFlag
Definition: IsoTrig.cc:248
std::vector< double > * t_NFTrkMinDR
Definition: IsoTrig.cc:243
std::vector< bool > * t_NFTrkMissFlag
Definition: IsoTrig.cc:247
std::vector< double > * t_NFTrkcandEta
Definition: IsoTrig.cc:240
std::vector< double > * t_NFcandP
Definition: IsoTrig.cc:233
std::vector< bool > * t_NFTrkqltyFlag
Definition: IsoTrig.cc:246
std::vector< bool > * t_NFTrkselTkFlag
Definition: IsoTrig.cc:245
std::vector< bool > * t_NFTrkMipFlag
Definition: IsoTrig.cc:252
std::vector< double > * t_NFTrkMinDP1
Definition: IsoTrig.cc:244
std::vector< double > * t_NFTrkcandP
Definition: IsoTrig.cc:238
std::vector< double > * t_ECone
Definition: IsoTrig.cc:253
std::vector< bool > * t_NFTrkChgIsoFlag
Definition: IsoTrig.cc:250
std::vector< double > * t_NFcandEta
Definition: IsoTrig.cc:235
std::vector< double > * t_NFcandEmip
Definition: IsoTrig.cc:237
std::vector< bool > * t_NFTrkPropFlag
Definition: IsoTrig.cc:249
std::vector< double > * t_NFTrkcandPhi
Definition: IsoTrig.cc:241
std::vector< double > * t_NFTrkcandPt
Definition: IsoTrig.cc:239
std::vector< double > * t_NFcandPt
Definition: IsoTrig.cc:234
std::vector< double > * t_NFTrkcandEmip
Definition: IsoTrig.cc:242
std::vector< bool > * t_NFTrkNeuIsoFlag
Definition: IsoTrig.cc:251
std::vector< double > * t_NFcandPhi
Definition: IsoTrig.cc:236

◆ studyIsolation()

void IsoTrig::studyIsolation ( edm::Handle< reco::TrackCollection > &  trkCollection,
std::vector< reco::TrackCollection::const_iterator > &  goodTks 
)
private

Definition at line 1688 of file IsoTrig.cc.

References a_charIsoR_, a_coneR_, a_mipR_, a_neutR1_, a_neutR2_, barrelRecHitsHandle_, bField_, spr::chargeIsolationCone(), cutCharge_, cutMip_, cutNeutral_, PbPb_ZMuSkimMuonDPG_cff::deltaR, hcalRecHitTable_cff::detId, doL2L3_, dR(), dr_L1_, StorageManager_cfg::e1, spr::eCone_ecal(), spr::eCone_hcal(), endcapRecHitsHandle_, fillCuts(), fillEnergy(), fillHist(), spr::find(), geo_, spr::goodTrack(), hbhe_, hit::id, hcalRecHitTable_cff::ieta, edm::HandleBase::isValid(), dqmdumpme::k, leadPV_, beamSpotPI::nTracks, reco::TrackBase::p(), spr::propagateCALO(), reco::TrackBase::px(), reco::TrackBase::py(), reco::TrackBase::pz(), selectionParameters_, theTrackQuality_, vec_, and verbosity_.

Referenced by analyze().

1689  {
1690  if (trkCollection.isValid()) {
1691  std::vector<spr::propagatedTrackDirection> trkCaloDirections;
1693  trkCollection, geo_, bField_, theTrackQuality_, trkCaloDirections, ((verbosity_ / 100) % 10 > 2));
1694 
1695  std::vector<spr::propagatedTrackDirection>::const_iterator trkDetItr;
1696  if ((verbosity_ / 1000) % 10 > 1) {
1697  edm::LogVerbatim("IsoTrack") << "n of barrelRecHitsHandle " << barrelRecHitsHandle_->size();
1699  ++hit) {
1700  edm::LogVerbatim("IsoTrack") << "hit : detid(ieta,iphi) " << (EBDetId)(hit->id()) << " time " << hit->time()
1701  << " energy " << hit->energy();
1702  }
1703  edm::LogVerbatim("IsoTrack") << "n of endcapRecHitsHandle " << endcapRecHitsHandle_->size();
1705  ++hit) {
1706  edm::LogVerbatim("IsoTrack") << "hit : detid(ieta,iphi) " << (EEDetId)(hit->id()) << " time " << hit->time()
1707  << " energy " << hit->energy();
1708  }
1709  edm::LogVerbatim("IsoTrack") << "n of hbhe " << hbhe_->size();
1710  for (HBHERecHitCollection::const_iterator hit = hbhe_->begin(); hit != hbhe_->end(); ++hit) {
1711  edm::LogVerbatim("IsoTrack") << "hit : detid(ieta,iphi) " << hit->id() << " time " << hit->time() << " energy "
1712  << hit->energy();
1713  }
1714  }
1715  unsigned int nTracks = 0;
1716  int ieta = 999;
1717  for (trkDetItr = trkCaloDirections.begin(); trkDetItr != trkCaloDirections.end(); trkDetItr++, nTracks++) {
1718  bool l3Track = (std::find(goodTks.begin(), goodTks.end(), trkDetItr->trkItr) != goodTks.end());
1719  const reco::Track *pTrack = &(*(trkDetItr->trkItr));
1720  math::XYZTLorentzVector v4(pTrack->px(), pTrack->py(), pTrack->pz(), pTrack->p());
1721  bool selectTk = spr::goodTrack(pTrack, leadPV_, selectionParameters_, ((verbosity_ / 100) % 10 > 1));
1722  double eMipDR = 9999., e_inCone = 0, conehmaxNearP = 0, mindR = 999.9, hCone = 0;
1723  if (trkDetItr->okHCAL) {
1724  HcalDetId detId = (HcalDetId)(trkDetItr->detIdHCAL);
1725  ieta = detId.ieta();
1726  }
1727  for (unsigned k = 0; k < vec_[0].size(); ++k) {
1728  double deltaR = dR(v4, vec_[0][k]);
1729  if (deltaR < mindR)
1730  mindR = deltaR;
1731  }
1732  if ((verbosity_ / 100) % 10 > 1)
1733  edm::LogVerbatim("IsoTrack") << "Track ECAL " << trkDetItr->okECAL << " HCAL " << trkDetItr->okHCAL << " Flag "
1734  << selectTk;
1735  if (selectTk && trkDetItr->okECAL && trkDetItr->okHCAL) {
1736  int nRH_eMipDR = 0, nNearTRKs = 0;
1737  double e1 = spr::eCone_ecal(geo_,
1740  trkDetItr->pointHCAL,
1741  trkDetItr->pointECAL,
1742  a_neutR1_,
1743  trkDetItr->directionECAL,
1744  nRH_eMipDR);
1745  double e2 = spr::eCone_ecal(geo_,
1748  trkDetItr->pointHCAL,
1749  trkDetItr->pointECAL,
1750  a_neutR2_,
1751  trkDetItr->directionECAL,
1752  nRH_eMipDR);
1753  eMipDR = spr::eCone_ecal(geo_,
1756  trkDetItr->pointHCAL,
1757  trkDetItr->pointECAL,
1758  a_mipR_,
1759  trkDetItr->directionECAL,
1760  nRH_eMipDR);
1761  conehmaxNearP =
1762  spr::chargeIsolationCone(nTracks, trkCaloDirections, a_charIsoR_, nNearTRKs, ((verbosity_ / 100) % 10 > 1));
1763  e_inCone = e2 - e1;
1764  double distFromHotCell = -99.0;
1765  int nRecHitsCone = -99, ietaHotCell = -99, iphiHotCell = -99;
1766  GlobalPoint gposHotCell(0., 0., 0.);
1767  std::vector<DetId> coneRecHitDetIds;
1768  hCone = spr::eCone_hcal(geo_,
1769  hbhe_,
1770  trkDetItr->pointHCAL,
1771  trkDetItr->pointECAL,
1772  a_coneR_,
1773  trkDetItr->directionHCAL,
1774  nRecHitsCone,
1775  coneRecHitDetIds,
1776  distFromHotCell,
1777  ietaHotCell,
1778  iphiHotCell,
1779  gposHotCell,
1780  -1);
1781  }
1782  if (l3Track) {
1783  fillHist(10, v4);
1784  if (selectTk) {
1785  fillHist(11, v4);
1786  fillCuts(0, eMipDR, conehmaxNearP, e_inCone, v4, ieta, (mindR > dr_L1_));
1787  if (conehmaxNearP < cutCharge_) {
1788  fillHist(12, v4);
1789  if (eMipDR < cutMip_) {
1790  fillHist(13, v4);
1791  fillEnergy(1, ieta, hCone, eMipDR, v4);
1792  fillEnergy(0, ieta, hCone, eMipDR, v4);
1793  if (e_inCone < cutNeutral_) {
1794  fillHist(14, v4);
1795  fillEnergy(4, ieta, hCone, eMipDR, v4);
1796  fillEnergy(3, ieta, hCone, eMipDR, v4);
1797  }
1798  }
1799  }
1800  }
1801  } else if (doL2L3_) {
1802  fillHist(15, v4);
1803  if (selectTk) {
1804  fillHist(16, v4);
1805  fillCuts(1, eMipDR, conehmaxNearP, e_inCone, v4, ieta, (mindR > dr_L1_));
1806  if (conehmaxNearP < cutCharge_) {
1807  fillHist(17, v4);
1808  if (eMipDR < cutMip_) {
1809  fillHist(18, v4);
1810  fillEnergy(2, ieta, hCone, eMipDR, v4);
1811  fillEnergy(0, ieta, hCone, eMipDR, v4);
1812  if (e_inCone < cutNeutral_) {
1813  fillHist(19, v4);
1814  fillEnergy(5, ieta, hCone, eMipDR, v4);
1815  fillEnergy(3, ieta, hCone, eMipDR, v4);
1816  }
1817  }
1818  }
1819  }
1820  }
1821  }
1822  }
1823 }
double eCone_hcal(const CaloGeometry *geo, edm::Handle< T > &hits, const GlobalPoint &hpoint1, const GlobalPoint &point1, double dR, const GlobalVector &trackMom, int &nRecHits, double hbThr=-100, double heThr=-100, double hfThr=-100, double hoThr=-100, double tMin=-500, double tMax=500, int detOnly=-1, int useRaw=0, bool debug=false)
Log< level::Info, true > LogVerbatim
const double a_coneR_
Definition: IsoTrig.cc:165
std::string theTrackQuality_
Definition: IsoTrig.cc:161
std::vector< spr::propagatedTrackID > propagateCALO(edm::Handle< reco::TrackCollection > &trkCollection, const CaloGeometry *geo, const MagneticField *bField, const std::string &theTrackQuality, bool debug=false)
edm::Handle< EcalRecHitCollection > endcapRecHitsHandle_
Definition: IsoTrig.cc:194
edm::Handle< HBHERecHitCollection > hbhe_
Definition: IsoTrig.cc:192
const double a_charIsoR_
Definition: IsoTrig.cc:165
const double a_neutR2_
Definition: IsoTrig.cc:166
double px() const
x coordinate of momentum vector
Definition: TrackBase.h:640
double p() const
momentum vector magnitude
Definition: TrackBase.h:631
const int verbosity_
Definition: IsoTrig.cc:157
std::vector< EcalRecHit >::const_iterator const_iterator
edm::Handle< EcalRecHitCollection > barrelRecHitsHandle_
Definition: IsoTrig.cc:193
double py() const
y coordinate of momentum vector
Definition: TrackBase.h:643
std::vector< math::XYZTLorentzVector > vec_[3]
Definition: IsoTrig.cc:269
double chargeIsolationCone(unsigned int trkIndex, std::vector< spr::propagatedTrackDirection > &trkDirs, double dR, int &nNearTRKs, bool debug=false)
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:19
const double a_mipR_
Definition: IsoTrig.cc:166
const double dr_L1_
Definition: IsoTrig.cc:165
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
void fillHist(int, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2038
bool goodTrack(const reco::Track *pTrack, math::XYZPoint leadPV, trackSelectionParameters parameters, bool debug=false)
const double a_neutR1_
Definition: IsoTrig.cc:166
void fillEnergy(int, int, double, double, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2084
spr::trackSelectionParameters selectionParameters_
Definition: IsoTrig.cc:164
double eCone_ecal(const CaloGeometry *geo, edm::Handle< T > &barrelhits, edm::Handle< T > &endcaphits, const GlobalPoint &hpoint1, const GlobalPoint &point1, double dR, const GlobalVector &trackMom, int &nRecHits, double ebThr=-100, double eeThr=-100, double tMin=-500, double tMax=500, bool debug=false)
const CaloGeometry * geo_
Definition: IsoTrig.cc:199
unsigned int id
const double cutCharge_
Definition: IsoTrig.cc:167
double pz() const
z coordinate of momentum vector
Definition: TrackBase.h:646
bool isValid() const
Definition: HandleBase.h:70
double dR(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2117
const MagneticField * bField_
Definition: IsoTrig.cc:198
math::XYZPoint leadPV_
Definition: IsoTrig.cc:200
const double cutMip_
Definition: IsoTrig.cc:166
const double cutNeutral_
Definition: IsoTrig.cc:167
void fillCuts(int, double, double, double, math::XYZTLorentzVector &, int, bool)
Definition: IsoTrig.cc:2063
const bool doL2L3_
Definition: IsoTrig.cc:155

◆ studyMipCut()

void IsoTrig::studyMipCut ( edm::Handle< reco::TrackCollection > &  trkCollection,
edm::Handle< reco::IsolatedPixelTrackCandidateCollection > &  L2cands 
)
private

Definition at line 1441 of file IsoTrig.cc.

References a_charIsoR_, a_coneR_, a_mipR_, a_neutR1_, a_neutR2_, funct::abs(), barrelRecHitsHandle_, bField_, spr::chargeIsolationCone(), clearMipCutTreeVectors(), cutCharge_, cutMip_, cutNeutral_, l1ctLayer1_cff::dr, dR(), StorageManager_cfg::e1, spr::eCone_ecal(), spr::eCone_hcal(), endcapRecHitsHandle_, reco::TrackBase::eta(), fillDifferences(), geo_, spr::goodTrack(), h_EnIn, h_EnOut, h_MipEnMatch, h_MipEnNoMatch, hbhe_, mps_fire::i, edm::HandleBase::isValid(), leadPV_, spr::trackSelectionParameters::maxDxyPV, spr::trackSelectionParameters::maxDzPV, spr::trackSelectionParameters::maxInMiss, spr::trackSelectionParameters::maxOutMiss, MipCutTree_, beamSpotPI::nTracks, reco::TrackBase::p(), reco::TrackBase::phi(), spr::propagateCALO(), reco::TrackBase::pt(), pushMipCutTreeVecs(), reco::TrackBase::px(), reco::TrackBase::py(), reco::TrackBase::pz(), selectionParameters_, theTrackQuality_, and verbosity_.

Referenced by analyze().

1442  {
1444  if (verbosity_ % 10 > 0)
1445  edm::LogVerbatim("IsoTrack") << "inside studymipcut";
1446  if (!trkCollection.isValid()) {
1447  edm::LogWarning("IsoTrack") << "trkCollection.isValid is false";
1448  } else {
1449  std::vector<spr::propagatedTrackDirection>::const_iterator trkDetItr;
1450  std::vector<spr::propagatedTrackDirection> trkCaloDirections1;
1452  trkCollection, geo_, bField_, theTrackQuality_, trkCaloDirections1, ((verbosity_ / 100) % 10 > 2));
1453  if (verbosity_ % 10 > 0)
1454  edm::LogVerbatim("IsoTrack") << "Number of L2cands:" << L2cands->size() << " to be matched to something out of "
1455  << trkCaloDirections1.size() << " reco tracks";
1456  for (unsigned int i = 0; i < L2cands->size(); i++) {
1459  double enIn = candref->energyIn();
1460  h_EnIn->Fill(candref->energyIn());
1461  h_EnOut->Fill(candref->energyOut());
1463  candref->track()->px(), candref->track()->py(), candref->track()->pz(), candref->track()->p());
1464  if (verbosity_ % 10 > 1)
1465  edm::LogVerbatim("IsoTrack") << "HLT Level Candidate eta/phi/pt/enIn:" << candref->track()->eta() << "/"
1466  << candref->track()->phi() << "/" << candref->track()->pt() << "/"
1467  << candref->energyIn();
1468  math::XYZTLorentzVector mindRvec;
1469  double mindR = 999.9, mindP1 = 999.9, eMipDR = 0.0;
1470  std::vector<bool> selFlags;
1471  unsigned int nTracks = 0;
1472  double conehmaxNearP = 0, hCone = 0;
1473  for (trkDetItr = trkCaloDirections1.begin(); trkDetItr != trkCaloDirections1.end(); trkDetItr++, nTracks++) {
1474  const reco::Track *pTrack = &(*(trkDetItr->trkItr));
1475  math::XYZTLorentzVector v2(pTrack->px(), pTrack->py(), pTrack->pz(), pTrack->p());
1476  double dr = dR(v1, v2);
1477  double dp1 = std::abs(1. / v1.r() - 1. / v2.r());
1478  if (verbosity_ % 1000 > 0)
1479  edm::LogVerbatim("IsoTrack") << "This recotrack(eta/phi/pt) " << pTrack->eta() << "/" << pTrack->phi() << "/"
1480  << pTrack->pt() << " has dr/dp= " << dr << "/" << dp1;
1481  if (dr < mindR) {
1482  mindR = dr;
1483  mindP1 = dp1;
1484  mindRvec = v2;
1485  int nRH_eMipDR = 0, nNearTRKs = 0;
1486  eMipDR = spr::eCone_ecal(geo_,
1489  trkDetItr->pointHCAL,
1490  trkDetItr->pointECAL,
1491  a_mipR_,
1492  trkDetItr->directionECAL,
1493  nRH_eMipDR);
1494  bool selectTk = spr::goodTrack(pTrack, leadPV_, selectionParameters_, ((verbosity_ / 100) % 10 > 1));
1496  oneCutParameters.maxDxyPV = 10;
1497  oneCutParameters.maxDzPV = 100;
1498  oneCutParameters.maxInMiss = 2;
1499  oneCutParameters.maxOutMiss = 2;
1500  bool qltyFlag = spr::goodTrack(pTrack, leadPV_, oneCutParameters, ((verbosity_ / 100) % 10 > 1));
1501  oneCutParameters = selectionParameters_;
1502  oneCutParameters.maxDxyPV = 10;
1503  oneCutParameters.maxDzPV = 100;
1504  bool qltyMissFlag = spr::goodTrack(pTrack, leadPV_, oneCutParameters, ((verbosity_ / 100) % 10 > 1));
1505  oneCutParameters = selectionParameters_;
1506  oneCutParameters.maxInMiss = 2;
1507  oneCutParameters.maxOutMiss = 2;
1508  bool qltyPVFlag = spr::goodTrack(pTrack, leadPV_, oneCutParameters, ((verbosity_ / 100) % 10 > 1));
1509  conehmaxNearP = spr::chargeIsolationCone(
1510  nTracks, trkCaloDirections1, a_charIsoR_, nNearTRKs, ((verbosity_ / 100) % 10 > 1));
1511  double e1 = spr::eCone_ecal(geo_,
1514  trkDetItr->pointHCAL,
1515  trkDetItr->pointECAL,
1516  a_neutR1_,
1517  trkDetItr->directionECAL,
1518  nRH_eMipDR);
1519  double e2 = spr::eCone_ecal(geo_,
1522  trkDetItr->pointHCAL,
1523  trkDetItr->pointECAL,
1524  a_neutR2_,
1525  trkDetItr->directionECAL,
1526  nRH_eMipDR);
1527  double e_inCone = e2 - e1;
1528  bool chgIsolFlag = (conehmaxNearP < cutCharge_);
1529  bool mipFlag = (eMipDR < cutMip_);
1530  bool neuIsolFlag = (e_inCone < cutNeutral_);
1531  bool trkpropFlag = ((trkDetItr->okECAL) && (trkDetItr->okHCAL));
1532  selFlags.clear();
1533  selFlags.push_back(selectTk);
1534  selFlags.push_back(qltyFlag);
1535  selFlags.push_back(qltyMissFlag);
1536  selFlags.push_back(qltyPVFlag);
1537  selFlags.push_back(trkpropFlag);
1538  selFlags.push_back(chgIsolFlag);
1539  selFlags.push_back(neuIsolFlag);
1540  selFlags.push_back(mipFlag);
1541  double distFromHotCell = -99.0;
1542  int nRecHitsCone = -99, ietaHotCell = -99, iphiHotCell = -99;
1543  GlobalPoint gposHotCell(0., 0., 0.);
1544  std::vector<DetId> coneRecHitDetIds;
1545  hCone = spr::eCone_hcal(geo_,
1546  hbhe_,
1547  trkDetItr->pointHCAL,
1548  trkDetItr->pointECAL,
1549  a_coneR_,
1550  trkDetItr->directionHCAL,
1551  nRecHitsCone,
1552  coneRecHitDetIds,
1553  distFromHotCell,
1554  ietaHotCell,
1555  iphiHotCell,
1556  gposHotCell,
1557  -1);
1558  }
1559  }
1560  pushMipCutTreeVecs(v1, mindRvec, enIn, eMipDR, mindR, mindP1, selFlags, hCone);
1561  fillDifferences(6, v1, mindRvec, (verbosity_ % 10 > 0));
1562  if (mindR >= 0.05) {
1563  fillDifferences(8, v1, mindRvec, (verbosity_ % 10 > 0));
1564  h_MipEnNoMatch->Fill(candref->energyIn(), eMipDR);
1565  } else {
1566  fillDifferences(7, v1, mindRvec, (verbosity_ % 10 > 0));
1567  h_MipEnMatch->Fill(candref->energyIn(), eMipDR);
1568  }
1569  }
1570  }
1571  MipCutTree_->Fill();
1572 }
double eCone_hcal(const CaloGeometry *geo, edm::Handle< T > &hits, const GlobalPoint &hpoint1, const GlobalPoint &point1, double dR, const GlobalVector &trackMom, int &nRecHits, double hbThr=-100, double heThr=-100, double hfThr=-100, double hoThr=-100, double tMin=-500, double tMax=500, int detOnly=-1, int useRaw=0, bool debug=false)
Log< level::Info, true > LogVerbatim
const double a_coneR_
Definition: IsoTrig.cc:165
std::string theTrackQuality_
Definition: IsoTrig.cc:161
std::vector< spr::propagatedTrackID > propagateCALO(edm::Handle< reco::TrackCollection > &trkCollection, const CaloGeometry *geo, const MagneticField *bField, const std::string &theTrackQuality, bool debug=false)
edm::Handle< EcalRecHitCollection > endcapRecHitsHandle_
Definition: IsoTrig.cc:194
edm::Handle< HBHERecHitCollection > hbhe_
Definition: IsoTrig.cc:192
TH1D * h_EnIn
Definition: IsoTrig.cc:255
const double a_charIsoR_
Definition: IsoTrig.cc:165
const double a_neutR2_
Definition: IsoTrig.cc:166
double px() const
x coordinate of momentum vector
Definition: TrackBase.h:640
double p() const
momentum vector magnitude
Definition: TrackBase.h:631
const int verbosity_
Definition: IsoTrig.cc:157
edm::Handle< EcalRecHitCollection > barrelRecHitsHandle_
Definition: IsoTrig.cc:193
double py() const
y coordinate of momentum vector
Definition: TrackBase.h:643
double chargeIsolationCone(unsigned int trkIndex, std::vector< spr::propagatedTrackDirection > &trkDirs, double dR, int &nNearTRKs, bool debug=false)
const double a_mipR_
Definition: IsoTrig.cc:166
void pushMipCutTreeVecs(math::XYZTLorentzVector &NFcand, math::XYZTLorentzVector &Trkcand, double &EmipNFcand, double &EmipTrkcand, double &mindR, double &mindP1, std::vector< bool > &Flags, double hCone)
Definition: IsoTrig.cc:850
TH1D * h_EnOut
Definition: IsoTrig.cc:255
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
double pt() const
track transverse momentum
Definition: TrackBase.h:637
bool goodTrack(const reco::Track *pTrack, math::XYZPoint leadPV, trackSelectionParameters parameters, bool debug=false)
const double a_neutR1_
Definition: IsoTrig.cc:166
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
spr::trackSelectionParameters selectionParameters_
Definition: IsoTrig.cc:164
double phi() const
azimuthal angle of momentum vector
Definition: TrackBase.h:649
double eCone_ecal(const CaloGeometry *geo, edm::Handle< T > &barrelhits, edm::Handle< T > &endcaphits, const GlobalPoint &hpoint1, const GlobalPoint &point1, double dR, const GlobalVector &trackMom, int &nRecHits, double ebThr=-100, double eeThr=-100, double tMin=-500, double tMax=500, bool debug=false)
const CaloGeometry * geo_
Definition: IsoTrig.cc:199
TH2D * h_MipEnMatch
Definition: IsoTrig.cc:256
const double cutCharge_
Definition: IsoTrig.cc:167
double eta() const
pseudorapidity of momentum vector
Definition: TrackBase.h:652
double pz() const
z coordinate of momentum vector
Definition: TrackBase.h:646
bool isValid() const
Definition: HandleBase.h:70
double dR(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2117
TTree * MipCutTree_
Definition: IsoTrig.cc:207
void clearMipCutTreeVectors()
Definition: IsoTrig.cc:808
void fillDifferences(int, math::XYZTLorentzVector &, math::XYZTLorentzVector &, bool)
Definition: IsoTrig.cc:2045
const MagneticField * bField_
Definition: IsoTrig.cc:198
TH2D * h_MipEnNoMatch
Definition: IsoTrig.cc:256
Log< level::Warning, false > LogWarning
math::XYZPoint leadPV_
Definition: IsoTrig.cc:200
const double cutMip_
Definition: IsoTrig.cc:166
const double cutNeutral_
Definition: IsoTrig.cc:167

◆ studyTiming()

void IsoTrig::studyTiming ( const edm::Event theEvent)
private

Definition at line 1330 of file IsoTrig.cc.

References PbPb_ZMuSkimMuonDPG_cff::deltaR, PVValHelper::dxy, PVValHelper::dz, PVValHelper::eta, edm::Event::getByToken(), trigger::TriggerRefsCollections::getObjects(), AlCaHLTBitMon_ParallelJobs::p, phi, pixelTrackRefsHB_, pixelTrackRefsHE_, edm::Handle< T >::product(), DiDispStaMuonMonitor_cfi::pt, dttmaxenums::R, HI_PhotonSkim_cff::rechits, SeedingLayerSetsHits::size(), t_nPixCand, t_nPixSeed, t_timeL2Prod, tauUnbiasCone_, TimingTree_, tok_l1cand_, tok_SeedingLayerHB_, tok_SeedingLayerHE_, tok_SiPixelRecHits_, tok_verthb_, tok_verthe_, trigger::TriggerL1CenJet, trigger::TriggerL1ForJet, trigger::TriggerL1TauJet, verbosity_, and vtxCutSeed_.

Referenced by analyze().

1330  {
1331  t_timeL2Prod->clear();
1332  t_nPixCand->clear();
1333  t_nPixSeed->clear();
1334 
1335  if (verbosity_ % 10 > 0) {
1336  edm::Handle<SeedingLayerSetsHits> hblayers, helayers;
1337  theEvent.getByToken(tok_SeedingLayerHB_, hblayers);
1338  theEvent.getByToken(tok_SeedingLayerHE_, helayers);
1339  const SeedingLayerSetsHits *layershb = hblayers.product();
1340  const SeedingLayerSetsHits *layershe = helayers.product();
1341  edm::LogVerbatim("IsoTrack") << "size of Seeding TripletLayers hb/he " << layershb->size() << "/"
1342  << layershe->size();
1344  theEvent.getByToken(tok_SiPixelRecHits_, rchts);
1345  const SiPixelRecHitCollection *rechits = rchts.product();
1346  edm::LogVerbatim("IsoTrack") << "size of SiPixelRechits " << rechits->size();
1347  }
1348  int nCandHB = pixelTrackRefsHB_.size(), nCandHE = pixelTrackRefsHE_.size();
1349  int nSeedHB = 0, nSeedHE = 0;
1350 
1351  if (nCandHE > 0) {
1352  edm::Handle<reco::VertexCollection> pVertHB, pVertHE;
1353  theEvent.getByToken(tok_verthb_, pVertHB);
1354  theEvent.getByToken(tok_verthe_, pVertHE);
1356  theEvent.getByToken(tok_l1cand_, l1trigobj);
1357 
1358  std::vector<edm::Ref<l1extra::L1JetParticleCollection>> l1tauobjref;
1359  std::vector<edm::Ref<l1extra::L1JetParticleCollection>> l1jetobjref;
1360  std::vector<edm::Ref<l1extra::L1JetParticleCollection>> l1forjetobjref;
1361 
1362  l1trigobj->getObjects(trigger::TriggerL1TauJet, l1tauobjref);
1363  l1trigobj->getObjects(trigger::TriggerL1CenJet, l1jetobjref);
1364  l1trigobj->getObjects(trigger::TriggerL1ForJet, l1forjetobjref);
1365 
1366  double ptTriggered = -10;
1367  double etaTriggered = -100;
1368  double phiTriggered = -100;
1369  for (unsigned int p = 0; p < l1tauobjref.size(); p++) {
1370  if (l1tauobjref[p]->pt() > ptTriggered) {
1371  ptTriggered = l1tauobjref[p]->pt();
1372  phiTriggered = l1tauobjref[p]->phi();
1373  etaTriggered = l1tauobjref[p]->eta();
1374  }
1375  }
1376  for (unsigned int p = 0; p < l1jetobjref.size(); p++) {
1377  if (l1jetobjref[p]->pt() > ptTriggered) {
1378  ptTriggered = l1jetobjref[p]->pt();
1379  phiTriggered = l1jetobjref[p]->phi();
1380  etaTriggered = l1jetobjref[p]->eta();
1381  }
1382  }
1383  for (unsigned int p = 0; p < l1forjetobjref.size(); p++) {
1384  if (l1forjetobjref[p]->pt() > ptTriggered) {
1385  ptTriggered = l1forjetobjref[p]->pt();
1386  phiTriggered = l1forjetobjref[p]->phi();
1387  etaTriggered = l1forjetobjref[p]->eta();
1388  }
1389  }
1390  for (unsigned iS = 0; iS < pixelTrackRefsHE_.size(); iS++) {
1391  reco::VertexCollection::const_iterator vitSel;
1392  double minDZ = 100;
1393  bool vtxMatch;
1394  for (reco::VertexCollection::const_iterator vit = pVertHE->begin(); vit != pVertHE->end(); vit++) {
1395  if (fabs(pixelTrackRefsHE_[iS]->dz(vit->position())) < minDZ) {
1396  minDZ = fabs(pixelTrackRefsHE_[iS]->dz(vit->position()));
1397  vitSel = vit;
1398  }
1399  }
1400  //cut on dYX:
1401  if ((fabs(pixelTrackRefsHE_[iS]->dxy(vitSel->position())) < vtxCutSeed_) || (minDZ == 100))
1402  vtxMatch = true;
1403 
1404  //select tracks not matched to triggered L1 jet
1405  double R = deltaR(etaTriggered, phiTriggered, pixelTrackRefsHE_[iS]->eta(), pixelTrackRefsHE_[iS]->phi());
1406  if (R > tauUnbiasCone_ && vtxMatch)
1407  nSeedHE++;
1408  }
1409  for (unsigned iS = 0; iS < pixelTrackRefsHB_.size(); iS++) {
1410  reco::VertexCollection::const_iterator vitSel;
1411  double minDZ = 100;
1412  bool vtxMatch(false);
1413  for (reco::VertexCollection::const_iterator vit = pVertHB->begin(); vit != pVertHB->end(); vit++) {
1414  if (fabs(pixelTrackRefsHB_[iS]->dz(vit->position())) < minDZ) {
1415  minDZ = fabs(pixelTrackRefsHB_[iS]->dz(vit->position()));
1416  vitSel = vit;
1417  }
1418  }
1419  //cut on dYX:
1420  if ((fabs(pixelTrackRefsHB_[iS]->dxy(vitSel->position())) < 101.0) || (minDZ == 100))
1421  vtxMatch = true;
1422 
1423  //select tracks not matched to triggered L1 jet
1424  double R = deltaR(etaTriggered, phiTriggered, pixelTrackRefsHB_[iS]->eta(), pixelTrackRefsHB_[iS]->phi());
1425  if (R > 1.2 && vtxMatch)
1426  nSeedHB++;
1427  }
1428 
1429  if (verbosity_ % 10 > 0) {
1430  edm::LogVerbatim("IsoTrack") << "(HB/HE) nCand: " << nCandHB << "/" << nCandHE << "nSeed: " << nSeedHB << "/"
1431  << nSeedHE;
1432  }
1433  }
1434  t_nPixSeed->push_back(nSeedHB);
1435  t_nPixSeed->push_back(nSeedHE);
1436  t_nPixCand->push_back(nCandHB);
1437  t_nPixCand->push_back(nCandHE);
1438 
1439  TimingTree_->Fill();
1440 }
Log< level::Info, true > LogVerbatim
void getObjects(Vids &ids, VRphoton &refs) const
various physics-level getters:
std::vector< reco::TrackRef > pixelTrackRefsHB_
Definition: IsoTrig.cc:191
const int verbosity_
Definition: IsoTrig.cc:157
T const * product() const
Definition: Handle.h:70
std::vector< int > * t_nPixSeed
Definition: IsoTrig.cc:210
unsigned short size() const
Get the number of SeedingLayerSets.
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:536
const double tauUnbiasCone_
Definition: IsoTrig.cc:160
edm::EDGetTokenT< SeedingLayerSetsHits > tok_SeedingLayerHB_
Definition: IsoTrig.cc:180
edm::EDGetTokenT< SeedingLayerSetsHits > tok_SeedingLayerHE_
Definition: IsoTrig.cc:181
std::vector< double > * t_timeL2Prod
Definition: IsoTrig.cc:208
std::vector< reco::TrackRef > pixelTrackRefsHE_
Definition: IsoTrig.cc:191
std::vector< int > * t_nPixCand
Definition: IsoTrig.cc:209
edm::EDGetTokenT< reco::VertexCollection > tok_verthb_
Definition: IsoTrig.cc:179
edm::EDGetTokenT< trigger::TriggerFilterObjectWithRefs > tok_l1cand_
Definition: IsoTrig.cc:184
edm::EDGetTokenT< SiPixelRecHitCollection > tok_SiPixelRecHits_
Definition: IsoTrig.cc:182
edm::EDGetTokenT< reco::VertexCollection > tok_verthe_
Definition: IsoTrig.cc:179
const double vtxCutSeed_
Definition: IsoTrig.cc:159
TTree * TimingTree_
Definition: IsoTrig.cc:207

◆ studyTrigger()

void IsoTrig::studyTrigger ( edm::Handle< reco::TrackCollection > &  trkCollection,
std::vector< reco::TrackCollection::const_iterator > &  goodTks 
)
private

Definition at line 1574 of file IsoTrig.cc.

References funct::abs(), PbPb_ZMuSkimMuonDPG_cff::deltaR, dEta(), Calorimetry_cff::dp, dPhi(), l1ctLayer1_cff::dr, dR(), fillDifferences(), fillHist(), h_dEtaL1, h_dPhiL1, h_dRL1, mps_fire::i, edm::HandleBase::isValid(), dqmiolumiharvest::j, dqmdumpme::k, mathSSE::sqrt(), vec_, and verbosity_.

Referenced by analyze().

1575  {
1576  if (verbosity_ % 10 > 0)
1577  edm::LogVerbatim("IsoTrack") << "Inside StudyTrigger";
1579  for (int j = 0; j < 3; j++) {
1580  for (unsigned int k = 0; k < vec_[j].size(); k++) {
1581  if (verbosity_ % 10 > 0)
1582  edm::LogVerbatim("IsoTrack") << "vec[" << j << "][" << k << "] pt " << vec_[j][k].pt() << " eta "
1583  << vec_[j][k].eta() << " phi " << vec_[j][k].phi();
1584  fillHist(j, vec_[j][k]);
1585  }
1586  }
1587 
1588  double deta, dphi, dr;
1590  for (int lvl = 1; lvl < 3; lvl++) {
1591  for (unsigned int i = 0; i < vec_[lvl].size(); i++) {
1592  deta = dEta(vec_[0][0], vec_[lvl][i]);
1593  dphi = dPhi(vec_[0][0], vec_[lvl][i]);
1594  dr = dR(vec_[0][0], vec_[lvl][i]);
1595  if (verbosity_ % 10 > 1)
1596  edm::LogVerbatim("IsoTrack") << "lvl " << lvl << " i " << i << " deta " << deta << " dphi " << dphi << " dR "
1597  << dr;
1598  h_dEtaL1[lvl - 1]->Fill(deta);
1599  h_dPhiL1[lvl - 1]->Fill(dphi);
1600  h_dRL1[lvl - 1]->Fill(std::sqrt(dr));
1601  }
1602  }
1603 
1604  math::XYZTLorentzVector mindRvec;
1605  double mindR;
1606  for (unsigned int k = 0; k < vec_[2].size(); ++k) {
1608  mindR = 999.9;
1609  if (verbosity_ % 10 > 1)
1610  edm::LogVerbatim("IsoTrack") << "L3obj: pt " << vec_[2][k].pt() << " eta " << vec_[2][k].eta() << " phi "
1611  << vec_[2][k].phi();
1612  for (unsigned int j = 0; j < vec_[1].size(); j++) {
1613  dr = dR(vec_[2][k], vec_[1][j]);
1614  if (dr < mindR) {
1615  mindR = dr;
1616  mindRvec = vec_[1][j];
1617  }
1618  }
1619  fillDifferences(0, vec_[2][k], mindRvec, (verbosity_ % 10 > 0));
1620  if (mindR < 0.03) {
1621  fillDifferences(1, vec_[2][k], mindRvec, (verbosity_ % 10 > 0));
1622  fillHist(6, mindRvec);
1623  fillHist(8, vec_[2][k]);
1624  } else {
1625  fillDifferences(2, vec_[2][k], mindRvec, (verbosity_ % 10 > 0));
1626  fillHist(7, mindRvec);
1627  fillHist(9, vec_[2][k]);
1628  }
1629 
1631  mindR = 999.9;
1632  if (verbosity_ % 10 > 0)
1633  edm::LogVerbatim("IsoTrack") << "Now Matching L3 track with reco: L3 Track (eta, phi) " << vec_[2][k].eta() << ":"
1634  << vec_[2][k].phi() << " L2 Track " << mindRvec.eta() << ":" << mindRvec.phi()
1635  << " dR " << mindR;
1636  reco::TrackCollection::const_iterator goodTk = trkCollection->end();
1637  if (trkCollection.isValid()) {
1638  double mindP(9999.9);
1639  reco::TrackCollection::const_iterator trkItr;
1640  for (trkItr = trkCollection->begin(); trkItr != trkCollection->end(); trkItr++) {
1641  math::XYZTLorentzVector v4(trkItr->px(), trkItr->py(), trkItr->pz(), trkItr->p());
1642  double deltaR = dR(v4, vec_[2][k]);
1643  double dp = std::abs(v4.r() / vec_[2][k].r() - 1.0);
1644  if (deltaR < mindR) {
1645  mindR = deltaR;
1646  mindP = dp;
1647  mindRvec = v4;
1648  goodTk = trkItr;
1649  }
1650  if ((verbosity_ / 10) % 10 > 1 && deltaR < 1.0)
1651  edm::LogVerbatim("IsoTrack") << "reco track: pt " << v4.pt() << " eta " << v4.eta() << " phi " << v4.phi()
1652  << " DR " << deltaR;
1653  }
1654  if (verbosity_ % 10 > 0)
1655  edm::LogVerbatim("IsoTrack") << "Now Matching at Reco level in step 1 DR: " << mindR << ":" << mindP
1656  << " eta:phi " << mindRvec.eta() << ":" << mindRvec.phi();
1657  if (mindR < 0.03 && mindP > 0.1) {
1658  for (trkItr = trkCollection->begin(); trkItr != trkCollection->end(); trkItr++) {
1659  math::XYZTLorentzVector v4(trkItr->px(), trkItr->py(), trkItr->pz(), trkItr->p());
1660  double deltaR = dR(v4, vec_[2][k]);
1661  double dp = std::abs(v4.r() / vec_[2][k].r() - 1.0);
1662  if (dp < mindP && deltaR < 0.03) {
1663  mindR = deltaR;
1664  mindP = dp;
1665  mindRvec = v4;
1666  goodTk = trkItr;
1667  }
1668  }
1669  if (verbosity_ % 10 > 0)
1670  edm::LogVerbatim("IsoTrack") << "Now Matching at Reco level in step 2 DR: " << mindR << ":" << mindP
1671  << " eta:phi " << mindRvec.eta() << ":" << mindRvec.phi();
1672  }
1673  fillDifferences(3, vec_[2][k], mindRvec, (verbosity_ % 10 > 0));
1674  fillHist(3, mindRvec);
1675  if (mindR < 0.03) {
1676  fillDifferences(4, vec_[2][k], mindRvec, (verbosity_ % 10 > 0));
1677  fillHist(4, mindRvec);
1678  } else {
1679  fillDifferences(5, vec_[2][k], mindRvec, (verbosity_ % 10 > 0));
1680  fillHist(5, mindRvec);
1681  }
1682  if (goodTk != trkCollection->end())
1683  goodTks.push_back(goodTk);
1684  }
1685  }
1686 }
Log< level::Info, true > LogVerbatim
const int verbosity_
Definition: IsoTrig.cc:157
TH1D * h_dEtaL1[2]
Definition: IsoTrig.cc:261
std::vector< math::XYZTLorentzVector > vec_[3]
Definition: IsoTrig.cc:269
TH1D * h_dPhiL1[2]
Definition: IsoTrig.cc:261
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
void fillHist(int, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2038
T sqrt(T t)
Definition: SSEVec.h:19
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
double dPhi(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2102
double dEta(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2100
bool isValid() const
Definition: HandleBase.h:70
double dR(math::XYZTLorentzVector &, math::XYZTLorentzVector &)
Definition: IsoTrig.cc:2117
void fillDifferences(int, math::XYZTLorentzVector &, math::XYZTLorentzVector &, bool)
Definition: IsoTrig.cc:2045
TH1D * h_dRL1[2]
Definition: IsoTrig.cc:261

◆ StudyTrkEbyP()

void IsoTrig::StudyTrkEbyP ( edm::Handle< reco::TrackCollection > &  trkCollection)
private

Definition at line 1206 of file IsoTrig.cc.

References a_charIsoR_, a_coneR_, a_mipR_, a_neutR1_, a_neutR2_, barrelRecHitsHandle_, bField_, spr::chargeIsolationCone(), cutCharge_, cutMip_, cutNeutral_, StorageManager_cfg::e1, spr::eCone_ecal(), spr::eCone_hcal(), endcapRecHitsHandle_, geo_, spr::goodTrack(), hbhe_, edm::HandleBase::isValid(), leadPV_, spr::trackSelectionParameters::maxDxyPV, spr::trackSelectionParameters::maxDzPV, spr::trackSelectionParameters::maxInMiss, spr::trackSelectionParameters::maxOutMiss, beamSpotPI::nTracks, reco::TrackBase::p(), spr::propagateCALO(), reco::TrackBase::px(), reco::TrackBase::py(), reco::TrackBase::pz(), selectionParameters_, t_TrkhCone, t_TrkMissFlag, t_TrkNuIsolFlag, t_TrkP, t_TrkPVFlag, t_TrkqltyFlag, t_TrkselTkFlag, theTrackQuality_, TrkResTree_, and verbosity_.

Referenced by analyze().

1206  {
1207  t_TrkselTkFlag->clear();
1208  t_TrkqltyFlag->clear();
1209  t_TrkMissFlag->clear();
1210  t_TrkPVFlag->clear();
1211  t_TrkNuIsolFlag->clear();
1212  t_TrkhCone->clear();
1213  t_TrkP->clear();
1214 
1215  if (!trkCollection.isValid()) {
1216  edm::LogVerbatim("IsoTrack") << "trkCollection.isValid is false";
1217  } else {
1218  std::vector<spr::propagatedTrackDirection>::const_iterator trkDetItr;
1219  std::vector<spr::propagatedTrackDirection> trkCaloDirections1;
1221  trkCollection, geo_, bField_, theTrackQuality_, trkCaloDirections1, ((verbosity_ / 100) % 10 > 2));
1222  unsigned int nTracks = 0;
1223  int nRH_eMipDR = 0, nNearTRKs = 0;
1224  std::vector<bool> selFlags;
1225  for (trkDetItr = trkCaloDirections1.begin(); trkDetItr != trkCaloDirections1.end(); trkDetItr++, nTracks++) {
1226  double conehmaxNearP = 0, hCone = 0, eMipDR = 0.0;
1227  const reco::Track *pTrack = &(*(trkDetItr->trkItr));
1228  if (verbosity_ % 10 > 0)
1229  edm::LogVerbatim("IsoTrack") << "track no. " << nTracks << " p(): " << pTrack->p();
1230  if (pTrack->p() > 20) {
1231  math::XYZTLorentzVector v2(pTrack->px(), pTrack->py(), pTrack->pz(), pTrack->p());
1232  eMipDR = spr::eCone_ecal(geo_,
1235  trkDetItr->pointHCAL,
1236  trkDetItr->pointECAL,
1237  a_mipR_,
1238  trkDetItr->directionECAL,
1239  nRH_eMipDR);
1240  bool selectTk = spr::goodTrack(pTrack, leadPV_, selectionParameters_, ((verbosity_ / 100) % 10 > 1));
1242  oneCutParameters.maxDxyPV = 10;
1243  oneCutParameters.maxDzPV = 100;
1244  oneCutParameters.maxInMiss = 2;
1245  oneCutParameters.maxOutMiss = 2;
1246  bool qltyFlag = spr::goodTrack(pTrack, leadPV_, oneCutParameters, ((verbosity_ / 100) % 10 > 1));
1247  oneCutParameters = selectionParameters_;
1248  oneCutParameters.maxDxyPV = 10;
1249  oneCutParameters.maxDzPV = 100;
1250  bool qltyMissFlag = spr::goodTrack(pTrack, leadPV_, oneCutParameters, ((verbosity_ / 100) % 10 > 1));
1251  oneCutParameters = selectionParameters_;
1252  oneCutParameters.maxInMiss = 2;
1253  oneCutParameters.maxOutMiss = 2;
1254  bool qltyPVFlag = spr::goodTrack(pTrack, leadPV_, oneCutParameters, ((verbosity_ / 100) % 10 > 1));
1255  if ((verbosity_ / 1000) % 10 > 1)
1256  edm::LogVerbatim("IsoTrack") << "sel " << selectTk << "ntracks " << nTracks << " a_charIsoR " << a_charIsoR_
1257  << " nNearTRKs " << nNearTRKs;
1258  conehmaxNearP = spr::chargeIsolationCone(
1259  nTracks, trkCaloDirections1, a_charIsoR_, nNearTRKs, ((verbosity_ / 100) % 10 > 1));
1260  if ((verbosity_ / 1000) % 10 > 1)
1261  edm::LogVerbatim("IsoTrack") << "coneh " << conehmaxNearP << "ok " << trkDetItr->okECAL << " "
1262  << trkDetItr->okHCAL;
1263  double e1 = spr::eCone_ecal(geo_,
1266  trkDetItr->pointHCAL,
1267  trkDetItr->pointECAL,
1268  a_neutR1_,
1269  trkDetItr->directionECAL,
1270  nRH_eMipDR);
1271  double e2 = spr::eCone_ecal(geo_,
1274  trkDetItr->pointHCAL,
1275  trkDetItr->pointECAL,
1276  a_neutR2_,
1277  trkDetItr->directionECAL,
1278  nRH_eMipDR);
1279  double e_inCone = e2 - e1;
1280  bool chgIsolFlag = (conehmaxNearP < cutCharge_);
1281  bool mipFlag = (eMipDR < cutMip_);
1282  bool neuIsolFlag = (e_inCone < cutNeutral_);
1283  bool trkpropFlag = ((trkDetItr->okECAL) && (trkDetItr->okHCAL));
1284  selFlags.clear();
1285  selFlags.push_back(selectTk);
1286  selFlags.push_back(qltyFlag);
1287  selFlags.push_back(qltyMissFlag);
1288  selFlags.push_back(qltyPVFlag);
1289  if (verbosity_ % 10 > 0)
1290  edm::LogVerbatim("IsoTrack") << "emip: " << eMipDR << "<" << cutMip_ << "(" << mipFlag << ")"
1291  << " ; ok: " << trkDetItr->okECAL << "/" << trkDetItr->okHCAL
1292  << " ; chgiso: " << conehmaxNearP << "<" << cutCharge_ << "(" << chgIsolFlag
1293  << ")";
1294 
1295  if (chgIsolFlag && mipFlag && trkpropFlag) {
1296  double distFromHotCell = -99.0;
1297  int nRecHitsCone = -99, ietaHotCell = -99, iphiHotCell = -99;
1298  GlobalPoint gposHotCell(0., 0., 0.);
1299  std::vector<DetId> coneRecHitDetIds;
1300  hCone = spr::eCone_hcal(geo_,
1301  hbhe_,
1302  trkDetItr->pointHCAL,
1303  trkDetItr->pointECAL,
1304  a_coneR_,
1305  trkDetItr->directionHCAL,
1306  nRecHitsCone,
1307  coneRecHitDetIds,
1308  distFromHotCell,
1309  ietaHotCell,
1310  iphiHotCell,
1311  gposHotCell,
1312  -1);
1313  // push vectors into the Tree
1314  t_TrkselTkFlag->push_back(selFlags[0]);
1315  t_TrkqltyFlag->push_back(selFlags[1]);
1316  t_TrkMissFlag->push_back(selFlags[2]);
1317  t_TrkPVFlag->push_back(selFlags[3]);
1318  t_TrkNuIsolFlag->push_back(neuIsolFlag);
1319  t_TrkhCone->push_back(hCone);
1320  t_TrkP->push_back(pTrack->p());
1321  }
1322  }
1323  }
1324  if (verbosity_ % 10 > 0)
1325  edm::LogVerbatim("IsoTrack") << "Filling " << t_TrkP->size() << " tracks in TrkRestree out of " << nTracks;
1326  }
1327  TrkResTree_->Fill();
1328 }
double eCone_hcal(const CaloGeometry *geo, edm::Handle< T > &hits, const GlobalPoint &hpoint1, const GlobalPoint &point1, double dR, const GlobalVector &trackMom, int &nRecHits, double hbThr=-100, double heThr=-100, double hfThr=-100, double hoThr=-100, double tMin=-500, double tMax=500, int detOnly=-1, int useRaw=0, bool debug=false)
Log< level::Info, true > LogVerbatim
const double a_coneR_
Definition: IsoTrig.cc:165
std::string theTrackQuality_
Definition: IsoTrig.cc:161
std::vector< spr::propagatedTrackID > propagateCALO(edm::Handle< reco::TrackCollection > &trkCollection, const CaloGeometry *geo, const MagneticField *bField, const std::string &theTrackQuality, bool debug=false)
edm::Handle< EcalRecHitCollection > endcapRecHitsHandle_
Definition: IsoTrig.cc:194
edm::Handle< HBHERecHitCollection > hbhe_
Definition: IsoTrig.cc:192
const double a_charIsoR_
Definition: IsoTrig.cc:165
const double a_neutR2_
Definition: IsoTrig.cc:166
double px() const
x coordinate of momentum vector
Definition: TrackBase.h:640
double p() const
momentum vector magnitude
Definition: TrackBase.h:631
const int verbosity_
Definition: IsoTrig.cc:157
edm::Handle< EcalRecHitCollection > barrelRecHitsHandle_
Definition: IsoTrig.cc:193
double py() const
y coordinate of momentum vector
Definition: TrackBase.h:643
std::vector< double > * t_TrkhCone
Definition: IsoTrig.cc:213
double chargeIsolationCone(unsigned int trkIndex, std::vector< spr::propagatedTrackDirection > &trkDirs, double dR, int &nNearTRKs, bool debug=false)
const double a_mipR_
Definition: IsoTrig.cc:166
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
std::vector< bool > * t_TrkNuIsolFlag
Definition: IsoTrig.cc:219
bool goodTrack(const reco::Track *pTrack, math::XYZPoint leadPV, trackSelectionParameters parameters, bool debug=false)
std::vector< bool > * t_TrkPVFlag
Definition: IsoTrig.cc:218
const double a_neutR1_
Definition: IsoTrig.cc:166
std::vector< double > * t_TrkP
Definition: IsoTrig.cc:214
spr::trackSelectionParameters selectionParameters_
Definition: IsoTrig.cc:164
double eCone_ecal(const CaloGeometry *geo, edm::Handle< T > &barrelhits, edm::Handle< T > &endcaphits, const GlobalPoint &hpoint1, const GlobalPoint &point1, double dR, const GlobalVector &trackMom, int &nRecHits, double ebThr=-100, double eeThr=-100, double tMin=-500, double tMax=500, bool debug=false)
const CaloGeometry * geo_
Definition: IsoTrig.cc:199
const double cutCharge_
Definition: IsoTrig.cc:167
std::vector< bool > * t_TrkMissFlag
Definition: IsoTrig.cc:217
double pz() const
z coordinate of momentum vector
Definition: TrackBase.h:646
bool isValid() const
Definition: HandleBase.h:70
std::vector< bool > * t_TrkqltyFlag
Definition: IsoTrig.cc:216
TTree * TrkResTree_
Definition: IsoTrig.cc:207
const MagneticField * bField_
Definition: IsoTrig.cc:198
math::XYZPoint leadPV_
Definition: IsoTrig.cc:200
const double cutMip_
Definition: IsoTrig.cc:166
const double cutNeutral_
Definition: IsoTrig.cc:167
std::vector< bool > * t_TrkselTkFlag
Definition: IsoTrig.cc:215

Member Data Documentation

◆ a_charIsoR_

const double IsoTrig::a_charIsoR_
private

◆ a_coneR_

const double IsoTrig::a_coneR_
private

Definition at line 165 of file IsoTrig.cc.

Referenced by IsoTrig(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ a_mipR_

const double IsoTrig::a_mipR_
private

Definition at line 166 of file IsoTrig.cc.

Referenced by getGoodTracks(), IsoTrig(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ a_neutIsoR_

const double IsoTrig::a_neutIsoR_
private

Definition at line 165 of file IsoTrig.cc.

Referenced by IsoTrig().

◆ a_neutR1_

const double IsoTrig::a_neutR1_
private

Definition at line 166 of file IsoTrig.cc.

Referenced by IsoTrig(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ a_neutR2_

const double IsoTrig::a_neutR2_
private

Definition at line 166 of file IsoTrig.cc.

Referenced by IsoTrig(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ barrelRecHitsHandle_

edm::Handle<EcalRecHitCollection> IsoTrig::barrelRecHitsHandle_
private

Definition at line 193 of file IsoTrig.cc.

Referenced by analyze(), getGoodTracks(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ beamSpotH_

edm::Handle<reco::BeamSpot> IsoTrig::beamSpotH_
private

Definition at line 195 of file IsoTrig.cc.

Referenced by analyze().

◆ bField_

const MagneticField* IsoTrig::bField_
private

◆ bfVal_

double IsoTrig::bfVal_
private

Definition at line 163 of file IsoTrig.cc.

Referenced by analyze(), and GetEtaPhiAtEcal().

◆ changed_

bool IsoTrig::changed_
private

Definition at line 204 of file IsoTrig.cc.

Referenced by analyze(), and beginRun().

◆ ChgIsolnTree_

TTree * IsoTrig::ChgIsolnTree_
private

Definition at line 207 of file IsoTrig.cc.

Referenced by beginJob(), and chgIsolation().

◆ cutCharge_

const double IsoTrig::cutCharge_
private

Definition at line 167 of file IsoTrig.cc.

Referenced by fillCuts(), IsoTrig(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ cutMip_

const double IsoTrig::cutMip_
private

Definition at line 166 of file IsoTrig.cc.

Referenced by fillCuts(), IsoTrig(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ cutNeutral_

const double IsoTrig::cutNeutral_
private

Definition at line 167 of file IsoTrig.cc.

Referenced by fillCuts(), IsoTrig(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ doChgIsolTree_

const bool IsoTrig::doChgIsolTree_
private

Definition at line 156 of file IsoTrig.cc.

Referenced by analyze(), beginJob(), and IsoTrig().

◆ doL2L3_

const bool IsoTrig::doL2L3_
private

Definition at line 155 of file IsoTrig.cc.

Referenced by analyze(), beginJob(), and studyIsolation().

◆ doMipCutTree_

const bool IsoTrig::doMipCutTree_
private

Definition at line 155 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ doStudyIsol_

const bool IsoTrig::doStudyIsol_
private

Definition at line 156 of file IsoTrig.cc.

Referenced by analyze().

◆ doTiming_

const bool IsoTrig::doTiming_
private

Definition at line 155 of file IsoTrig.cc.

Referenced by analyze(), beginJob(), and IsoTrig().

◆ doTrkResTree_

const bool IsoTrig::doTrkResTree_
private

Definition at line 156 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ dr_L1_

const double IsoTrig::dr_L1_
private

Definition at line 165 of file IsoTrig.cc.

Referenced by studyIsolation().

◆ endcapRecHitsHandle_

edm::Handle<EcalRecHitCollection> IsoTrig::endcapRecHitsHandle_
private

Definition at line 194 of file IsoTrig.cc.

Referenced by analyze(), getGoodTracks(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ fs_

edm::Service<TFileService> IsoTrig::fs_
private

Definition at line 206 of file IsoTrig.cc.

Referenced by beginJob(), and endJob().

◆ g_Accepts

TH1I* IsoTrig::g_Accepts
private

Definition at line 268 of file IsoTrig.cc.

Referenced by endJob().

◆ g_Pre

TH1D* IsoTrig::g_Pre
private

Definition at line 267 of file IsoTrig.cc.

Referenced by endJob().

◆ g_PreHLT

TH1D * IsoTrig::g_PreHLT
private

Definition at line 267 of file IsoTrig.cc.

Referenced by endJob().

◆ g_PreL1

TH1D * IsoTrig::g_PreL1
private

Definition at line 267 of file IsoTrig.cc.

Referenced by endJob().

◆ geo_

const CaloGeometry* IsoTrig::geo_
private

◆ h_dEta

TH1D* IsoTrig::h_dEta[9]
private

Definition at line 262 of file IsoTrig.cc.

Referenced by beginJob(), and fillDifferences().

◆ h_dEtaL1

TH1D* IsoTrig::h_dEtaL1[2]
private

Definition at line 261 of file IsoTrig.cc.

Referenced by beginJob(), and studyTrigger().

◆ h_dinvPt

TH1D* IsoTrig::h_dinvPt[9]
private

Definition at line 263 of file IsoTrig.cc.

Referenced by beginJob(), and fillDifferences().

◆ h_dP

TH1D * IsoTrig::h_dP[9]
private

Definition at line 262 of file IsoTrig.cc.

Referenced by beginJob(), and fillDifferences().

◆ h_dPhi

TH1D * IsoTrig::h_dPhi[9]
private

Definition at line 262 of file IsoTrig.cc.

Referenced by beginJob(), and fillDifferences().

◆ h_dPhiL1

TH1D * IsoTrig::h_dPhiL1[2]
private

Definition at line 261 of file IsoTrig.cc.

Referenced by beginJob(), and studyTrigger().

◆ h_dPt

TH1D * IsoTrig::h_dPt[9]
private

Definition at line 262 of file IsoTrig.cc.

Referenced by beginJob(), and fillDifferences().

◆ h_dRL1

TH1D * IsoTrig::h_dRL1[2]
private

Definition at line 261 of file IsoTrig.cc.

Referenced by beginJob(), and studyTrigger().

◆ h_eCalo

TH1D * IsoTrig::h_eCalo[5][6][48]
private

Definition at line 266 of file IsoTrig.cc.

Referenced by beginJob(), and fillEnergy().

◆ h_eHcal

TH1D* IsoTrig::h_eHcal[5][6][48]
private

Definition at line 266 of file IsoTrig.cc.

Referenced by beginJob(), and fillEnergy().

◆ h_eMaxNearP

TH1D* IsoTrig::h_eMaxNearP[2]
private

Definition at line 264 of file IsoTrig.cc.

Referenced by beginJob(), and fillCuts().

◆ h_eMip

TH1D * IsoTrig::h_eMip[2]
private

Definition at line 263 of file IsoTrig.cc.

Referenced by beginJob(), and fillCuts().

◆ h_eNeutIso

TH1D * IsoTrig::h_eNeutIso[2]
private

Definition at line 264 of file IsoTrig.cc.

Referenced by beginJob(), and fillCuts().

◆ h_EnIn

TH1D* IsoTrig::h_EnIn
private

Definition at line 255 of file IsoTrig.cc.

Referenced by beginJob(), and studyMipCut().

◆ h_EnOut

TH1D * IsoTrig::h_EnOut
private

Definition at line 255 of file IsoTrig.cc.

Referenced by beginJob(), and studyMipCut().

◆ h_eta

TH1D * IsoTrig::h_eta[20]
private

Definition at line 260 of file IsoTrig.cc.

Referenced by beginJob(), and fillHist().

◆ h_etaCalibTracks

TH1D* IsoTrig::h_etaCalibTracks[5][2][2]
private

Definition at line 265 of file IsoTrig.cc.

Referenced by beginJob(), and fillCuts().

◆ h_etaMipTracks

TH1D * IsoTrig::h_etaMipTracks[5][2][2]
private

Definition at line 265 of file IsoTrig.cc.

Referenced by beginJob(), and fillCuts().

◆ h_Filters

TH1I * IsoTrig::h_Filters
private

Definition at line 258 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_HLT

TH1I * IsoTrig::h_HLT
private

Definition at line 257 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_L1ObjEnergy

TH1D * IsoTrig::h_L1ObjEnergy
private

Definition at line 259 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_mindR

TH1D * IsoTrig::h_mindR[9]
private

Definition at line 263 of file IsoTrig.cc.

Referenced by beginJob(), and fillDifferences().

◆ h_MipEnMatch

TH2D* IsoTrig::h_MipEnMatch
private

Definition at line 256 of file IsoTrig.cc.

Referenced by beginJob(), and studyMipCut().

◆ h_MipEnNoMatch

TH2D * IsoTrig::h_MipEnNoMatch
private

Definition at line 256 of file IsoTrig.cc.

Referenced by beginJob(), and studyMipCut().

◆ h_nHLT

TH1I* IsoTrig::h_nHLT
private

Definition at line 257 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_nL3Objs

TH1I * IsoTrig::h_nL3Objs
private

Definition at line 258 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_p

TH1D* IsoTrig::h_p[20]
private

Definition at line 260 of file IsoTrig.cc.

Referenced by beginJob(), and fillHist().

◆ h_phi

TH1D * IsoTrig::h_phi[20]
private

Definition at line 260 of file IsoTrig.cc.

Referenced by beginJob(), and fillHist().

◆ h_Pre

TH1I* IsoTrig::h_Pre
private

Definition at line 258 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_PreHLT

TH1I * IsoTrig::h_PreHLT
private

Definition at line 257 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_PreHLTwt

TH1D * IsoTrig::h_PreHLTwt
private

Definition at line 259 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_PreL1

TH1I * IsoTrig::h_PreL1
private

Definition at line 257 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_PreL1wt

TH1D* IsoTrig::h_PreL1wt
private

Definition at line 259 of file IsoTrig.cc.

Referenced by analyze(), and beginJob().

◆ h_pt

TH1D * IsoTrig::h_pt[20]
private

Definition at line 260 of file IsoTrig.cc.

Referenced by beginJob(), and fillHist().

◆ hbhe_

edm::Handle<HBHERecHitCollection> IsoTrig::hbhe_
private

Definition at line 192 of file IsoTrig.cc.

Referenced by analyze(), studyIsolation(), studyMipCut(), and StudyTrkEbyP().

◆ hltPrescaleProvider_

HLTPrescaleProvider IsoTrig::hltPrescaleProvider_
private

Definition at line 151 of file IsoTrig.cc.

Referenced by analyze(), and beginRun().

◆ l1CandTag_

const edm::InputTag IsoTrig::l1CandTag_
private

Definition at line 153 of file IsoTrig.cc.

Referenced by IsoTrig().

◆ l2CandTag_

const edm::InputTag IsoTrig::l2CandTag_
private

Definition at line 153 of file IsoTrig.cc.

Referenced by IsoTrig().

◆ leadPV_

math::XYZPoint IsoTrig::leadPV_
private

◆ maxRunNo_

const int IsoTrig::maxRunNo_
private

Definition at line 168 of file IsoTrig.cc.

Referenced by endJob().

◆ minPTrackValue_

const double IsoTrig::minPTrackValue_
private

Definition at line 159 of file IsoTrig.cc.

Referenced by chgIsolation(), and IsoTrig().

◆ minRunNo_

const int IsoTrig::minRunNo_
private

Definition at line 168 of file IsoTrig.cc.

Referenced by endJob().

◆ MipCutTree_

TTree* IsoTrig::MipCutTree_
private

Definition at line 207 of file IsoTrig.cc.

Referenced by beginJob(), and studyMipCut().

◆ pixCandTag_

const edm::InputTag IsoTrig::pixCandTag_
private

Definition at line 153 of file IsoTrig.cc.

Referenced by IsoTrig().

◆ pixelIsolationConeSizeAtEC_

const std::vector<double> IsoTrig::pixelIsolationConeSizeAtEC_
private

Definition at line 158 of file IsoTrig.cc.

Referenced by chgIsolation(), and IsoTrig().

◆ pixelTrackRefsHB_

std::vector<reco::TrackRef> IsoTrig::pixelTrackRefsHB_
private

Definition at line 191 of file IsoTrig.cc.

Referenced by analyze(), and studyTiming().

◆ pixelTrackRefsHE_

std::vector<reco::TrackRef> IsoTrig::pixelTrackRefsHE_
private

Definition at line 191 of file IsoTrig.cc.

Referenced by analyze(), chgIsolation(), and studyTiming().

◆ pixelTracksSources_

const std::vector<edm::InputTag> IsoTrig::pixelTracksSources_
private

Definition at line 154 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ pLimits_

double IsoTrig::pLimits_[6]
private

Definition at line 205 of file IsoTrig.cc.

Referenced by beginJob(), fillCuts(), fillEnergy(), and IsoTrig().

◆ prelimCone_

const double IsoTrig::prelimCone_
private

Definition at line 160 of file IsoTrig.cc.

Referenced by chgIsolation(), and IsoTrig().

◆ processName_

const std::string IsoTrig::processName_
private

Definition at line 162 of file IsoTrig.cc.

Referenced by beginRun(), and IsoTrig().

◆ rEB_

double IsoTrig::rEB_
private

Definition at line 163 of file IsoTrig.cc.

Referenced by getDistInCM(), GetEtaPhiAtEcal(), and IsoTrig().

◆ recVtxs_

edm::Handle<reco::VertexCollection> IsoTrig::recVtxs_
private

Definition at line 196 of file IsoTrig.cc.

Referenced by analyze(), and chgIsolation().

◆ selectionParameters_

spr::trackSelectionParameters IsoTrig::selectionParameters_
private

◆ t_ECone

std::vector<double>* IsoTrig::t_ECone
private

Definition at line 253 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFcandEmip

std::vector<double>* IsoTrig::t_NFcandEmip
private

Definition at line 237 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFcandEta

std::vector<double>* IsoTrig::t_NFcandEta
private

Definition at line 235 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFcandP

std::vector<double>* IsoTrig::t_NFcandP
private

Definition at line 233 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFcandPhi

std::vector<double>* IsoTrig::t_NFcandPhi
private

Definition at line 236 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFcandPt

std::vector<double>* IsoTrig::t_NFcandPt
private

Definition at line 234 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkcandEmip

std::vector<double>* IsoTrig::t_NFTrkcandEmip
private

Definition at line 242 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkcandEta

std::vector<double>* IsoTrig::t_NFTrkcandEta
private

Definition at line 240 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkcandP

std::vector<double>* IsoTrig::t_NFTrkcandP
private

Definition at line 238 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkcandPhi

std::vector<double>* IsoTrig::t_NFTrkcandPhi
private

Definition at line 241 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkcandPt

std::vector<double>* IsoTrig::t_NFTrkcandPt
private

Definition at line 239 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkChgIsoFlag

std::vector<bool>* IsoTrig::t_NFTrkChgIsoFlag
private

Definition at line 250 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkMinDP1

std::vector<double>* IsoTrig::t_NFTrkMinDP1
private

Definition at line 244 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkMinDR

std::vector<double>* IsoTrig::t_NFTrkMinDR
private

Definition at line 243 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkMipFlag

std::vector<bool>* IsoTrig::t_NFTrkMipFlag
private

Definition at line 252 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkMissFlag

std::vector<bool>* IsoTrig::t_NFTrkMissFlag
private

Definition at line 247 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkNeuIsoFlag

std::vector<bool>* IsoTrig::t_NFTrkNeuIsoFlag
private

Definition at line 251 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkPropFlag

std::vector<bool>* IsoTrig::t_NFTrkPropFlag
private

Definition at line 249 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkPVFlag

std::vector<bool>* IsoTrig::t_NFTrkPVFlag
private

Definition at line 248 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkqltyFlag

std::vector<bool>* IsoTrig::t_NFTrkqltyFlag
private

Definition at line 246 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_NFTrkselTkFlag

std::vector<bool>* IsoTrig::t_NFTrkselTkFlag
private

Definition at line 245 of file IsoTrig.cc.

Referenced by beginJob(), clearMipCutTreeVectors(), pushMipCutTreeVecs(), and ~IsoTrig().

◆ t_nGoodTk

std::vector<int>* IsoTrig::t_nGoodTk
private

Definition at line 211 of file IsoTrig.cc.

Referenced by beginJob(), getGoodTracks(), and ~IsoTrig().

◆ t_nPixCand

std::vector<int>* IsoTrig::t_nPixCand
private

Definition at line 209 of file IsoTrig.cc.

Referenced by beginJob(), studyTiming(), and ~IsoTrig().

◆ t_nPixSeed

std::vector<int>* IsoTrig::t_nPixSeed
private

Definition at line 210 of file IsoTrig.cc.

Referenced by beginJob(), studyTiming(), and ~IsoTrig().

◆ t_PixcandEta

std::vector<double>* IsoTrig::t_PixcandEta
private

Definition at line 223 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixcandMaxP

std::vector<std::vector<double> >* IsoTrig::t_PixcandMaxP
private

Definition at line 225 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixcandP

std::vector<double>* IsoTrig::t_PixcandP
private

Definition at line 221 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixcandPhi

std::vector<double>* IsoTrig::t_PixcandPhi
private

Definition at line 224 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixcandPt

std::vector<double>* IsoTrig::t_PixcandPt
private

Definition at line 222 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixTrkcandEta

std::vector<double>* IsoTrig::t_PixTrkcandEta
private

Definition at line 228 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixTrkcandMaxP

std::vector<double>* IsoTrig::t_PixTrkcandMaxP
private

Definition at line 230 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixTrkcandP

std::vector<double>* IsoTrig::t_PixTrkcandP
private

Definition at line 226 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixTrkcandPhi

std::vector<double>* IsoTrig::t_PixTrkcandPhi
private

Definition at line 229 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixTrkcandPt

std::vector<double>* IsoTrig::t_PixTrkcandPt
private

Definition at line 227 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_PixTrkcandselTk

std::vector<bool>* IsoTrig::t_PixTrkcandselTk
private

Definition at line 231 of file IsoTrig.cc.

Referenced by beginJob(), clearChgIsolnTreeVectors(), pushChgIsolnTreeVecs(), and ~IsoTrig().

◆ t_timeL2Prod

std::vector<double>* IsoTrig::t_timeL2Prod
private

Definition at line 208 of file IsoTrig.cc.

Referenced by beginJob(), studyTiming(), and ~IsoTrig().

◆ t_TrkhCone

std::vector<double>* IsoTrig::t_TrkhCone
private

Definition at line 213 of file IsoTrig.cc.

Referenced by beginJob(), StudyTrkEbyP(), and ~IsoTrig().

◆ t_TrkMissFlag

std::vector<bool>* IsoTrig::t_TrkMissFlag
private

Definition at line 217 of file IsoTrig.cc.

Referenced by beginJob(), StudyTrkEbyP(), and ~IsoTrig().

◆ t_TrkNuIsolFlag

std::vector<bool>* IsoTrig::t_TrkNuIsolFlag
private

Definition at line 219 of file IsoTrig.cc.

Referenced by beginJob(), StudyTrkEbyP(), and ~IsoTrig().

◆ t_TrkP

std::vector<double>* IsoTrig::t_TrkP
private

Definition at line 214 of file IsoTrig.cc.

Referenced by beginJob(), StudyTrkEbyP(), and ~IsoTrig().

◆ t_TrkPVFlag

std::vector<bool>* IsoTrig::t_TrkPVFlag
private

Definition at line 218 of file IsoTrig.cc.

Referenced by beginJob(), StudyTrkEbyP(), and ~IsoTrig().

◆ t_TrkqltyFlag

std::vector<bool>* IsoTrig::t_TrkqltyFlag
private

Definition at line 216 of file IsoTrig.cc.

Referenced by beginJob(), StudyTrkEbyP(), and ~IsoTrig().

◆ t_TrkselTkFlag

std::vector<bool>* IsoTrig::t_TrkselTkFlag
private

Definition at line 215 of file IsoTrig.cc.

Referenced by beginJob(), StudyTrkEbyP(), and ~IsoTrig().

◆ tauUnbiasCone_

const double IsoTrig::tauUnbiasCone_
private

Definition at line 160 of file IsoTrig.cc.

Referenced by chgIsolation(), IsoTrig(), and studyTiming().

◆ theTrackQuality_

std::string IsoTrig::theTrackQuality_
private

◆ TimingTree_

TTree * IsoTrig::TimingTree_
private

Definition at line 207 of file IsoTrig.cc.

Referenced by beginJob(), and studyTiming().

◆ tok_bs_

edm::EDGetTokenT<reco::BeamSpot> IsoTrig::tok_bs_
private

Definition at line 175 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_EB_

edm::EDGetTokenT<EcalRecHitCollection> IsoTrig::tok_EB_
private

Definition at line 176 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_EE_

edm::EDGetTokenT<EcalRecHitCollection> IsoTrig::tok_EE_
private

Definition at line 177 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_genTrack_

edm::EDGetTokenT<reco::TrackCollection> IsoTrig::tok_genTrack_
private

Definition at line 173 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_geom_

edm::ESGetToken<CaloGeometry, CaloGeometryRecord> IsoTrig::tok_geom_
private

Definition at line 188 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_hbhe_

edm::EDGetTokenT<HBHERecHitCollection> IsoTrig::tok_hbhe_
private

Definition at line 178 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_hlt_

Definition at line 172 of file IsoTrig.cc.

Referenced by IsoTrig().

◆ tok_l1cand_

Definition at line 184 of file IsoTrig.cc.

Referenced by analyze(), getGoodTracks(), IsoTrig(), and studyTiming().

◆ tok_l2cand_

Definition at line 185 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_lumi_

edm::EDGetTokenT<LumiDetails> IsoTrig::tok_lumi_
private

Definition at line 169 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_magField_

edm::ESGetToken<MagneticField, IdealMagneticFieldRecord> IsoTrig::tok_magField_
private

Definition at line 189 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_pixtk_

Definition at line 183 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_pixtks_

std::vector<edm::EDGetTokenT<reco::TrackCollection> > IsoTrig::tok_pixtks_
private

Definition at line 186 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_recVtx_

edm::EDGetTokenT<reco::VertexCollection> IsoTrig::tok_recVtx_
private

Definition at line 174 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_SeedingLayerHB_

edm::EDGetTokenT<SeedingLayerSetsHits> IsoTrig::tok_SeedingLayerHB_
private

Definition at line 180 of file IsoTrig.cc.

Referenced by IsoTrig(), and studyTiming().

◆ tok_SeedingLayerHE_

edm::EDGetTokenT<SeedingLayerSetsHits> IsoTrig::tok_SeedingLayerHE_
private

Definition at line 181 of file IsoTrig.cc.

Referenced by IsoTrig(), and studyTiming().

◆ tok_SiPixelRecHits_

edm::EDGetTokenT<SiPixelRecHitCollection> IsoTrig::tok_SiPixelRecHits_
private

Definition at line 182 of file IsoTrig.cc.

Referenced by IsoTrig(), and studyTiming().

◆ tok_trigEvt_

edm::EDGetTokenT<trigger::TriggerEvent> IsoTrig::tok_trigEvt_
private

Definition at line 170 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_trigRes_

edm::EDGetTokenT<edm::TriggerResults> IsoTrig::tok_trigRes_
private

Definition at line 171 of file IsoTrig.cc.

Referenced by analyze(), and IsoTrig().

◆ tok_verthb_

edm::EDGetTokenT<reco::VertexCollection> IsoTrig::tok_verthb_
private

Definition at line 179 of file IsoTrig.cc.

Referenced by IsoTrig(), and studyTiming().

◆ tok_verthe_

edm::EDGetTokenT<reco::VertexCollection> IsoTrig::tok_verthe_
private

Definition at line 179 of file IsoTrig.cc.

Referenced by IsoTrig(), and studyTiming().

◆ trigList_

std::unordered_map<unsigned int, unsigned int> IsoTrig::trigList_
private

Definition at line 202 of file IsoTrig.cc.

Referenced by analyze(), and endJob().

◆ trigNames_

const std::vector<std::string> IsoTrig::trigNames_
private

Definition at line 152 of file IsoTrig.cc.

Referenced by analyze(), and endJob().

◆ trigPreList_

std::unordered_map<unsigned int, const std::pair<double, double> > IsoTrig::trigPreList_
private

Definition at line 203 of file IsoTrig.cc.

Referenced by analyze(), and endJob().

◆ TrkResTree_

TTree * IsoTrig::TrkResTree_
private

Definition at line 207 of file IsoTrig.cc.

Referenced by beginJob(), and StudyTrkEbyP().

◆ vec_

std::vector<math::XYZTLorentzVector> IsoTrig::vec_[3]
private

Definition at line 269 of file IsoTrig.cc.

Referenced by analyze(), etaPhiTrigger(), studyIsolation(), and studyTrigger().

◆ verbosity_

const int IsoTrig::verbosity_
private

◆ vtxCutIsol_

const double IsoTrig::vtxCutIsol_
private

Definition at line 159 of file IsoTrig.cc.

Referenced by chgIsolation(), and IsoTrig().

◆ vtxCutSeed_

const double IsoTrig::vtxCutSeed_
private

Definition at line 159 of file IsoTrig.cc.

Referenced by chgIsolation(), IsoTrig(), and studyTiming().

◆ zEE_

double IsoTrig::zEE_
private

Definition at line 163 of file IsoTrig.cc.

Referenced by getDistInCM(), GetEtaPhiAtEcal(), and IsoTrig().