Skip to content

Commit

Permalink
Modernized modules in L1Trigger/RegionalCaloTrigger
Browse files Browse the repository at this point in the history
- switch to thread friendly module types
- added consumes calls
  • Loading branch information
Dr15Jones committed Jul 26, 2022
1 parent ca284ed commit 1403207
Showing 11 changed files with 46 additions and 87 deletions.
4 changes: 2 additions & 2 deletions L1Trigger/RegionalCaloTrigger/interface/L1RCTInputProducer.h
Original file line number Diff line number Diff line change
@@ -1,7 +1,7 @@
#ifndef L1RCTInputProducer_h
#define L1RCTInputProducer_h

#include "FWCore/Framework/interface/EDProducer.h"
#include "FWCore/Framework/interface/stream/EDProducer.h"

#include "DataFormats/Common/interface/Handle.h"
#include "FWCore/Framework/interface/ESHandle.h"
@@ -27,7 +27,7 @@
class L1RCT;
class L1RCTLookupTables;

class L1RCTInputProducer : public edm::EDProducer {
class L1RCTInputProducer : public edm::stream::EDProducer<> {
public:
explicit L1RCTInputProducer(const edm::ParameterSet &ps);
~L1RCTInputProducer() override;
4 changes: 2 additions & 2 deletions L1Trigger/RegionalCaloTrigger/interface/L1RCTLutWriter.h
Original file line number Diff line number Diff line change
@@ -27,7 +27,7 @@
#include <iostream>

// user include files
#include "FWCore/Framework/interface/EDAnalyzer.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"

#include "FWCore/Framework/interface/Event.h"
@@ -56,7 +56,7 @@ class L1RCTParameters;
// class declaration
//

class L1RCTLutWriter : public edm::EDAnalyzer {
class L1RCTLutWriter : public edm::one::EDAnalyzer<> {
public:
explicit L1RCTLutWriter(const edm::ParameterSet &);
~L1RCTLutWriter() override;
8 changes: 4 additions & 4 deletions L1Trigger/RegionalCaloTrigger/interface/L1RCTRelValAnalyzer.h
Original file line number Diff line number Diff line change
@@ -22,7 +22,7 @@
#include <iostream>
#include <memory>
// user include files
#include "FWCore/Framework/interface/EDAnalyzer.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"

#include "FWCore/Framework/interface/Event.h"
@@ -42,7 +42,7 @@
// class declaration
//

class L1RCTRelValAnalyzer : public edm::EDAnalyzer {
class L1RCTRelValAnalyzer : public edm::one::EDAnalyzer<edm::one::SharedResources> {
public:
explicit L1RCTRelValAnalyzer(const edm::ParameterSet &);
~L1RCTRelValAnalyzer() override;
@@ -51,8 +51,8 @@ class L1RCTRelValAnalyzer : public edm::EDAnalyzer {

private:
// ----------member data ---------------------------
edm::InputTag rctEmCandsLabel;
edm::InputTag rctRegionsLabel;
edm::EDGetTokenT<L1CaloEmCollection> m_rctEmCands;
edm::EDGetTokenT<L1CaloRegionCollection> m_rctRegions;

TH1F *h_emRank;
TH1F *h_emIeta;
4 changes: 2 additions & 2 deletions L1Trigger/RegionalCaloTrigger/interface/L1RCTSaveInput.h
Original file line number Diff line number Diff line change
@@ -24,7 +24,7 @@

#include "DataFormats/Common/interface/Handle.h"

#include "FWCore/Framework/interface/EDAnalyzer.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EventSetup.h"
@@ -50,7 +50,7 @@
class L1RCTLookupTables;
class L1RCT;

class L1RCTSaveInput : public edm::EDAnalyzer {
class L1RCTSaveInput : public edm::one::EDAnalyzer<> {
public:
explicit L1RCTSaveInput(const edm::ParameterSet &);
~L1RCTSaveInput() override;
15 changes: 7 additions & 8 deletions L1Trigger/RegionalCaloTrigger/interface/L1RCTTPGProvider.h
Original file line number Diff line number Diff line change
@@ -21,7 +21,7 @@
#include <memory>

// user include files
#include "FWCore/Framework/interface/EDProducer.h"
#include "FWCore/Framework/interface/global/EDProducer.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"

#include "FWCore/Framework/interface/Event.h"
@@ -32,20 +32,19 @@
// class decleration
//

class L1RCTTPGProvider : public edm::EDProducer {
class L1RCTTPGProvider : public edm::global::EDProducer<> {
public:
explicit L1RCTTPGProvider(const edm::ParameterSet &);
~L1RCTTPGProvider() override;

private:
void produce(edm::Event &, const edm::EventSetup &) override;
void endJob() override;
void produce(edm::StreamID, edm::Event &, const edm::EventSetup &) const override;

// ----------member data ---------------------------
edm::InputTag ecalTPG_;
edm::InputTag hcalTPG_;
bool useHcalCosmicTiming;
bool useEcalCosmicTiming;
edm::EDGetTokenT<EcalTrigPrimDigiCollection> ecalTPG_;
edm::EDGetTokenT<HcalTrigPrimDigiCollection> hcalTPG_;
mutable std::atomic<bool> useHcalCosmicTiming;
mutable std::atomic<bool> useEcalCosmicTiming;
int preSamples;
int postSamples;
int hfShift;
4 changes: 2 additions & 2 deletions L1Trigger/RegionalCaloTrigger/interface/L1RCTTestAnalyzer.h
Original file line number Diff line number Diff line change
@@ -21,7 +21,7 @@
#include <iostream>
#include <memory>
// user include files
#include "FWCore/Framework/interface/EDAnalyzer.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"

#include "FWCore/Framework/interface/Event.h"
@@ -50,7 +50,7 @@
// class declaration
//

class L1RCTTestAnalyzer : public edm::EDAnalyzer {
class L1RCTTestAnalyzer : public edm::one::EDAnalyzer<edm::one::SharedResources> {
public:
explicit L1RCTTestAnalyzer(const edm::ParameterSet &);
~L1RCTTestAnalyzer() override;
Original file line number Diff line number Diff line change
@@ -26,7 +26,7 @@ RCT.
#include <memory>

// user include files
#include "FWCore/Framework/interface/EDProducer.h"
#include "FWCore/Framework/interface/global/EDProducer.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EventSetup.h"
@@ -42,21 +42,20 @@ RCT.
// class declaration
//

class MaskedRctInputDigiProducer : public edm::EDProducer {
class MaskedRctInputDigiProducer : public edm::global::EDProducer<> {
public:
explicit MaskedRctInputDigiProducer(const edm::ParameterSet &);
~MaskedRctInputDigiProducer() override;

private:
void produce(edm::Event &, const edm::EventSetup &) override;
void endJob() override;
void produce(edm::StreamID, edm::Event &, const edm::EventSetup &) const override;

// ----------member data ---------------------------

bool useEcal_;
bool useHcal_;
edm::InputTag ecalDigisLabel_;
edm::InputTag hcalDigisLabel_;
edm::EDGetTokenT<EcalTrigPrimDigiCollection> ecalDigisToken_;
edm::EDGetTokenT<HcalTrigPrimDigiCollection> hcalDigisToken_;
edm::FileInPath maskFile_;
};
#endif
28 changes: 7 additions & 21 deletions L1Trigger/RegionalCaloTrigger/plugins/L1RCTRelValAnalyzer.cc
Original file line number Diff line number Diff line change
@@ -24,10 +24,11 @@ using std::string;
// constructors and destructor
//
L1RCTRelValAnalyzer::L1RCTRelValAnalyzer(const edm::ParameterSet &iConfig)
: rctEmCandsLabel(iConfig.getParameter<edm::InputTag>("rctEmCandsLabel")),
rctRegionsLabel(iConfig.getParameter<edm::InputTag>("rctRegionsLabel")) {
: m_rctEmCands(consumes(iConfig.getParameter<edm::InputTag>("rctEmCandsLabel"))),
m_rctRegions(consumes(iConfig.getParameter<edm::InputTag>("rctRegionsLabel"))) {
// now do what ever initialization is needed

usesResource(TFileService::kSharedResource);
edm::Service<TFileService> fs;
h_emRank = fs->make<TH1F>("emRank", "emRank", 64, 0., 64.);
h_emIeta = fs->make<TH1F>("emOccupancyIeta", "emOccupancyIeta", 22, 0., 22.);
@@ -52,27 +53,12 @@ L1RCTRelValAnalyzer::~L1RCTRelValAnalyzer() {
// ------------ method called to produce the data ------------
void L1RCTRelValAnalyzer::analyze(const edm::Event &iEvent, const edm::EventSetup &iSetup) {
using namespace edm;
#ifdef THIS_IS_AN_EVENT_EXAMPLE
Handle<ExampleData> pIn;
iEvent.getByLabel("example", pIn);
#endif

#ifdef THIS_IS_AN_EVENTSETUP_EXAMPLE
ESHandle<SetupData> pSetup;
iSetup.get<SetupRecord>().get(pSetup);
#endif

// as in L1GctTestAnalyzer.cc
Handle<L1CaloEmCollection> rctEmCands;
Handle<L1CaloRegionCollection> rctRegions;

L1CaloEmCollection::const_iterator em;
L1CaloRegionCollection::const_iterator rgn;

iEvent.getByLabel(rctEmCandsLabel, rctEmCands);
iEvent.getByLabel(rctRegionsLabel, rctRegions);
Handle<L1CaloEmCollection> rctEmCands = iEvent.getHandle(m_rctEmCands);
Handle<L1CaloRegionCollection> rctRegions = iEvent.getHandle(m_rctRegions);

for (em = rctEmCands->begin(); em != rctEmCands->end(); em++) {
for (auto em = rctEmCands->begin(); em != rctEmCands->end(); em++) {
if ((*em).rank() > 0) {
h_emRank->Fill((*em).rank());
h_emIeta->Fill((*em).regionId().ieta());
@@ -85,7 +71,7 @@ void L1RCTRelValAnalyzer::analyze(const edm::Event &iEvent, const edm::EventSetu
}
}

for (rgn = rctRegions->begin(); rgn != rctRegions->end(); rgn++) {
for (auto rgn = rctRegions->begin(); rgn != rctRegions->end(); rgn++) {
if ((*rgn).et() > 0) {
h_regionSum->Fill((*rgn).et());
h_regionSumIetaIphi->Fill((*rgn).gctEta(), (*rgn).gctPhi(), (*rgn).et());
17 changes: 5 additions & 12 deletions L1Trigger/RegionalCaloTrigger/plugins/L1RCTTPGProvider.cc
Original file line number Diff line number Diff line change
@@ -3,8 +3,8 @@
#include "L1Trigger/RegionalCaloTrigger/interface/L1RCTTPGProvider.h"

L1RCTTPGProvider::L1RCTTPGProvider(const edm::ParameterSet &iConfig)
: ecalTPG_(iConfig.getParameter<edm::InputTag>("ecalTPGs")),
hcalTPG_(iConfig.getParameter<edm::InputTag>("hcalTPGs")),
: ecalTPG_(consumes(iConfig.getParameter<edm::InputTag>("ecalTPGs"))),
hcalTPG_(consumes(iConfig.getParameter<edm::InputTag>("hcalTPGs"))),
useHcalCosmicTiming(iConfig.getParameter<bool>("useHCALCosmicTiming")),
useEcalCosmicTiming(iConfig.getParameter<bool>("useECALCosmicTiming")),
preSamples(iConfig.getParameter<int>("preSamples")),
@@ -45,7 +45,7 @@ L1RCTTPGProvider::~L1RCTTPGProvider() {
//

// ------------ method called to produce the data ------------
void L1RCTTPGProvider::produce(edm::Event &iEvent, const edm::EventSetup &iSetup) {
void L1RCTTPGProvider::produce(edm::StreamID, edm::Event &iEvent, const edm::EventSetup &iSetup) const {
using namespace edm;
// Declare handles
Handle<EcalTrigPrimDigiCollection> ecal;
@@ -58,7 +58,7 @@ void L1RCTTPGProvider::produce(edm::Event &iEvent, const edm::EventSetup &iSetup

unsigned nSamples = preSamples + postSamples + 1;

if (iEvent.getByLabel(ecalTPG_, ecal))
if (ecal = iEvent.getHandle(ecalTPG_))
if (ecal.isValid()) {
// loop through all ecal digis
for (EcalTrigPrimDigiCollection::const_iterator ecal_it = ecal->begin(); ecal_it != ecal->end(); ecal_it++) {
@@ -152,7 +152,7 @@ void L1RCTTPGProvider::produce(edm::Event &iEvent, const edm::EventSetup &iSetup
}
}

if (iEvent.getByLabel(hcalTPG_, hcal))
if (hcal = iEvent.getHandle(hcalTPG_))
if (hcal.isValid()) {
// loop through all hcal digis
for (HcalTrigPrimDigiCollection::const_iterator hcal_it = hcal->begin(); hcal_it != hcal->end(); hcal_it++) {
@@ -301,10 +301,3 @@ void L1RCTTPGProvider::produce(edm::Event &iEvent, const edm::EventSetup &iSetup
iEvent.put(std::move(hcalIn2), hcal_label);
}
}

// ------------ method called once each job just before starting event loop
// ------------

// ------------ method called once each job just after ending the event loop
// ------------
void L1RCTTPGProvider::endJob() {}
1 change: 1 addition & 0 deletions L1Trigger/RegionalCaloTrigger/plugins/L1RCTTestAnalyzer.cc
Original file line number Diff line number Diff line change
@@ -32,6 +32,7 @@ L1RCTTestAnalyzer::L1RCTTestAnalyzer(const edm::ParameterSet &iConfig)
rctDigisLabel(iConfig.getParameter<edm::InputTag>("rctDigisLabel")) {
// now do what ever initialization is needed

usesResource(TFileService::kSharedResource);
edm::Service<TFileService> fs;

emTree = fs->make<TTree>("emTree", "L1 RCT EM tree");
Original file line number Diff line number Diff line change
@@ -15,9 +15,13 @@ using std::vector;
MaskedRctInputDigiProducer::MaskedRctInputDigiProducer(const edm::ParameterSet &iConfig)
: useEcal_(iConfig.getParameter<bool>("useEcal")),
useHcal_(iConfig.getParameter<bool>("useHcal")),
ecalDigisLabel_(iConfig.getParameter<edm::InputTag>("ecalDigisLabel")),
hcalDigisLabel_(iConfig.getParameter<edm::InputTag>("hcalDigisLabel")),
maskFile_(iConfig.getParameter<edm::FileInPath>("maskFile")) {
if (useEcal_) {
ecalDigisToken_ = consumes(iConfig.getParameter<edm::InputTag>("ecalDigisLabel"));
}
if (useHcal_) {
hcalDigisToken_ = consumes(iConfig.getParameter<edm::InputTag>("hcalDigisLabel"));
}
// register your products
/* Examples
produces<ExampleData2>();
@@ -42,27 +46,17 @@ MaskedRctInputDigiProducer::~MaskedRctInputDigiProducer() {
//

// ------------ method called to produce the data ------------
void MaskedRctInputDigiProducer::produce(edm::Event &iEvent, const edm::EventSetup &iSetup) {
void MaskedRctInputDigiProducer::produce(edm::StreamID, edm::Event &iEvent, const edm::EventSetup &iSetup) const {
using namespace edm;
/* This is an event example
//Read 'ExampleData' from the Event
Handle<ExampleData> pIn;
iEvent.getByLabel("example",pIn);
//Use the ExampleData to create an ExampleData2 which
// is put into the Event
std::unique_ptr<ExampleData2> pOut(new ExampleData2(*pIn));
iEvent.put(std::move(pOut));
*/

edm::Handle<EcalTrigPrimDigiCollection> ecal;
edm::Handle<HcalTrigPrimDigiCollection> hcal;

if (useEcal_) {
iEvent.getByLabel(ecalDigisLabel_, ecal);
ecal = iEvent.getHandle(ecalDigisToken_);
}
if (useHcal_) {
iEvent.getByLabel(hcalDigisLabel_, hcal);
hcal = iEvent.getHandle(hcalDigisToken_);
}

EcalTrigPrimDigiCollection ecalColl;
@@ -74,12 +68,6 @@ void MaskedRctInputDigiProducer::produce(edm::Event &iEvent, const edm::EventSet
hcalColl = *hcal;
}

/* this is an EventSetup example
//Read SetupData from the SetupRecord in the EventSetup
ESHandle<SetupData> pSetup;
iSetup.get<SetupRecord>().get(pSetup);
*/

ifstream maskFileStream(maskFile_.fullPath().c_str());
if (!maskFileStream.is_open()) {
throw cms::Exception("FileInPathError") << "RCT mask file not opened" << std::endl;
@@ -333,12 +321,5 @@ void MaskedRctInputDigiProducer::produce(edm::Event &iEvent, const edm::EventSet
iEvent.put(std::move(maskedHcalTPs));
}

// ------------ method called once each job just before starting event loop
// ------------

// ------------ method called once each job just after ending the event loop
// ------------
void MaskedRctInputDigiProducer::endJob() {}

// define this as a plug-in
DEFINE_FWK_MODULE(MaskedRctInputDigiProducer);

0 comments on commit 1403207

Please sign in to comment.