L1Trigger
L1TCalorimeter
plugins
L1TCaloRCTToUpgradeConverter.cc
Go to the documentation of this file.
1
// -*- C++ -*-
2
//
3
// Package: L1Trigger/L1TCalorimeter
4
// Class: L1TCaloRCTToUpgradeConverter
5
//
13
//
14
// Original Author: James Brooke
15
// Created: Thu, 05 Dec 2013 17:39:27 GMT
16
//
17
//
18
#include "
FWCore/Framework/interface/EventSetup.h
"
19
#include "
FWCore/Framework/interface/Frameworkfwd.h
"
20
#include "
FWCore/Framework/interface/global/EDProducer.h
"
21
#include "
FWCore/Framework/interface/Event.h
"
22
#include "
FWCore/Framework/interface/MakerMacros.h
"
23
#include "
FWCore/ParameterSet/interface/ParameterSet.h
"
24
#include "
FWCore/Utilities/interface/EDGetToken.h
"
25
#include "
FWCore/Utilities/interface/EDPutToken.h
"
26
#include "
FWCore/Utilities/interface/InputTag.h
"
27
#include "
FWCore/MessageLogger/interface/MessageLogger.h
"
28
29
#include "
DataFormats/L1CaloTrigger/interface/L1CaloEmCand.h
"
30
#include "
DataFormats/L1CaloTrigger/interface/L1CaloRegion.h
"
31
#include "
DataFormats/L1CaloTrigger/interface/L1CaloCollections.h
"
32
33
#include "
DataFormats/L1Trigger/interface/BXVector.h
"
34
35
#include "
DataFormats/L1TCalorimeter/interface/CaloEmCand.h
"
36
#include "
DataFormats/L1TCalorimeter/interface/CaloRegion.h
"
37
38
#include "
DataFormats/Math/interface/LorentzVector.h
"
39
40
#include <vector>
41
42
namespace
l1t
{
43
44
class
L1TCaloRCTToUpgradeConverter
:
public
edm::global::EDProducer
<> {
45
public
:
46
explicit
L1TCaloRCTToUpgradeConverter
(
const
edm::ParameterSet
& ps);
47
48
static
void
fillDescriptions
(
edm::ConfigurationDescriptions
& descriptions);
49
50
private
:
51
void
produce
(
edm::StreamID
,
edm::Event
&,
const
edm::EventSetup
&)
const override
;
52
53
// ----------member data ---------------------------
54
55
edm::EDGetTokenT<L1CaloRegionCollection>
const
rgnToken_
;
56
edm::EDGetTokenT<L1CaloEmCollection>
const
emToken_
;
57
58
edm::EDPutTokenT<CaloRegionBxCollection>
const
rgnPutToken_
;
59
edm::EDPutTokenT<CaloEmCandBxCollection>
const
emPutToken_
;
60
};
61
62
}
// namespace l1t
63
64
using namespace
l1t
;
65
66
L1TCaloRCTToUpgradeConverter::L1TCaloRCTToUpgradeConverter
(
const
edm::ParameterSet
& ps)
67
: rgnToken_{consumes<L1CaloRegionCollection>(ps.
getParameter
<
edm::InputTag
>(
"regionTag"
))},
68
emToken_{consumes<L1CaloEmCollection>(ps.getParameter<
edm::InputTag
>(
"emTag"
))},
69
rgnPutToken_{produces<CaloRegionBxCollection>()},
70
emPutToken_{produces<CaloEmCandBxCollection>()} {}
71
72
// ------------ method called to produce the data ------------
73
void
L1TCaloRCTToUpgradeConverter::produce
(
edm::StreamID
,
edm::Event
&
iEvent
,
const
edm::EventSetup
& iSetup)
const
{
74
// check status of RCT conditions & renew if needed
75
76
// store new formats
77
BXVector<CaloEmCand>
emcands;
78
BXVector<CaloRegion>
regions
;
79
80
// get old formats
81
auto
const
& ems =
iEvent
.get(
emToken_
);
82
auto
const
& rgns =
iEvent
.get(
rgnToken_
);
83
84
// get the firstBx_ and lastBx_ from the input datatypes (assume bx for em same as rgn)
85
int
firstBx = 0;
86
int
lastBx = 0;
87
for
(
auto
const
& em : ems) {
88
int
bx
= em.bx();
89
if
(
bx
< firstBx)
90
firstBx =
bx
;
91
if
(
bx
> lastBx)
92
lastBx =
bx
;
93
}
94
95
emcands.
setBXRange
(firstBx, lastBx);
96
regions
.setBXRange(firstBx, lastBx);
97
98
const
ROOT::Math::LorentzVector<ROOT::Math::PxPyPzE4D<double> >
p4
(0, 0, 0, 0);
99
100
// loop over EM
101
for
(
auto
const
& em : ems) {
102
// get physical units
103
// double pt = 0.;
104
// double eta = 0.;
105
// double phi = 0.;
106
//math::PtEtaPhiMLorentzVector p4( pt+1.e-6, eta, phi, 0. );
107
108
//CaloStage1Cluster cluster;
109
CaloEmCand
EmCand(
p4
, (
int
)em.rank(), (
int
)em.regionId().ieta(), (
int
)em.regionId().iphi(), (
int
)em.index());
110
111
EmCand.
setHwIso
((
int
)em.isolated());
112
//std::cout<<"ISO: "<<EmCand.hwIso()<<" "<<em.isolated()<<std::endl;
113
114
// create new format
115
emcands.
push_back
(em.bx(), EmCand);
116
}
117
118
// loop over regions
119
for
(
auto
const
& rgn : rgns) {
120
// get physical units
121
// double pt = 0.;
122
// double eta = 0.;
123
// double phi = 0.;
124
//math::PtEtaPhiMLorentzVector p4( pt+1.e-6, eta, phi, 0 );
125
126
bool
tauVeto = rgn.fineGrain();
//equivalent to tauVeto for HB/HE, includes extra info for HF
127
int
hwQual = (
int
)tauVeto;
128
129
// create new format
130
// several values here are stage 2 only, leave empty
131
CaloRegion
region
(
p4
,
// LorentzVector& p4,
132
0.,
// etEm,
133
0.,
// etHad,
134
(
int
)rgn.et(),
// pt,
135
(
int
)rgn.id().ieta(),
// eta,
136
(
int
)rgn.id().iphi(),
// phi,
137
hwQual,
// qual,
138
0,
// hwEtEm,
139
0);
// hwEtHad
140
141
// add to output
142
regions
.push_back(rgn.bx(),
region
);
143
}
144
145
iEvent
.emplace(
emPutToken_
,
std::move
(emcands));
146
iEvent
.emplace(
rgnPutToken_
,
std::move
(
regions
));
147
}
148
149
// ------------ method fills 'descriptions' with the allowed parameters for the module ------------
150
void
L1TCaloRCTToUpgradeConverter::fillDescriptions
(
edm::ConfigurationDescriptions
& descriptions) {
151
edm::ParameterSetDescription
desc
;
152
desc
.add<
edm::InputTag
>(
"regionTag"
);
153
desc
.add<
edm::InputTag
>(
"emTag"
);
154
descriptions.
addDefault
(
desc
);
155
}
156
157
//define this as a plug-in
158
DEFINE_FWK_MODULE
(
L1TCaloRCTToUpgradeConverter
);
edm::StreamID
Definition:
StreamID.h:30
l1t::L1TCaloRCTToUpgradeConverter::rgnToken_
const edm::EDGetTokenT< L1CaloRegionCollection > rgnToken_
Definition:
L1TCaloRCTToUpgradeConverter.cc:55
L1CaloEmCand.h
MessageLogger.h
BXVector.h
edm::EDGetTokenT< L1CaloRegionCollection >
edm::EDPutTokenT
Definition:
EDPutToken.h:33
l1t::L1TCaloRCTToUpgradeConverter::produce
void produce(edm::StreamID, edm::Event &, const edm::EventSetup &) const override
Definition:
L1TCaloRCTToUpgradeConverter.cc:73
l1GtPatternGenerator_cfi.bx
bx
Definition:
l1GtPatternGenerator_cfi.py:18
edm::ParameterSetDescription
Definition:
ParameterSetDescription.h:52
l1t::L1TCaloRCTToUpgradeConverter::fillDescriptions
static void fillDescriptions(edm::ConfigurationDescriptions &descriptions)
Definition:
L1TCaloRCTToUpgradeConverter.cc:150
l1t::L1TCaloRCTToUpgradeConverter::L1TCaloRCTToUpgradeConverter
L1TCaloRCTToUpgradeConverter(const edm::ParameterSet &ps)
Definition:
L1TCaloRCTToUpgradeConverter.cc:66
l1t::L1TCaloRCTToUpgradeConverter::emPutToken_
const edm::EDPutTokenT< CaloEmCandBxCollection > emPutToken_
Definition:
L1TCaloRCTToUpgradeConverter.cc:59
BXVector
Definition:
BXVector.h:15
MakerMacros.h
CaloRegion.h
DEFINE_FWK_MODULE
#define DEFINE_FWK_MODULE(type)
Definition:
MakerMacros.h:16
EDGetToken.h
edm::global::EDProducer
Definition:
EDProducer.h:32
edm::ConfigurationDescriptions
Definition:
ConfigurationDescriptions.h:28
edm::ParameterSet
Definition:
ParameterSet.h:47
Event.h
l1t
delete x;
Definition:
CaloConfig.h:22
EDPutToken.h
LorentzVector.h
HLT_FULL_cff.region
region
Definition:
HLT_FULL_cff.py:88272
createfilelist.int
int
Definition:
createfilelist.py:10
L1CaloCollections.h
iEvent
int iEvent
Definition:
GenABIO.cc:224
p4
double p4[4]
Definition:
TauolaWrapper.h:92
l1t::L1TCaloRCTToUpgradeConverter
Definition:
L1TCaloRCTToUpgradeConverter.cc:44
edm::EventSetup
Definition:
EventSetup.h:57
InputTag.h
submitPVResolutionJobs.desc
string desc
Definition:
submitPVResolutionJobs.py:251
eostools.move
def move(src, dest)
Definition:
eostools.py:511
CaloEmCand.h
Frameworkfwd.h
l1t::CaloRegion
Definition:
CaloRegion.h:9
l1t::L1Candidate::setHwIso
void setHwIso(int iso)
Definition:
L1Candidate.h:32
EventSetup.h
l1t::L1TCaloRCTToUpgradeConverter::emToken_
const edm::EDGetTokenT< L1CaloEmCollection > emToken_
Definition:
L1TCaloRCTToUpgradeConverter.cc:56
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition:
ParameterSet.h:303
AlignmentPI::regions
regions
Definition:
AlignmentPayloadInspectorHelper.h:76
ParameterSet.h
EDProducer.h
l1t::L1TCaloRCTToUpgradeConverter::rgnPutToken_
const edm::EDPutTokenT< CaloRegionBxCollection > rgnPutToken_
Definition:
L1TCaloRCTToUpgradeConverter.cc:58
BXVector::setBXRange
void setBXRange(int bxFirst, int bxLast)
edm::Event
Definition:
Event.h:73
edm::ConfigurationDescriptions::addDefault
void addDefault(ParameterSetDescription const &psetDescription)
Definition:
ConfigurationDescriptions.cc:99
BXVector::push_back
void push_back(int bx, T object)
edm::InputTag
Definition:
InputTag.h:15
L1CaloRegion.h
l1t::CaloEmCand
Definition:
CaloEmCand.h:8
Generated for CMSSW Reference Manual by
1.8.16