CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Member Functions | Private Attributes
ticl::SeedingRegionByL1 Class Referencefinal

#include <SeedingRegionByL1.h>

Inheritance diagram for ticl::SeedingRegionByL1:
ticl::SeedingRegionAlgoBase

Public Member Functions

void initialize (const edm::EventSetup &es) override
 
void makeRegions (const edm::Event &ev, const edm::EventSetup &es, std::vector< TICLSeedingRegion > &result) override
 
 SeedingRegionByL1 (const edm::ParameterSet &conf, edm::ConsumesCollector &sumes)
 
- Public Member Functions inherited from ticl::SeedingRegionAlgoBase
 SeedingRegionAlgoBase (const edm::ParameterSet &conf, edm::ConsumesCollector &sumes)
 
virtual ~SeedingRegionAlgoBase ()
 

Static Public Member Functions

static void fillPSetDescription (edm::ParameterSetDescription &desc)
 
- Static Public Member Functions inherited from ticl::SeedingRegionAlgoBase
static void fillPSetDescription (edm::ParameterSetDescription &desc)
 

Private Member Functions

double tkEmOfflineEt (double et) const
 

Private Attributes

int algoVerbosity_ = 0
 
bool applyQuality_
 
std::vector< double > endcapScalings_
 
edm::EDGetTokenT< std::vector< l1t::TkEm > > l1TkEmsToken_
 
double maxAbsEta_
 
double minAbsEta_
 
double minPt_
 
int quality_
 
bool qualityIsMask_
 

Additional Inherited Members

- Protected Attributes inherited from ticl::SeedingRegionAlgoBase
int algo_verbosity_
 
int algoId_
 

Detailed Description

Definition at line 22 of file SeedingRegionByL1.h.

Constructor & Destructor Documentation

◆ SeedingRegionByL1()

ticl::SeedingRegionByL1::SeedingRegionByL1 ( const edm::ParameterSet conf,
edm::ConsumesCollector sumes 
)

Definition at line 19 of file SeedingRegionByL1.cc.

20  : SeedingRegionAlgoBase(conf, sumes),
21  l1TkEmsToken_(sumes.consumes<std::vector<l1t::TkEm>>(conf.getParameter<edm::InputTag>("l1TkEmColl"))),
22  algoVerbosity_(conf.getParameter<int>("algo_verbosity")),
23  minPt_(conf.getParameter<double>("minPt")),
24  minAbsEta_(conf.getParameter<double>("minAbsEta")),
25  maxAbsEta_(conf.getParameter<double>("maxAbsEta")),
26  endcapScalings_(conf.getParameter<std::vector<double>>("endcapScalings")),
27  quality_(conf.getParameter<int>("quality")),
28  qualityIsMask_(conf.getParameter<bool>("qualityIsMask")),
29  applyQuality_(conf.getParameter<bool>("applyQuality")) {}
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
T getParameter(std::string const &) const
Definition: ParameterSet.h:307
SeedingRegionAlgoBase(const edm::ParameterSet &conf, edm::ConsumesCollector &sumes)
std::vector< double > endcapScalings_
edm::EDGetTokenT< std::vector< l1t::TkEm > > l1TkEmsToken_

Member Function Documentation

◆ fillPSetDescription()

void ticl::SeedingRegionByL1::fillPSetDescription ( edm::ParameterSetDescription desc)
static

Definition at line 74 of file SeedingRegionByL1.cc.

References submitPVResolutionJobs::desc, ticl::SeedingRegionAlgoBase::fillPSetDescription(), and ProducerED_cfi::InputTag.

74  {
75  desc.add<edm::InputTag>("l1TkEmColl", edm::InputTag("L1TkPhotonsHGC", "EG"));
76  desc.add<double>("minPt", 10);
77  desc.add<double>("minAbsEta", 1.479);
78  desc.add<double>("maxAbsEta", 4.0);
79  desc.add<std::vector<double>>("endcapScalings", {3.17445, 1.13219, 0.0});
80  desc.add<int>("quality", 5);
81  desc.add<bool>("qualityIsMask", false);
82  desc.add<bool>("applyQuality", false);
84 }
static void fillPSetDescription(edm::ParameterSetDescription &desc)

◆ initialize()

void ticl::SeedingRegionByL1::initialize ( const edm::EventSetup es)
inlineoverridevirtual

Implements ticl::SeedingRegionAlgoBase.

Definition at line 26 of file SeedingRegionByL1.h.

26 {};

◆ makeRegions()

void ticl::SeedingRegionByL1::makeRegions ( const edm::Event ev,
const edm::EventSetup es,
std::vector< TICLSeedingRegion > &  result 
)
overridevirtual

Implements ticl::SeedingRegionAlgoBase.

Definition at line 31 of file SeedingRegionByL1.cc.

References a, funct::abs(), b, makeMEIFBenchmarkPlots::ev, edm::ProductID::id(), createfilelist::int, mps_fire::result, and jetUpdater_cfi::sort.

33  {
34  auto l1TrkEms = ev.getHandle(l1TkEmsToken_);
35  edm::ProductID l1tkemsId = l1TrkEms.id();
36 
37  for (size_t indx = 0; indx < (*l1TrkEms).size(); indx++) {
38  const auto &l1TrkEm = (*l1TrkEms)[indx];
39  double offlinePt = this->tkEmOfflineEt(l1TrkEm.pt());
40  bool passQuality(false);
41 
42  if (applyQuality_) {
43  if (qualityIsMask_) {
44  passQuality = (l1TrkEm.hwQual() & quality_);
45  } else {
46  passQuality = (l1TrkEm.hwQual() == quality_);
47  }
48  } else {
49  passQuality = true;
50  }
51 
52  if ((offlinePt < minPt_) || (std::abs(l1TrkEm.eta()) < minAbsEta_) || (std::abs(l1TrkEm.eta()) > maxAbsEta_) ||
53  !passQuality) {
54  continue;
55  }
56 
57  int iSide = int(l1TrkEm.eta() > 0);
58  result.emplace_back(GlobalPoint(l1TrkEm.p4().X(), l1TrkEm.p4().Y(), l1TrkEm.p4().Z()),
59  GlobalVector(l1TrkEm.px(), l1TrkEm.py(), l1TrkEm.pz()),
60  iSide,
61  indx,
62  l1tkemsId);
63  }
64 
65  std::sort(result.begin(), result.end(), [](const TICLSeedingRegion &a, const TICLSeedingRegion &b) {
66  return a.directionAtOrigin.perp2() > b.directionAtOrigin.perp2();
67  });
68 }
Global3DPoint GlobalPoint
Definition: GlobalPoint.h:10
Abs< T >::type abs(const T &t)
Definition: Abs.h:22
edm::EDGetTokenT< std::vector< l1t::TkEm > > l1TkEmsToken_
ProductIndex id() const
Definition: ProductID.h:35
double tkEmOfflineEt(double et) const
double b
Definition: hdecay.h:120
double a
Definition: hdecay.h:121
Global3DVector GlobalVector
Definition: GlobalVector.h:10

◆ tkEmOfflineEt()

double ticl::SeedingRegionByL1::tkEmOfflineEt ( double  et) const
private

Definition at line 70 of file SeedingRegionByL1.cc.

References EgHLTOffHistBins_cfi::et.

70  {
71  return (endcapScalings_.at(0) + et * endcapScalings_.at(1) + et * et * endcapScalings_.at(2));
72 }
std::vector< double > endcapScalings_

Member Data Documentation

◆ algoVerbosity_

int ticl::SeedingRegionByL1::algoVerbosity_ = 0
private

Definition at line 32 of file SeedingRegionByL1.h.

◆ applyQuality_

bool ticl::SeedingRegionByL1::applyQuality_
private

Definition at line 39 of file SeedingRegionByL1.h.

◆ endcapScalings_

std::vector<double> ticl::SeedingRegionByL1::endcapScalings_
private

Definition at line 36 of file SeedingRegionByL1.h.

◆ l1TkEmsToken_

edm::EDGetTokenT<std::vector<l1t::TkEm> > ticl::SeedingRegionByL1::l1TkEmsToken_
private

Definition at line 31 of file SeedingRegionByL1.h.

◆ maxAbsEta_

double ticl::SeedingRegionByL1::maxAbsEta_
private

Definition at line 35 of file SeedingRegionByL1.h.

◆ minAbsEta_

double ticl::SeedingRegionByL1::minAbsEta_
private

Definition at line 34 of file SeedingRegionByL1.h.

◆ minPt_

double ticl::SeedingRegionByL1::minPt_
private

Definition at line 33 of file SeedingRegionByL1.h.

◆ quality_

int ticl::SeedingRegionByL1::quality_
private

Definition at line 37 of file SeedingRegionByL1.h.

◆ qualityIsMask_

bool ticl::SeedingRegionByL1::qualityIsMask_
private

Definition at line 38 of file SeedingRegionByL1.h.