CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Public Attributes | Private Member Functions | Private Attributes
L1TauRecoTreeProducer Class Reference
Inheritance diagram for L1TauRecoTreeProducer:
edm::EDAnalyzer edm::EDConsumerBase

Public Member Functions

 L1TauRecoTreeProducer (const edm::ParameterSet &)
 
 ~L1TauRecoTreeProducer ()
 
- Public Member Functions inherited from edm::EDAnalyzer
void callWhenNewProductsRegistered (std::function< void(BranchDescription const &)> const &func)
 
 EDAnalyzer ()
 
ModuleDescription const & moduleDescription () const
 
std::string workerType () const
 
virtual ~EDAnalyzer ()
 
- Public Member Functions inherited from edm::EDConsumerBase
std::vector< ConsumesInfoconsumesInfo () const
 
 EDConsumerBase ()
 
ProductHolderIndexAndSkipBit indexFrom (EDGetToken, BranchType, TypeID const &) const
 
void itemsMayGet (BranchType, std::vector< ProductHolderIndexAndSkipBit > &) const
 
void itemsToGet (BranchType, std::vector< ProductHolderIndexAndSkipBit > &) const
 
std::vector
< ProductHolderIndexAndSkipBit >
const & 
itemsToGetFromEvent () const
 
void labelsForToken (EDGetToken iToken, Labels &oLabels) const
 
void modulesDependentUpon (std::string const &iProcessName, std::string const &iModuleLabel, bool iPrint, std::vector< char const * > &oModuleLabels) const
 
void modulesWhoseProductsAreConsumed (std::vector< ModuleDescription const * > &modules, ProductRegistry const &preg, std::map< std::string, ModuleDescription const * > const &labelsToDesc, std::string const &processName) const
 
bool registeredToConsume (ProductHolderIndex, bool, BranchType) const
 
bool registeredToConsumeMany (TypeID const &, BranchType) const
 
void updateLookup (BranchType iBranchType, ProductHolderIndexHelper const &)
 
virtual ~EDConsumerBase ()
 

Public Attributes

L1Analysis::L1AnalysisRecoTautau
 
L1Analysis::L1AnalysisRecoTauDataFormattau_data
 

Private Member Functions

virtual void analyze (const edm::Event &, const edm::EventSetup &)
 
virtual void beginJob (void)
 
virtual void endJob ()
 

Private Attributes

bool caloJetsMissing_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
DMFindingOldToken_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
DMFindingToken_
 
edm::Service< TFileServicefs_
 
double jetptThreshold_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
LooseAntiElectronToken_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
LooseAntiMuonToken_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
LooseIsoToken_
 
unsigned int maxCl_
 
unsigned int maxTau_
 
unsigned int maxTrk_
 
unsigned int maxVtx_
 
std::string period_
 
edm::EDGetTokenT
< reco::PFTauCollection
TauToken_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
TightAntiElectronToken_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
TightAntiMuonToken_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
TightIsoToken_
 
TTree * tree_
 
edm::EDGetTokenT
< reco::PFTauDiscriminator
VLooseAntiElectronToken_
 

Additional Inherited Members

- Public Types inherited from edm::EDAnalyzer
typedef EDAnalyzer ModuleType
 
- Public Types inherited from edm::EDConsumerBase
typedef ProductLabels Labels
 
- Static Public Member Functions inherited from edm::EDAnalyzer
static const std::string & baseType ()
 
static void fillDescriptions (ConfigurationDescriptions &descriptions)
 
static void prevalidate (ConfigurationDescriptions &)
 
- 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 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 65 of file L1TauRecoTreeProducer.cc.

Constructor & Destructor Documentation

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

Definition at line 117 of file L1TauRecoTreeProducer.cc.

References DMFindingOldToken_, DMFindingToken_, fs_, L1Analysis::L1AnalysisRecoTau::getData(), edm::ParameterSet::getParameter(), edm::ParameterSet::getUntrackedParameter(), LooseAntiElectronToken_, LooseAntiMuonToken_, LooseIsoToken_, TFileService::make(), maxTau_, period_, AlCaHLTBitMon_QueryRunRegistry::string, tau, tau_data, TauToken_, TightAntiElectronToken_, TightAntiMuonToken_, TightIsoToken_, tree_, and VLooseAntiElectronToken_.

117  :
118  caloJetsMissing_(false)
119 {
120 
121  period_ = iConfig.getParameter<std::string>("period");
122 
123  if(period_=="2015")
124  {
125  maxTau_ = iConfig.getParameter<unsigned int>("maxTau");
126  TauToken_ = consumes<reco::PFTauCollection>(iConfig.getUntrackedParameter("TauToken",edm::InputTag("hpsPFTauProducer")));
127  DMFindingToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("DMFindingToken",edm::InputTag("hpsPFTauDiscriminationByDecayModeFindingNewDMs")));
128  DMFindingOldToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("DMFindingOldToken",edm::InputTag("hpsPFTauDiscriminationByDecayModeFindingOldDMs")));
129  TightIsoToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("TightIsoToken",edm::InputTag("hpsPFTauDiscriminationByTightIsolation")));
130  LooseIsoToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("LooseIsoToken",edm::InputTag("hpsPFTauDiscriminationByLooseIsolation")));
131  LooseAntiMuonToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("LooseAntiMuonToken",edm::InputTag("hpsPFTauDiscriminationByLooseMuonRejection")));
132  TightAntiMuonToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("TightAntiMuonToken",edm::InputTag("hpsPFTauDiscriminationByTightMuonRejection")));
133  VLooseAntiElectronToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("VLooseAntiElectronToken",edm::InputTag("hpsPFTauDiscriminationByMVA5VLooseElectronRejection")));
134  LooseAntiElectronToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("LooseAntiElectronToken",edm::InputTag("hpsPFTauDiscriminationByMVA5LooseElectronRejection")));
135  TightAntiElectronToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("TightAntiElectronToken",edm::InputTag("hpsPFTauDiscriminationByMVA5TightElectronRejection")));
136  }
137  else if(period_=="2016")
138  {
139  maxTau_ = iConfig.getParameter<unsigned int>("maxTau");
140  TauToken_ = consumes<reco::PFTauCollection>(iConfig.getUntrackedParameter("TauToken",edm::InputTag("hpsPFTauProducer")));
141  DMFindingToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("DMFindingToken",edm::InputTag("hpsPFTauDiscriminationByDecayModeFindingNewDMs")));
142  DMFindingOldToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("DMFindingOldToken",edm::InputTag("hpsPFTauDiscriminationByDecayModeFindingOldDMs")));
143  TightIsoToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("TightIsoToken",edm::InputTag("hpsPFTauDiscriminationByTightCombinedIsolationDBSumPtCorr3Hits")));
144  LooseIsoToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("LooseIsoToken",edm::InputTag("hpsPFTauDiscriminationByLooseCombinedIsolationDBSumPtCorr3Hits")));
145  LooseAntiMuonToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("LooseAntiMuonToken",edm::InputTag("hpsPFTauDiscriminationByLooseMuonRejection3")));
146  TightAntiMuonToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("TightAntiMuonToken",edm::InputTag("hpsPFTauDiscriminationByTightMuonRejection3")));
147  VLooseAntiElectronToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("VLooseAntiElectronToken",edm::InputTag("hpsPFTauDiscriminationByMVA6VLooseElectronRejection")));
148  LooseAntiElectronToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("LooseAntiElectronToken",edm::InputTag("hpsPFTauDiscriminationByMVA6LooseElectronRejection")));
149  TightAntiElectronToken_ = consumes<reco::PFTauDiscriminator>(iConfig.getUntrackedParameter("TightAntiElectronToken",edm::InputTag("hpsPFTauDiscriminationByMVA6TightElectronRejection")));
150  }
151 
152  /*
153  caloJetToken_ = consumes<reco::CaloJetCollection>(iConfig.getUntrackedParameter("caloJetToken",edm::InputTag("ak4CaloJets")));
154  // caloJetIdToken_ = consumes<edm::ValueMap<reco::JetID> >(iConfig.getUntrackedParameter("jetIdToken",edm::InputTag("ak4JetID")));
155  jetCorrectorToken_ = consumes<reco::JetCorrector>(iConfig.getUntrackedParameter<edm::InputTag>("jetCorrToken"));
156 
157  jetptThreshold_ = iConfig.getParameter<double> ("jetptThreshold");
158  maxTau_ = iConfig.getParameter<unsigned int>("maxTau");
159  */
160 
162  tau_data = tau->getData();
163 
164  /*
165  // set up output
166  */
167  tree_=fs_->make<TTree>("TauRecoTree", "TauRecoTree");
168  //tree_=fs_->make<TTree>("JetRecoTree", "JetRecoTree");
169  tree_->Branch("Tau", "L1Analysis::L1AnalysisRecoTauDataFormat", &tau_data, 32000, 3);
170 
171 }
edm::EDGetTokenT< reco::PFTauDiscriminator > TightAntiMuonToken_
T getParameter(std::string const &) const
L1Analysis::L1AnalysisRecoTauDataFormat * tau_data
T getUntrackedParameter(std::string const &, T const &) const
edm::EDGetTokenT< reco::PFTauDiscriminator > VLooseAntiElectronToken_
L1AnalysisRecoTauDataFormat * getData()
edm::EDGetTokenT< reco::PFTauDiscriminator > LooseIsoToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > TightIsoToken_
T * make(const Args &...args) const
make new ROOT object
Definition: TFileService.h:64
edm::EDGetTokenT< reco::PFTauDiscriminator > DMFindingToken_
L1Analysis::L1AnalysisRecoTau * tau
edm::EDGetTokenT< reco::PFTauDiscriminator > DMFindingOldToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > TightAntiElectronToken_
edm::EDGetTokenT< reco::PFTauCollection > TauToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > LooseAntiElectronToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > LooseAntiMuonToken_
edm::Service< TFileService > fs_
L1TauRecoTreeProducer::~L1TauRecoTreeProducer ( )

Definition at line 174 of file L1TauRecoTreeProducer.cc.

175 {
176 
177  // do anything here that needs to be done at desctruction time
178  // (e.g. close files, deallocate resources etc.)
179 
180 }

Member Function Documentation

void L1TauRecoTreeProducer::analyze ( const edm::Event iEvent,
const edm::EventSetup iSetup 
)
privatevirtual

Implements edm::EDAnalyzer.

Definition at line 188 of file L1TauRecoTreeProducer.cc.

References caloJetsMissing_, DMFindingOldToken_, DMFindingToken_, edm::Event::getByToken(), edm::HandleBase::isValid(), LooseAntiElectronToken_, LooseAntiMuonToken_, LooseIsoToken_, maxTau_, L1Analysis::L1AnalysisRecoTau::Reset(), L1Analysis::L1AnalysisRecoTau::SetTau(), tau, TauToken_, TightAntiElectronToken_, TightAntiMuonToken_, TightIsoToken_, tree_, and VLooseAntiElectronToken_.

189 {
190 
191  tau->Reset();
193  iEvent.getByToken(TauToken_, recoTaus);
194 
196  iEvent.getByToken(DMFindingToken_, DMFindingTaus);
197 
198  edm::Handle<reco::PFTauDiscriminator> DMFindingOldTaus;
199  iEvent.getByToken(DMFindingOldToken_, DMFindingOldTaus);
200 
202  iEvent.getByToken(TightIsoToken_, TightIsoTaus);
203 
205  iEvent.getByToken(LooseIsoToken_, LooseIsoTaus);
206 
208  iEvent.getByToken(LooseAntiMuonToken_, LooseAntiMuon);
209 
211  iEvent.getByToken(TightAntiMuonToken_, TightAntiMuon);
212 
213  edm::Handle<reco::PFTauDiscriminator> VLooseAntiElectron;
214  iEvent.getByToken(VLooseAntiElectronToken_, VLooseAntiElectron);
215 
216  edm::Handle<reco::PFTauDiscriminator> LooseAntiElectron;
217  iEvent.getByToken(LooseAntiElectronToken_, LooseAntiElectron);
218 
219  edm::Handle<reco::PFTauDiscriminator> TightAntiElectron;
220  iEvent.getByToken(TightAntiElectronToken_, TightAntiElectron);
221 
222  //std::cout<<"size of recoTaus = "<<recoTaus->size()<<std::endl;
223 
224  if (recoTaus.isValid()) {
225  //std::cout<<"passing here"<<std::endl;
226  tau->SetTau(iEvent, iSetup, recoTaus, DMFindingOldTaus, DMFindingTaus, TightIsoTaus, LooseIsoTaus, LooseAntiMuon, TightAntiMuon, VLooseAntiElectron, LooseAntiElectron, TightAntiElectron, maxTau_);
227  }
228  else {
229  if (!caloJetsMissing_) {edm::LogWarning("MissingProduct") << "CaloJets not found. Branch will not be filled" << std::endl;}
230  caloJetsMissing_ = true;
231  }
232 
233  /*
234  jet->Reset();
235 
236  // get jets & co...
237  edm::Handle<reco::CaloJetCollection> recoCaloJets;
238  edm::Handle<edm::ValueMap<reco::JetID> > jetsID;
239  edm::Handle<reco::JetCorrector> jetCorr;
240 
241  iEvent.getByToken(caloJetToken_, recoCaloJets);
242  //iEvent.getByLabel(jetIdTag_,jetsID);
243  //iEvent.getByToken(jetCorrectorToken_, jetCorr);
244 
245  if (recoCaloJets.isValid()) {
246  jet->SetCaloJet(iEvent, iSetup, recoCaloJets, maxTau_); //jetsID, maxTau_);
247  }
248  else {
249  if (!caloJetsMissing_) {edm::LogWarning("MissingProduct") << "CaloJets not found. Branch will not be filled" << std::endl;}
250  caloJetsMissing_ = true;
251  }
252  */
253 
254  tree_->Fill();
255 
256 }
edm::EDGetTokenT< reco::PFTauDiscriminator > TightAntiMuonToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > VLooseAntiElectronToken_
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:462
edm::EDGetTokenT< reco::PFTauDiscriminator > LooseIsoToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > TightIsoToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > DMFindingToken_
L1Analysis::L1AnalysisRecoTau * tau
edm::EDGetTokenT< reco::PFTauDiscriminator > DMFindingOldToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > TightAntiElectronToken_
edm::EDGetTokenT< reco::PFTauCollection > TauToken_
edm::EDGetTokenT< reco::PFTauDiscriminator > LooseAntiElectronToken_
bool isValid() const
Definition: HandleBase.h:75
edm::EDGetTokenT< reco::PFTauDiscriminator > LooseAntiMuonToken_
void SetTau(const edm::Event &event, const edm::EventSetup &setup, const edm::Handle< reco::PFTauCollection > taus, const edm::Handle< reco::PFTauDiscriminator > DMFindingOldTaus, const edm::Handle< reco::PFTauDiscriminator > DMFindingTaus, const edm::Handle< reco::PFTauDiscriminator > TightIsoTaus, const edm::Handle< reco::PFTauDiscriminator > LooseIsoTaus, const edm::Handle< reco::PFTauDiscriminator > LooseAntiMuon, const edm::Handle< reco::PFTauDiscriminator > TightAntiMuon, const edm::Handle< reco::PFTauDiscriminator > VLooseAntiElectron, const edm::Handle< reco::PFTauDiscriminator > LooseAntiElectron, const edm::Handle< reco::PFTauDiscriminator > TightAntiElectron, unsigned maxTau)
void L1TauRecoTreeProducer::beginJob ( void  )
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 260 of file L1TauRecoTreeProducer.cc.

261 {
262 }
void L1TauRecoTreeProducer::endJob ( void  )
privatevirtual

Reimplemented from edm::EDAnalyzer.

Definition at line 266 of file L1TauRecoTreeProducer.cc.

266  {
267 }

Member Data Documentation

bool L1TauRecoTreeProducer::caloJetsMissing_
private

Definition at line 106 of file L1TauRecoTreeProducer.cc.

Referenced by analyze().

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::DMFindingOldToken_
private

Definition at line 92 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::DMFindingToken_
private

Definition at line 91 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

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

Definition at line 84 of file L1TauRecoTreeProducer.cc.

Referenced by L1TauRecoTreeProducer().

double L1TauRecoTreeProducer::jetptThreshold_
private

Definition at line 107 of file L1TauRecoTreeProducer.cc.

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::LooseAntiElectronToken_
private

Definition at line 98 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::LooseAntiMuonToken_
private

Definition at line 95 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::LooseIsoToken_
private

Definition at line 94 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

unsigned int L1TauRecoTreeProducer::maxCl_
private

Definition at line 108 of file L1TauRecoTreeProducer.cc.

unsigned int L1TauRecoTreeProducer::maxTau_
private

Definition at line 110 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

unsigned int L1TauRecoTreeProducer::maxTrk_
private

Definition at line 112 of file L1TauRecoTreeProducer.cc.

unsigned int L1TauRecoTreeProducer::maxVtx_
private

Definition at line 111 of file L1TauRecoTreeProducer.cc.

std::string L1TauRecoTreeProducer::period_
private

Definition at line 109 of file L1TauRecoTreeProducer.cc.

Referenced by L1TauRecoTreeProducer().

L1Analysis::L1AnalysisRecoTau* L1TauRecoTreeProducer::tau
L1Analysis::L1AnalysisRecoTauDataFormat* L1TauRecoTreeProducer::tau_data

Definition at line 79 of file L1TauRecoTreeProducer.cc.

Referenced by L1TauRecoTreeProducer().

edm::EDGetTokenT<reco::PFTauCollection> L1TauRecoTreeProducer::TauToken_
private

Definition at line 90 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::TightAntiElectronToken_
private

Definition at line 99 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::TightAntiMuonToken_
private

Definition at line 96 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::TightIsoToken_
private

Definition at line 93 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

TTree* L1TauRecoTreeProducer::tree_
private

Definition at line 87 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().

edm::EDGetTokenT<reco::PFTauDiscriminator> L1TauRecoTreeProducer::VLooseAntiElectronToken_
private

Definition at line 97 of file L1TauRecoTreeProducer.cc.

Referenced by analyze(), and L1TauRecoTreeProducer().