CMS 3D CMS Logo

List of all members | Public Member Functions | Private Member Functions | Private Attributes
PatBasicAnalyzer Class Reference
Inheritance diagram for PatBasicAnalyzer:
edm::one::EDAnalyzer< edm::one::SharedResources > edm::one::EDAnalyzerBase edm::EDConsumerBase

Public Member Functions

 PatBasicAnalyzer (const edm::ParameterSet &)
 default constructor More...
 
 ~PatBasicAnalyzer () override
 default destructor More...
 
- Public Member Functions inherited from edm::one::EDAnalyzer< edm::one::SharedResources >
 EDAnalyzer ()=default
 
 EDAnalyzer (const EDAnalyzer &)=delete
 
SerialTaskQueueglobalLuminosityBlocksQueue () final
 
SerialTaskQueueglobalRunsQueue () final
 
const EDAnalyzeroperator= (const EDAnalyzer &)=delete
 
bool wantsGlobalLuminosityBlocks () const noexcept final
 
bool wantsGlobalRuns () const noexcept final
 
bool wantsInputProcessBlocks () const noexcept final
 
bool wantsProcessBlocks () const noexcept 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 noexcept
 
bool wantsStreamRuns () const noexcept
 
 ~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)
 

Private Member Functions

void analyze (const edm::Event &, const edm::EventSetup &) override
 everything that needs to be done during the event loop More...
 
void beginJob () override
 everything that needs to be done before the event loop More...
 
void endJob () override
 everything that needs to be done after the event loop More...
 

Private Attributes

edm::EDGetTokenT< edm::View< pat::Electron > > elecSrcToken_
 
std::map< std::string, TH1F * > histContainer_
 
edm::EDGetTokenT< edm::View< pat::Jet > > jetSrcToken_
 
TH1F * jetTowers_
 
edm::EDGetTokenT< edm::View< pat::MET > > metSrcToken_
 
edm::EDGetTokenT< edm::View< pat::Muon > > muonSrcToken_
 
edm::EDGetTokenT< edm::View< pat::Photon > > photonSrcToken_
 
edm::EDGetTokenT< edm::View< pat::Tau > > tauSrcToken_
 

Additional Inherited Members

- Public Types inherited from edm::one::EDAnalyzerBase
typedef EDAnalyzerBase ModuleType
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Static Public Member Functions inherited from edm::one::EDAnalyzerBase
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &descriptions)
 
- 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

Definition at line 20 of file PatBasicAnalyzer.cc.

Constructor & Destructor Documentation

◆ PatBasicAnalyzer()

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

default constructor

Definition at line 51 of file PatBasicAnalyzer.cc.

References TFileService::kSharedResource.

52  : histContainer_(),
59  usesResource(TFileService::kSharedResource);
60 }
static const std::string kSharedResource
Definition: TFileService.h:76
edm::EDGetTokenT< edm::View< pat::Tau > > tauSrcToken_
edm::EDGetTokenT< edm::View< pat::Jet > > jetSrcToken_
std::map< std::string, TH1F * > histContainer_
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
T getUntrackedParameter(std::string const &, T const &) const
edm::EDGetTokenT< edm::View< pat::Muon > > muonSrcToken_
edm::EDGetTokenT< edm::View< pat::MET > > metSrcToken_
edm::EDGetTokenT< edm::View< pat::Electron > > elecSrcToken_
edm::EDGetTokenT< edm::View< pat::Photon > > photonSrcToken_

◆ ~PatBasicAnalyzer()

PatBasicAnalyzer::~PatBasicAnalyzer ( )
override

default destructor

Definition at line 62 of file PatBasicAnalyzer.cc.

62 {}

Member Function Documentation

◆ analyze()

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

everything that needs to be done during the event loop

Implements edm::one::EDAnalyzerBase.

Definition at line 64 of file PatBasicAnalyzer.cc.

References elecSrcToken_, pwdgSkimBPark_cfi::electrons, histContainer_, iEvent, metsig::jet, PDWG_EXODelayedJetMET_cff::jets, jetSrcToken_, singleTopDQM_cfi::mets, metSrcToken_, DiMuonV_cfg::muons, muonSrcToken_, nJets, BPHMonitor_cfi::photons, photonSrcToken_, Tau3MuMonitor_cff::taus, and tauSrcToken_.

64  {
65  // get electron collection
67  iEvent.getByToken(elecSrcToken_, electrons);
68 
69  // get muon collection
71  iEvent.getByToken(muonSrcToken_, muons);
72 
73  // get tau collection
75  iEvent.getByToken(tauSrcToken_, taus);
76 
77  // get jet collection
79  iEvent.getByToken(jetSrcToken_, jets);
80 
81  // get met collection
83  iEvent.getByToken(metSrcToken_, mets);
84 
85  // get photon collection
87  iEvent.getByToken(photonSrcToken_, photons);
88 
89  // loop over jets
90  size_t nJets = 0;
91  for (edm::View<pat::Jet>::const_iterator jet = jets->begin(); jet != jets->end(); ++jet) {
92  if (jet->pt() > 50) {
93  ++nJets;
94  }
95  // uncomment the following line to fill the
96  // jetTowers_ histogram
97  // jetTowers_->Fill(jet->getCaloConstituents().size());
98  }
99  histContainer_["jets"]->Fill(nJets);
100 
101  // do something similar for the other candidates
102  histContainer_["photons"]->Fill(photons->size());
103  histContainer_["elecs"]->Fill(electrons->size());
104  histContainer_["muons"]->Fill(muons->size());
105  histContainer_["taus"]->Fill(taus->size());
106  histContainer_["met"]->Fill(mets->empty() ? 0 : (*mets)[0].et());
107 }
edm::EDGetTokenT< edm::View< pat::Tau > > tauSrcToken_
edm::EDGetTokenT< edm::View< pat::Jet > > jetSrcToken_
static constexpr int nJets
std::map< std::string, TH1F * > histContainer_
muons
the two sets of parameters below are mutually exclusive, depending if RECO or ALCARECO is used the us...
Definition: DiMuonV_cfg.py:214
edm::EDGetTokenT< edm::View< pat::Muon > > muonSrcToken_
int iEvent
Definition: GenABIO.cc:224
edm::EDGetTokenT< edm::View< pat::MET > > metSrcToken_
edm::EDGetTokenT< edm::View< pat::Electron > > elecSrcToken_
boost::indirect_iterator< typename seq_t::const_iterator > const_iterator
Definition: View.h:88
edm::EDGetTokenT< edm::View< pat::Photon > > photonSrcToken_

◆ beginJob()

void PatBasicAnalyzer::beginJob ( void  )
overrideprivatevirtual

everything that needs to be done before the event loop

Reimplemented from edm::one::EDAnalyzerBase.

Definition at line 109 of file PatBasicAnalyzer.cc.

References compareTotals::fs, and histContainer_.

109  {
110  // register to the TFileService
112 
113  // book histograms:
114  // uncomment the following line to book the jetTowers_ histogram
115  //jetTowers_= fs->make<TH1F>("jetTowers", "towers per jet", 90, 0, 90);
116  histContainer_["photons"] = fs->make<TH1F>("photons", "photon multiplicity", 10, 0, 10);
117  histContainer_["elecs"] = fs->make<TH1F>("elecs", "electron multiplicity", 10, 0, 10);
118  histContainer_["muons"] = fs->make<TH1F>("muons", "muon multiplicity", 10, 0, 10);
119  histContainer_["taus"] = fs->make<TH1F>("taus", "tau multiplicity", 10, 0, 10);
120  histContainer_["jets"] = fs->make<TH1F>("jets", "jet multiplicity", 10, 0, 10);
121  histContainer_["met"] = fs->make<TH1F>("met", "missing E_{T}", 20, 0, 100);
122 }
std::map< std::string, TH1F * > histContainer_

◆ endJob()

void PatBasicAnalyzer::endJob ( void  )
overrideprivatevirtual

everything that needs to be done after the event loop

Reimplemented from edm::one::EDAnalyzerBase.

Definition at line 124 of file PatBasicAnalyzer.cc.

124 {}

Member Data Documentation

◆ elecSrcToken_

edm::EDGetTokenT<edm::View<pat::Electron> > PatBasicAnalyzer::elecSrcToken_
private

Definition at line 44 of file PatBasicAnalyzer.cc.

Referenced by analyze().

◆ histContainer_

std::map<std::string, TH1F*> PatBasicAnalyzer::histContainer_
private

Definition at line 38 of file PatBasicAnalyzer.cc.

Referenced by analyze(), and beginJob().

◆ jetSrcToken_

edm::EDGetTokenT<edm::View<pat::Jet> > PatBasicAnalyzer::jetSrcToken_
private

Definition at line 47 of file PatBasicAnalyzer.cc.

Referenced by analyze().

◆ jetTowers_

TH1F* PatBasicAnalyzer::jetTowers_
private

Definition at line 40 of file PatBasicAnalyzer.cc.

◆ metSrcToken_

edm::EDGetTokenT<edm::View<pat::MET> > PatBasicAnalyzer::metSrcToken_
private

Definition at line 48 of file PatBasicAnalyzer.cc.

Referenced by analyze().

◆ muonSrcToken_

edm::EDGetTokenT<edm::View<pat::Muon> > PatBasicAnalyzer::muonSrcToken_
private

Definition at line 45 of file PatBasicAnalyzer.cc.

Referenced by analyze().

◆ photonSrcToken_

edm::EDGetTokenT<edm::View<pat::Photon> > PatBasicAnalyzer::photonSrcToken_
private

Definition at line 43 of file PatBasicAnalyzer.cc.

Referenced by analyze().

◆ tauSrcToken_

edm::EDGetTokenT<edm::View<pat::Tau> > PatBasicAnalyzer::tauSrcToken_
private

Definition at line 46 of file PatBasicAnalyzer.cc.

Referenced by analyze().