CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes
AlCaIsoTracksFilter Class Reference
Inheritance diagram for AlCaIsoTracksFilter:
edm::stream::EDFilter< edm::GlobalCache< AlCaIsoTracks::Counters > > edm::stream::EDFilterBase edm::ProducerBase edm::EDConsumerBase edm::ProductRegistryHelper

Public Member Functions

 AlCaIsoTracksFilter (edm::ParameterSet const &, const AlCaIsoTracks::Counters *count)
 
void endStream () override
 
bool filter (edm::Event &, edm::EventSetup const &) override
 
 ~AlCaIsoTracksFilter () override
 
- Public Member Functions inherited from edm::stream::EDFilter< edm::GlobalCache< AlCaIsoTracks::Counters > >
 EDFilter ()=default
 
bool hasAbilityToProduceInLumis () const final
 
bool hasAbilityToProduceInRuns () const final
 
- Public Member Functions inherited from edm::stream::EDFilterBase
 EDFilterBase ()
 
ModuleDescription const & moduleDescription () const
 
 ~EDFilterBase () override
 
- Public Member Functions inherited from edm::ProducerBase
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
std::vector< edm::ProductResolverIndex > const & indiciesForPutProducts (BranchType iBranchType) const
 
 ProducerBase ()
 
std::vector< edm::ProductResolverIndex > const & putTokenIndexToProductResolverIndex () const
 
void registerProducts (ProducerBase *, ProductRegistry *, ModuleDescription const &)
 
std::function< void(BranchDescription const &)> registrationCallback () const
 used by the fwk to register list of products More...
 
void resolvePutIndicies (BranchType iBranchType, ModuleToResolverIndicies const &iIndicies, std::string const &moduleLabel)
 
 ~ProducerBase () noexcept(false) 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
 
ESProxyIndex const * esGetTokenIndices (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::vector< ModuleDescription const * > &modules, 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
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
ProductResolverIndexAndSkipBit uncheckedIndexFrom (EDGetToken) const
 
void updateLookup (BranchType iBranchType, ProductResolverIndexHelper const &, bool iPrefetchMayGet)
 
void updateLookup (eventsetup::ESRecordsToProxyIndices const &)
 
virtual ~EDConsumerBase () noexcept(false)
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &descriptions)
 
static void globalEndJob (const AlCaIsoTracks::Counters *counters)
 
static std::unique_ptr< AlCaIsoTracks::CountersinitializeGlobalCache (edm::ParameterSet const &iConfig)
 
- Static Public Member Functions inherited from edm::stream::EDFilterBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 

Private Member Functions

void beginRun (edm::Run const &, edm::EventSetup const &) override
 
void endRun (edm::Run const &, edm::EventSetup const &) override
 

Private Attributes

double a_charIsoR_
 
const double a_coneR_
 
const double a_mipR_
 
const double eEcalMax_
 
const double eIsolate_
 
const double hitEthrEB_
 
const double hitEthrEE0_
 
const double hitEthrEE1_
 
const double hitEthrEE2_
 
const double hitEthrEE3_
 
const double hitEthrEEHi_
 
const double hitEthrEELo_
 
HLTConfigProvider hltConfig_
 
const edm::InputTag labelEB_
 
const edm::InputTag labelEE_
 
const edm::InputTag labelGenTrack_
 
const edm::InputTag labelHBHE_
 
const edm::InputTag labelRecVtx_
 
const double maxRestrictionP_
 
unsigned int nAll_
 
unsigned int nGood_
 
unsigned int nHigh_
 
unsigned int nRange_
 
unsigned int nRun_
 
const int preScale_
 
const int preScaleH_
 
const std::string processName_
 
const double pTrackH_
 
const double pTrackHigh_
 
const double pTrackLow_
 
const double pTrackMin_
 
spr::trackSelectionParameters selectionParameter_
 
const double slopeRestrictionP_
 
const std::string theTrackQuality_
 
const edm::InputTag theTriggerResultsLabel_
 
edm::EDGetTokenT< reco::BeamSpottok_bs_
 
edm::EDGetTokenT< EcalRecHitCollectiontok_EB_
 
edm::EDGetTokenT< EcalRecHitCollectiontok_EE_
 
edm::EDGetTokenT< reco::TrackCollectiontok_genTrack_
 
edm::EDGetTokenT< HBHERecHitCollectiontok_hbhe_
 
edm::EDGetTokenT< reco::VertexCollectiontok_recVtx_
 
edm::EDGetTokenT< trigger::TriggerEventtok_trigEvt_
 
edm::EDGetTokenT< edm::TriggerResultstok_trigRes_
 
const edm::InputTag triggerEvent_
 
const std::vector< std::string > trigNames_
 

Additional Inherited Members

- Public Types inherited from edm::stream::EDFilter< edm::GlobalCache< AlCaIsoTracks::Counters > >
typedef CacheContexts< T... > CacheTypes
 
typedef CacheTypes::GlobalCache GlobalCache
 
typedef AbilityChecker< T... > HasAbility
 
typedef CacheTypes::LuminosityBlockCache LuminosityBlockCache
 
typedef LuminosityBlockContextT< LuminosityBlockCache, RunCache, GlobalCacheLuminosityBlockContext
 
typedef CacheTypes::LuminosityBlockSummaryCache LuminosityBlockSummaryCache
 
typedef CacheTypes::RunCache RunCache
 
typedef RunContextT< RunCache, GlobalCacheRunContext
 
typedef CacheTypes::RunSummaryCache RunSummaryCache
 
- Public Types inherited from edm::stream::EDFilterBase
typedef EDFilterAdaptorBase ModuleType
 
- Public Types inherited from edm::ProducerBase
using ModuleToResolverIndicies = std::unordered_multimap< std::string, std::tuple< edm::TypeID const *, const char *, edm::ProductResolverIndex >>
 
typedef ProductRegistryHelper::TypeLabelList TypeLabelList
 
- 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)
 
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 ProductType , BranchType B = InEvent>
void consumesMany ()
 
void consumesMany (const TypeToGet &id)
 
template<BranchType B>
void consumesMany (const TypeToGet &id)
 
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<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)
 

Detailed Description

Definition at line 68 of file AlCaIsoTracksFilter.cc.

Constructor & Destructor Documentation

AlCaIsoTracksFilter::AlCaIsoTracksFilter ( edm::ParameterSet const &  ,
const AlCaIsoTracks::Counters count 
)
explicit

Definition at line 126 of file AlCaIsoTracksFilter.cc.

References a_charIsoR_, a_coneR_, a_mipR_, eIsolate_, edm::ParameterSet::getParameter(), hitEthrEB_, hitEthrEE0_, hitEthrEE1_, hitEthrEE2_, hitEthrEE3_, hitEthrEEHi_, hitEthrEELo_, gen::k, labelEB_, labelEE_, labelGenTrack_, labelHBHE_, labelRecVtx_, spr::trackSelectionParameters::maxChi2, spr::trackSelectionParameters::maxDpOverP, spr::trackSelectionParameters::maxDxyPV, spr::trackSelectionParameters::maxDzPV, spr::trackSelectionParameters::maxInMiss, spr::trackSelectionParameters::maxOutMiss, maxRestrictionP_, spr::trackSelectionParameters::minLayerCrossed, spr::trackSelectionParameters::minOuterHit, spr::trackSelectionParameters::minPt, spr::trackSelectionParameters::minQuality, preScale_, preScaleH_, pTrackH_, pTrackHigh_, pTrackLow_, reco::TrackBase::qualityByName(), selectionParameter_, slopeRestrictionP_, theTrackQuality_, theTriggerResultsLabel_, tok_bs_, tok_EB_, tok_EE_, tok_genTrack_, tok_hbhe_, tok_recVtx_, tok_trigEvt_, tok_trigRes_, triggerEvent_, and trigNames_.

127  : trigNames_(iConfig.getParameter<std::vector<std::string> >("triggers")),
128  labelGenTrack_(iConfig.getParameter<edm::InputTag>("labelTrack")),
129  labelRecVtx_(iConfig.getParameter<edm::InputTag>("labelVertex")),
130  labelEB_(iConfig.getParameter<edm::InputTag>("labelEBRecHit")),
131  labelEE_(iConfig.getParameter<edm::InputTag>("labelEERecHit")),
132  labelHBHE_(iConfig.getParameter<edm::InputTag>("labelHBHERecHit")),
133  triggerEvent_(iConfig.getParameter<edm::InputTag>("labelTriggerEvent")),
134  theTriggerResultsLabel_(iConfig.getParameter<edm::InputTag>("labelTriggerResult")),
135  processName_(iConfig.getParameter<std::string>("processName")),
136  a_coneR_(iConfig.getParameter<double>("coneRadius")),
137  a_mipR_(iConfig.getParameter<double>("coneRadiusMIP")),
138  pTrackMin_(iConfig.getParameter<double>("minimumTrackP")),
139  eEcalMax_(iConfig.getParameter<double>("maximumEcalEnergy")),
140  maxRestrictionP_(iConfig.getParameter<double>("maxTrackP")),
141  slopeRestrictionP_(iConfig.getParameter<double>("slopeTrackP")),
142  eIsolate_(iConfig.getParameter<double>("isolationEnergy")),
143  hitEthrEB_(iConfig.getParameter<double>("EBHitEnergyThreshold")),
144  hitEthrEE0_(iConfig.getParameter<double>("EEHitEnergyThreshold0")),
145  hitEthrEE1_(iConfig.getParameter<double>("EEHitEnergyThreshold1")),
146  hitEthrEE2_(iConfig.getParameter<double>("EEHitEnergyThreshold2")),
147  hitEthrEE3_(iConfig.getParameter<double>("EEHitEnergyThreshold3")),
148  hitEthrEELo_(iConfig.getParameter<double>("EEHitEnergyThresholdLow")),
149  hitEthrEEHi_(iConfig.getParameter<double>("EEHitEnergyThresholdHigh")),
150  pTrackLow_(iConfig.getParameter<double>("momentumRangeLow")),
151  pTrackHigh_(iConfig.getParameter<double>("momentumRangeHigh")),
152  pTrackH_(iConfig.getParameter<double>("momentumHigh")),
153  preScale_(iConfig.getParameter<int>("preScaleFactor")),
154  preScaleH_(iConfig.getParameter<int>("preScaleHigh")),
155  theTrackQuality_(iConfig.getParameter<std::string>("trackQuality")),
156  nRun_(0),
157  nAll_(0),
158  nGood_(0),
159  nRange_(0),
160  nHigh_(0) {
161  //now do what ever initialization is needed
162  const double isolationRadius(28.9);
163  // Different isolation cuts are described in DN-2016/029
164  // Tight cut uses 2 GeV; Loose cut uses 10 GeV
165  // Eta dependent cut uses (maxRestrictionP_ * exp(|ieta|*log(2.5)/18))
166  // with the factor for exponential slopeRestrictionP_ = log(2.5)/18
167  // maxRestrictionP_ = 8 GeV as came from a study
169  selectionParameter_.minPt = iConfig.getParameter<double>("minTrackPt");
170  ;
171  selectionParameter_.minQuality = trackQuality_;
172  selectionParameter_.maxDxyPV = iConfig.getParameter<double>("maxDxyPV");
173  selectionParameter_.maxDzPV = iConfig.getParameter<double>("maxDzPV");
174  selectionParameter_.maxChi2 = iConfig.getParameter<double>("maxChi2");
175  selectionParameter_.maxDpOverP = iConfig.getParameter<double>("maxDpOverP");
176  selectionParameter_.minOuterHit = iConfig.getParameter<int>("minOuterHit");
177  selectionParameter_.minLayerCrossed = iConfig.getParameter<int>("minLayerCrossed");
178  selectionParameter_.maxInMiss = iConfig.getParameter<int>("maxInMiss");
179  selectionParameter_.maxOutMiss = iConfig.getParameter<int>("maxOutMiss");
180  a_charIsoR_ = a_coneR_ + isolationRadius;
181 
182  // define tokens for access
183  tok_trigEvt_ = consumes<trigger::TriggerEvent>(triggerEvent_);
184  tok_trigRes_ = consumes<edm::TriggerResults>(theTriggerResultsLabel_);
185  tok_genTrack_ = consumes<reco::TrackCollection>(labelGenTrack_);
186  tok_recVtx_ = consumes<reco::VertexCollection>(labelRecVtx_);
187  tok_bs_ = consumes<reco::BeamSpot>(iConfig.getParameter<edm::InputTag>("labelBeamSpot"));
188 
189  tok_EB_ = consumes<EcalRecHitCollection>(labelEB_);
190  tok_EE_ = consumes<EcalRecHitCollection>(labelEE_);
191  tok_hbhe_ = consumes<HBHERecHitCollection>(labelHBHE_);
192 
193  edm::LogInfo("HcalIsoTrack") << "Parameters read from config file \n"
194  << "\t minPt " << selectionParameter_.minPt << "\t theTrackQuality " << theTrackQuality_
195  << "\t minQuality " << selectionParameter_.minQuality << "\t maxDxyPV "
197  << "\t maxChi2 " << selectionParameter_.maxChi2 << "\t maxDpOverP "
199  << "\t minLayerCrossed " << selectionParameter_.minLayerCrossed << "\t maxInMiss "
201  << "\n"
202  << "\t a_coneR " << a_coneR_ << "\t a_charIsoR " << a_charIsoR_ << "\t a_mipR "
203  << a_mipR_ << "\t maxRestrictionP_ " << maxRestrictionP_ << "\t slopeRestrictionP_ "
204  << slopeRestrictionP_ << "\t eIsolate_ " << eIsolate_ << "\n"
205  << "\t Precale factor " << preScale_ << "\t in momentum range " << pTrackLow_ << ":"
206  << pTrackHigh_ << " and prescale factor " << preScaleH_ << " for p > " << pTrackH_
207  << " Threshold for EB " << hitEthrEB_ << " EE " << hitEthrEE0_ << ":" << hitEthrEE1_
208  << ":" << hitEthrEE2_ << ":" << hitEthrEE3_ << ":" << hitEthrEELo_ << ":"
209  << hitEthrEEHi_;
210 
211  for (unsigned int k = 0; k < trigNames_.size(); ++k)
212  edm::LogInfo("HcalIsoTrack") << "Trigger[" << k << "] " << trigNames_[k];
213 } // AlCaIsoTracksFilter::AlCaIsoTracksFilter constructor
const edm::InputTag labelEE_
const double slopeRestrictionP_
const edm::InputTag labelRecVtx_
spr::trackSelectionParameters selectionParameter_
edm::EDGetTokenT< reco::TrackCollection > tok_genTrack_
TrackQuality
track quality
Definition: TrackBase.h:151
const std::string theTrackQuality_
const std::string processName_
edm::EDGetTokenT< reco::BeamSpot > tok_bs_
edm::EDGetTokenT< reco::VertexCollection > tok_recVtx_
const std::vector< std::string > trigNames_
const edm::InputTag triggerEvent_
const edm::InputTag labelGenTrack_
const edm::InputTag labelHBHE_
edm::EDGetTokenT< trigger::TriggerEvent > tok_trigEvt_
edm::EDGetTokenT< HBHERecHitCollection > tok_hbhe_
edm::EDGetTokenT< EcalRecHitCollection > tok_EB_
int k[5][pyjets_maxn]
edm::EDGetTokenT< edm::TriggerResults > tok_trigRes_
edm::EDGetTokenT< EcalRecHitCollection > tok_EE_
static TrackQuality qualityByName(const std::string &name)
Definition: TrackBase.cc:134
const edm::InputTag theTriggerResultsLabel_
reco::TrackBase::TrackQuality minQuality
const edm::InputTag labelEB_
AlCaIsoTracksFilter::~AlCaIsoTracksFilter ( )
override

Definition at line 215 of file AlCaIsoTracksFilter.cc.

215 {}

Member Function Documentation

void AlCaIsoTracksFilter::beginRun ( edm::Run const &  iRun,
edm::EventSetup const &  iSetup 
)
overrideprivatevirtual

Reimplemented from edm::stream::EDFilterBase.

Definition at line 430 of file AlCaIsoTracksFilter.cc.

References hltConfig_, HLTConfigProvider::init(), nRun_, processName_, and edm::RunBase::run().

430  {
431  bool changed(false);
432  edm::LogInfo("HcalIsoTrack") << "Run[" << nRun_ << "] " << iRun.run() << " hltconfig.init "
433  << hltConfig_.init(iRun, iSetup, processName_, changed);
434 }
const std::string processName_
bool init(const edm::Run &iRun, const edm::EventSetup &iSetup, const std::string &processName, bool &changed)
d&#39;tor
HLTConfigProvider hltConfig_
void AlCaIsoTracksFilter::endRun ( edm::Run const &  iRun,
edm::EventSetup const &   
)
overrideprivatevirtual

Reimplemented from edm::stream::EDFilterBase.

Definition at line 437 of file AlCaIsoTracksFilter.cc.

References nRun_, and edm::RunBase::run().

437  {
438  ++nRun_;
439  edm::LogInfo("HcalIsoTrack") << "endRun[" << nRun_ << "] " << iRun.run();
440 }
void AlCaIsoTracksFilter::endStream ( )
overridevirtual

Reimplemented from edm::stream::EDFilterBase.

Definition at line 416 of file AlCaIsoTracksFilter.cc.

References nAll_, nGood_, nHigh_, and nRange_.

416  {
417  globalCache()->nAll_ += nAll_;
418  globalCache()->nGood_ += nGood_;
419  globalCache()->nRange_ += nRange_;
420  globalCache()->nHigh_ += nHigh_;
421 }
void AlCaIsoTracksFilter::fillDescriptions ( edm::ConfigurationDescriptions descriptions)
static

Definition at line 443 of file AlCaIsoTracksFilter.cc.

References edm::ConfigurationDescriptions::add(), edm::ParameterSetDescription::add(), DEFINE_FWK_MODULE, and AlCaHLTBitMon_QueryRunRegistry::string.

443  {
445  desc.add<edm::InputTag>("labelTrack", edm::InputTag("generalTracks"));
446  desc.add<edm::InputTag>("labelVertex", edm::InputTag("offlinePrimaryVertices"));
447  desc.add<edm::InputTag>("labelBeamSpot", edm::InputTag("offlineBeamSpot"));
448  desc.add<edm::InputTag>("labelEBRecHit", edm::InputTag("ecalRecHit", "EcalRecHitsEB"));
449  desc.add<edm::InputTag>("labelEERecHit", edm::InputTag("ecalRecHit", "EcalRecHitsEE"));
450  desc.add<edm::InputTag>("labelHBHERecHit", edm::InputTag("hbhereco"));
451  desc.add<edm::InputTag>("labelTriggerEvent", edm::InputTag("hltTriggerSummaryAOD", "", "HLT"));
452  desc.add<edm::InputTag>("labelTriggerResult", edm::InputTag("TriggerResults", "", "HLT"));
453  std::vector<std::string> trigger;
454  desc.add<std::vector<std::string> >("triggers", trigger);
455  desc.add<std::string>("processName", "HLT");
456  // following 10 parameters are parameters to select good tracks
457  desc.add<std::string>("trackQuality", "highPurity");
458  desc.add<double>("minTrackPt", 1.0);
459  desc.add<double>("maxDxyPV", 10.0);
460  desc.add<double>("maxDzPV", 100.0);
461  desc.add<double>("maxChi2", 5.0);
462  desc.add<double>("maxDpOverP", 0.1);
463  desc.add<int>("minOuterHit", 4);
464  desc.add<int>("minLayerCrossed", 8);
465  desc.add<int>("maxInMiss", 2);
466  desc.add<int>("maxOutMiss", 2);
467  // Minimum momentum of selected isolated track and signal zone
468  desc.add<double>("coneRadius", 34.98);
469  desc.add<double>("minimumTrackP", 20.0);
470  // signal zone in ECAL and MIP energy cutoff
471  desc.add<double>("coneRadiusMIP", 14.0);
472  desc.add<double>("maximumEcalEnergy", 100.0);
473  // following 3 parameters are for isolation cuts and described in the code
474  desc.add<double>("maxTrackP", 8.0);
475  desc.add<double>("slopeTrackP", 0.05090504066);
476  desc.add<double>("isolationEnergy", 10.0);
477  // energy thershold for ECAL (from Egamma group)
478  desc.add<double>("EBHitEnergyThreshold", 0.08);
479  desc.add<double>("EEHitEnergyThreshold0", 0.30);
480  desc.add<double>("EEHitEnergyThreshold1", 0.00);
481  desc.add<double>("EEHitEnergyThreshold2", 0.00);
482  desc.add<double>("EEHitEnergyThreshold3", 0.00);
483  desc.add<double>("EEHitEnergyThresholdLow", 0.30);
484  desc.add<double>("EEHitEnergyThresholdHigh", 0.30);
485  // Prescale events only containing isolated tracks in the range
486  desc.add<double>("momentumRangeLow", 20.0);
487  desc.add<double>("momentumRangeHigh", 40.0);
488  desc.add<int>("preScaleFactor", 10);
489  desc.add<double>("momentumHigh", 60.0);
490  desc.add<int>("preScaleHigh", 2);
491  descriptions.add("alcaIsoTracksFilter", desc);
492 }
ParameterDescriptionBase * add(U const &iLabel, T const &value)
void add(std::string const &label, ParameterSetDescription const &psetDescription)
bool AlCaIsoTracksFilter::filter ( edm::Event iEvent,
edm::EventSetup const &  iSetup 
)
overridevirtual

Implements edm::stream::EDFilterBase.

Definition at line 222 of file AlCaIsoTracksFilter.cc.

References a_charIsoR_, a_mipR_, funct::abs(), accept(), edm::HLTGlobalStatus::accept(), ecalTB2006H4_GenSimDigiReco_cfg::bField, edm::EventBase::bunchCrossing(), spr::chargeIsolationCone(), EcalBarrel, spr::eCone_ecal(), eEcalMax_, eIsolate_, PVValHelper::eta, PV3DBase< T, PVType, FrameType >::eta(), reco::TrackBase::eta(), edm::EventID::event(), JetChargeProducer_cfi::exp, spr::find(), edm::EventSetup::get(), edm::Event::getByToken(), CaloGeometry::getPosition(), spr::goodTrack(), photonIsolationHIProducer_cfi::hbhe, hitEthrEB_, hitEthrEE0_, hitEthrEE1_, hitEthrEE2_, hitEthrEE3_, hitEthrEEHi_, hitEthrEELo_, ValidationMatrix::hlt, mps_fire::i, edm::EventBase::id(), HcalDetId::ietaAbs(), edm::HandleBase::isValid(), gen::k, edm::InputTag::label(), labelEB_, labelEE_, labelGenTrack_, labelHBHE_, edm::EventBase::luminosityBlock(), maxRestrictionP_, electrons_cff::modules, nAll_, nGood_, nHigh_, nRange_, nTracks(), reco::TrackBase::p(), reco::TrackBase::phi(), reco::BeamSpot::position(), preScale_, preScaleH_, edm::Handle< T >::product(), edm::ESHandle< T >::product(), spr::propagateCALO(), reco::TrackBase::pt(), pTrackH_, pTrackHigh_, pTrackLow_, pTrackMin_, reco::TrackBase::px(), reco::TrackBase::py(), reco::TrackBase::pz(), edm::EventID::run(), selectionParameter_, edm::HLTGlobalStatus::size(), slopeRestrictionP_, theTrackQuality_, tok_bs_, tok_EB_, tok_EE_, tok_genTrack_, tok_hbhe_, tok_recVtx_, tok_trigEvt_, tok_trigRes_, triggerEvent_, edm::TriggerNames::triggerNames(), edm::Event::triggerNames(), triggerResults, trigNames_, x, y, and z.

Referenced by Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::filter(), Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::find(), Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::setDataAccessor(), and Vispa.Plugins.Browser.BrowserTabController.BrowserTabController::switchCenterView().

222  {
223  bool accept(false);
224  ++nAll_;
225  edm::LogVerbatim("HcalIsoTrack") << "Run " << iEvent.id().run() << " Event " << iEvent.id().event() << " Luminosity "
226  << iEvent.luminosityBlock() << " Bunch " << iEvent.bunchCrossing();
227 
228  //Step1: Find if the event passes one of the chosen triggers
229  bool triggerSatisfied(false);
230  if (trigNames_.empty()) {
231  triggerSatisfied = true;
232  } else {
233  trigger::TriggerEvent triggerEvent;
234  edm::Handle<trigger::TriggerEvent> triggerEventHandle;
235  iEvent.getByToken(tok_trigEvt_, triggerEventHandle);
236  if (!triggerEventHandle.isValid()) {
237  edm::LogWarning("HcalIsoTrack") << "Error! Can't get the product " << triggerEvent_.label();
238  } else {
239  triggerEvent = *(triggerEventHandle.product());
240 
243  iEvent.getByToken(tok_trigRes_, triggerResults);
244  if (triggerResults.isValid()) {
245  std::vector<std::string> modules;
246  const edm::TriggerNames& triggerNames = iEvent.triggerNames(*triggerResults);
247  const std::vector<std::string>& triggerNames_ = triggerNames.triggerNames();
248  for (unsigned int iHLT = 0; iHLT < triggerResults->size(); iHLT++) {
249  int hlt = triggerResults->accept(iHLT);
250  for (unsigned int i = 0; i < trigNames_.size(); ++i) {
251  if (triggerNames_[iHLT].find(trigNames_[i]) != std::string::npos) {
252  if (hlt > 0)
253  triggerSatisfied = true;
254  edm::LogVerbatim("HcalIsoTrack")
255  << triggerNames_[iHLT] << " has got HLT flag " << hlt << ":" << triggerSatisfied;
256  if (triggerSatisfied)
257  break;
258  }
259  }
260  }
261  }
262  }
263  }
264 
265  //Step2: Get geometry/B-field information
266  if (triggerSatisfied) {
267  //Get magnetic field
269  iSetup.get<IdealMagneticFieldRecord>().get(bFieldH);
270  const MagneticField* bField = bFieldH.product();
271  // get handles to calogeometry and calotopology
273  iSetup.get<CaloGeometryRecord>().get(pG);
274  const CaloGeometry* geo = pG.product();
275 
276  //Also relevant information to extrapolate tracks to Hcal surface
277  bool foundCollections(true);
278  //Get track collection
280  iEvent.getByToken(tok_genTrack_, trkCollection);
281  if (!trkCollection.isValid()) {
282  edm::LogWarning("HcalIsoTrack") << "Cannot access the collection " << labelGenTrack_;
283  foundCollections = false;
284  }
285 
286  //Define the best vertex and the beamspot
288  iEvent.getByToken(tok_recVtx_, recVtxs);
289  edm::Handle<reco::BeamSpot> beamSpotH;
290  iEvent.getByToken(tok_bs_, beamSpotH);
291  math::XYZPoint leadPV(0, 0, 0);
292  if (!recVtxs->empty() && !((*recVtxs)[0].isFake())) {
293  leadPV = math::XYZPoint((*recVtxs)[0].x(), (*recVtxs)[0].y(), (*recVtxs)[0].z());
294  } else if (beamSpotH.isValid()) {
295  leadPV = beamSpotH->position();
296  }
297  edm::LogVerbatim("HcalIsoTrack") << "Primary Vertex " << leadPV;
298 
299  // RecHits
300  edm::Handle<EcalRecHitCollection> barrelRecHitsHandle;
301  iEvent.getByToken(tok_EB_, barrelRecHitsHandle);
302  if (!barrelRecHitsHandle.isValid()) {
303  edm::LogWarning("HcalIsoTrack") << "Cannot access the collection " << labelEB_;
304  foundCollections = false;
305  }
306  edm::Handle<EcalRecHitCollection> endcapRecHitsHandle;
307  iEvent.getByToken(tok_EE_, endcapRecHitsHandle);
308  if (!endcapRecHitsHandle.isValid()) {
309  edm::LogWarning("HcalIsoTrack") << "Cannot access the collection " << labelEE_;
310  foundCollections = false;
311  }
313  iEvent.getByToken(tok_hbhe_, hbhe);
314  if (!hbhe.isValid()) {
315  edm::LogWarning("HcalIsoTrack") << "Cannot access the collection " << labelHBHE_;
316  foundCollections = false;
317  }
318 
319  //Step3 propagate the tracks to calorimeter surface and find
320  // candidates for isolated tracks
321  if (foundCollections) {
322  //Propagate tracks to calorimeter surface)
323  std::vector<spr::propagatedTrackDirection> trkCaloDirections;
324  spr::propagateCALO(trkCollection, geo, bField, theTrackQuality_, trkCaloDirections, false);
325 
326  std::vector<spr::propagatedTrackDirection>::const_iterator trkDetItr;
327  unsigned int nTracks(0), nselTracks(0), ntrin(0), ntrout(0), ntrH(0);
328  for (trkDetItr = trkCaloDirections.begin(), nTracks = 0; trkDetItr != trkCaloDirections.end();
329  trkDetItr++, nTracks++) {
330  const reco::Track* pTrack = &(*(trkDetItr->trkItr));
331  math::XYZTLorentzVector v4(pTrack->px(), pTrack->py(), pTrack->pz(), pTrack->p());
332  edm::LogVerbatim("HcalIsoTrack") << "This track : " << nTracks << " (pt|eta|phi|p) :" << pTrack->pt() << "|"
333  << pTrack->eta() << "|" << pTrack->phi() << "|" << pTrack->p();
334 
335  //Selection of good track
336  int ieta(0);
337  if (trkDetItr->okHCAL) {
338  HcalDetId detId = (HcalDetId)(trkDetItr->detIdHCAL);
339  ieta = detId.ietaAbs();
340  }
341  bool qltyFlag = spr::goodTrack(pTrack, leadPV, selectionParameter_, false);
342  edm::LogVerbatim("HcalIsoTrack") << "qltyFlag|okECAL|okHCAL : " << qltyFlag << "|" << trkDetItr->okECAL << "|"
343  << trkDetItr->okHCAL;
344  if (qltyFlag && trkDetItr->okECAL && trkDetItr->okHCAL) {
345  double t_p = pTrack->p();
346  nselTracks++;
347  int nNearTRKs(0);
348  std::vector<DetId> eIds;
349  std::vector<double> eHit;
350  double eEcal = spr::eCone_ecal(geo,
351  barrelRecHitsHandle,
352  endcapRecHitsHandle,
353  trkDetItr->pointHCAL,
354  trkDetItr->pointECAL,
355  a_mipR_,
356  trkDetItr->directionECAL,
357  eIds,
358  eHit);
359  double eMipDR(0);
360  for (unsigned int k = 0; k < eIds.size(); ++k) {
361  const GlobalPoint& pos = geo->getPosition(eIds[k]);
362  double eta = std::abs(pos.eta());
363  double eThr(hitEthrEB_);
364  if (eIds[k].subdetId() != EcalBarrel) {
365  eThr = (((eta * hitEthrEE3_ + hitEthrEE2_) * eta + hitEthrEE1_) * eta + hitEthrEE0_);
366  if (eThr < hitEthrEELo_)
367  eThr = hitEthrEELo_;
368  else if (eThr > hitEthrEEHi_)
369  eThr = hitEthrEEHi_;
370  }
371  if (eHit[k] > eThr)
372  eMipDR += eHit[k];
373  }
374  double hmaxNearP = spr::chargeIsolationCone(nTracks, trkCaloDirections, a_charIsoR_, nNearTRKs, false);
375  double eIsolation = (maxRestrictionP_ * exp(slopeRestrictionP_ * ((double)(ieta))));
376  if (eIsolation < eIsolate_)
377  eIsolation = eIsolate_;
378  edm::LogVerbatim("HcalIsoTrack") << "This track : " << nTracks << " (pt|eta|phi|p) :" << pTrack->pt() << "|"
379  << pTrack->eta() << "|" << pTrack->phi() << "|" << t_p << "e_MIP " << eMipDR
380  << ":" << eEcal << " Chg Isolation " << hmaxNearP << ":" << eIsolation;
381  if (t_p > pTrackMin_ && eMipDR < eEcalMax_ && hmaxNearP < eIsolation) {
382  if (t_p > pTrackLow_ && t_p < pTrackHigh_)
383  ntrin++;
384  else if (t_p > pTrackH_)
385  ntrH++;
386  else
387  ntrout++;
388  }
389  }
390  }
391  accept = (ntrout > 0);
392  if (!accept && ntrin > 0) {
393  ++nRange_;
394  if (preScale_ <= 1)
395  accept = true;
396  else if (nRange_ % preScale_ == 1)
397  accept = true;
398  }
399  if (!accept && ntrH > 0) {
400  ++nHigh_;
401  if (preScaleH_ <= 1)
402  accept = true;
403  else if (nHigh_ % preScaleH_ == 1)
404  accept = true;
405  }
406  }
407  }
408  // Step 4: Return the acceptance flag
409  if (accept)
410  ++nGood_;
411  return accept;
412 
413 } // AlCaIsoTracksFilter::filter
RunNumber_t run() const
Definition: EventID.h:39
double p() const
momentum vector magnitude
Definition: TrackBase.h:654
const edm::InputTag labelEE_
const double slopeRestrictionP_
EventNumber_t event() const
Definition: EventID.h:41
std::vector< spr::propagatedTrackID > propagateCALO(edm::Handle< reco::TrackCollection > &trkCollection, const CaloGeometry *geo, const MagneticField *bField, const std::string &theTrackQuality, bool debug=false)
const unsigned int nTracks(const reco::Vertex &sv)
The single EDProduct to be saved for each event (AOD case)
Definition: TriggerEvent.h:25
spr::trackSelectionParameters selectionParameter_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:517
edm::EDGetTokenT< reco::TrackCollection > tok_genTrack_
const std::string theTrackQuality_
bool accept() const
Has at least one path accepted the event?
int bunchCrossing() const
Definition: EventBase.h:64
edm::LuminosityBlockNumber_t luminosityBlock() const
Definition: EventBase.h:61
edm::EDGetTokenT< reco::BeamSpot > tok_bs_
double phi() const
azimuthal angle of momentum vector
Definition: TrackBase.h:684
double chargeIsolationCone(unsigned int trkIndex, std::vector< spr::propagatedTrackDirection > &trkDirs, double dR, int &nNearTRKs, bool debug=false)
double px() const
x coordinate of momentum vector
Definition: TrackBase.h:666
void find(edm::Handle< EcalRecHitCollection > &hits, DetId thisDet, std::vector< EcalRecHitCollection::const_iterator > &hit, bool debug=false)
Definition: FindCaloHit.cc:20
bool accept(const edm::Event &event, const edm::TriggerResults &triggerTable, const std::string &triggerPath)
Definition: TopDQMHelpers.h:30
edm::EDGetTokenT< reco::VertexCollection > tok_recVtx_
Strings const & triggerNames() const
Definition: TriggerNames.cc:20
const std::vector< std::string > trigNames_
const edm::InputTag triggerEvent_
XYZTLorentzVectorD XYZTLorentzVector
Lorentz vector with cylindrical internal representation using pseudorapidity.
Definition: LorentzVector.h:29
double eta() const
pseudorapidity of momentum vector
Definition: TrackBase.h:690
bool goodTrack(const reco::Track *pTrack, math::XYZPoint leadPV, trackSelectionParameters parameters, bool debug=false)
unsigned int size() const
Get number of paths stored.
double pt() const
track transverse momentum
Definition: TrackBase.h:660
const edm::InputTag labelGenTrack_
GlobalPoint getPosition(const DetId &id) const
Get the position of a given detector id.
Definition: CaloGeometry.cc:74
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
const edm::InputTag labelHBHE_
edm::EDGetTokenT< trigger::TriggerEvent > tok_trigEvt_
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)
edm::EDGetTokenT< HBHERecHitCollection > tok_hbhe_
static std::string const triggerResults
Definition: EdmProvDump.cc:45
edm::EDGetTokenT< EcalRecHitCollection > tok_EB_
bool isValid() const
Definition: HandleBase.h:74
double pz() const
z coordinate of momentum vector
Definition: TrackBase.h:678
int k[5][pyjets_maxn]
int ietaAbs() const
get the absolute value of the cell ieta
Definition: HcalDetId.h:154
edm::EDGetTokenT< edm::TriggerResults > tok_trigRes_
edm::EDGetTokenT< EcalRecHitCollection > tok_EE_
T const * product() const
Definition: Handle.h:74
XYZPointD XYZPoint
point in space with cartesian internal representation
Definition: Point3D.h:12
std::string const & label() const
Definition: InputTag.h:36
T eta() const
Definition: PV3DBase.h:76
edm::EventID id() const
Definition: EventBase.h:59
const edm::InputTag labelEB_
const Point & position() const
position
Definition: BeamSpot.h:62
T const * product() const
Definition: ESHandle.h:86
edm::TriggerNames const & triggerNames(edm::TriggerResults const &triggerResults) const override
Definition: Event.cc:256
double py() const
y coordinate of momentum vector
Definition: TrackBase.h:672
void AlCaIsoTracksFilter::globalEndJob ( const AlCaIsoTracks::Counters counters)
static

Definition at line 423 of file AlCaIsoTracksFilter.cc.

References AlCaIsoTracks::Counters::nAll_, AlCaIsoTracks::Counters::nGood_, AlCaIsoTracks::Counters::nHigh_, and AlCaIsoTracks::Counters::nRange_.

423  {
424  edm::LogVerbatim("HcalIsoTrack") << "Selects " << count->nGood_ << " in " << count->nAll_ << " events and with "
425  << count->nRange_ << " events in the p-range" << count->nHigh_
426  << " events with high p";
427 }
static std::unique_ptr<AlCaIsoTracks::Counters> AlCaIsoTracksFilter::initializeGlobalCache ( edm::ParameterSet const &  iConfig)
inlinestatic

Definition at line 73 of file AlCaIsoTracksFilter.cc.

References Ecal2004TBTDCRanges_v1_cff::endRun, fillDescriptions(), and ALCARECOTkAlBeamHalo_cff::filter.

73  {
74  return std::make_unique<AlCaIsoTracks::Counters>();
75  }

Member Data Documentation

double AlCaIsoTracksFilter::a_charIsoR_
private

Definition at line 103 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::a_coneR_
private

Definition at line 93 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter().

const double AlCaIsoTracksFilter::a_mipR_
private

Definition at line 93 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::eEcalMax_
private

Definition at line 93 of file AlCaIsoTracksFilter.cc.

Referenced by filter().

const double AlCaIsoTracksFilter::eIsolate_
private

Definition at line 95 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::hitEthrEB_
private

Definition at line 96 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::hitEthrEE0_
private

Definition at line 96 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::hitEthrEE1_
private

Definition at line 96 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::hitEthrEE2_
private

Definition at line 97 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::hitEthrEE3_
private

Definition at line 97 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::hitEthrEEHi_
private

Definition at line 98 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::hitEthrEELo_
private

Definition at line 98 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

HLTConfigProvider AlCaIsoTracksFilter::hltConfig_
private

Definition at line 87 of file AlCaIsoTracksFilter.cc.

Referenced by beginRun().

const edm::InputTag AlCaIsoTracksFilter::labelEB_
private

Definition at line 90 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const edm::InputTag AlCaIsoTracksFilter::labelEE_
private

Definition at line 90 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const edm::InputTag AlCaIsoTracksFilter::labelGenTrack_
private

Definition at line 89 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const edm::InputTag AlCaIsoTracksFilter::labelHBHE_
private

Definition at line 90 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const edm::InputTag AlCaIsoTracksFilter::labelRecVtx_
private

Definition at line 89 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter().

const double AlCaIsoTracksFilter::maxRestrictionP_
private

Definition at line 94 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

unsigned int AlCaIsoTracksFilter::nAll_
private

Definition at line 104 of file AlCaIsoTracksFilter.cc.

Referenced by endStream(), and filter().

unsigned int AlCaIsoTracksFilter::nGood_
private

Definition at line 104 of file AlCaIsoTracksFilter.cc.

Referenced by endStream(), and filter().

unsigned int AlCaIsoTracksFilter::nHigh_
private

Definition at line 104 of file AlCaIsoTracksFilter.cc.

Referenced by endStream(), and filter().

unsigned int AlCaIsoTracksFilter::nRange_
private

Definition at line 104 of file AlCaIsoTracksFilter.cc.

Referenced by endStream(), and filter().

unsigned int AlCaIsoTracksFilter::nRun_
private

Definition at line 104 of file AlCaIsoTracksFilter.cc.

Referenced by beginRun(), and endRun().

const int AlCaIsoTracksFilter::preScale_
private

Definition at line 100 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const int AlCaIsoTracksFilter::preScaleH_
private

Definition at line 100 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const std::string AlCaIsoTracksFilter::processName_
private

Definition at line 92 of file AlCaIsoTracksFilter.cc.

Referenced by beginRun().

const double AlCaIsoTracksFilter::pTrackH_
private

Definition at line 99 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::pTrackHigh_
private

Definition at line 99 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::pTrackLow_
private

Definition at line 99 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::pTrackMin_
private

Definition at line 93 of file AlCaIsoTracksFilter.cc.

Referenced by filter().

spr::trackSelectionParameters AlCaIsoTracksFilter::selectionParameter_
private

Definition at line 102 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const double AlCaIsoTracksFilter::slopeRestrictionP_
private

Definition at line 94 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const std::string AlCaIsoTracksFilter::theTrackQuality_
private

Definition at line 101 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const edm::InputTag AlCaIsoTracksFilter::theTriggerResultsLabel_
private

Definition at line 91 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter().

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

Definition at line 109 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

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

Definition at line 110 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

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

Definition at line 111 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

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

Definition at line 107 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

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

Definition at line 112 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

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

Definition at line 108 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

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

Definition at line 105 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

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

Definition at line 106 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

const edm::InputTag AlCaIsoTracksFilter::triggerEvent_
private

Definition at line 91 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().

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

Definition at line 88 of file AlCaIsoTracksFilter.cc.

Referenced by AlCaIsoTracksFilter(), and filter().