CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Protected Member Functions | Private Attributes
EcalRecHitParametersGPUESProducer Class Reference
Inheritance diagram for EcalRecHitParametersGPUESProducer:
edm::ESProducer edm::EventSetupRecordIntervalFinder edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Public Member Functions

 EcalRecHitParametersGPUESProducer (edm::ParameterSet const &)
 
std::unique_ptr< EcalRecHitParametersGPUproduce (JobConfigurationGPURecord const &)
 
 ~EcalRecHitParametersGPUESProducer () override=default
 
- Public Member Functions inherited from edm::ESProducer
 ESProducer ()
 
 ESProducer (const ESProducer &)=delete
 
ESProxyIndex const * getTokenIndices (unsigned int iIndex) const
 
ESRecordIndex const * getTokenRecordIndices (unsigned int iIndex) const
 
bool hasMayConsumes () const noexcept
 
size_t numberOfTokenIndices (unsigned int iIndex) const
 
ESProducer const & operator= (const ESProducer &)=delete
 
SerialTaskQueueChainqueue ()
 
template<typename Record >
std::optional< std::vector< ESProxyIndex > > updateFromMayConsumes (unsigned int iIndex, const Record &iRecord) const
 
void updateLookup (eventsetup::ESRecordsToProxyIndices const &) final
 
 ~ESProducer () noexcept(false) override
 
- Public Member Functions inherited from edm::ESProxyFactoryProducer
 ESProxyFactoryProducer ()
 
 ESProxyFactoryProducer (const ESProxyFactoryProducer &)=delete
 
const ESProxyFactoryProduceroperator= (const ESProxyFactoryProducer &)=delete
 
 ~ESProxyFactoryProducer () noexcept(false) override
 
- Public Member Functions inherited from edm::eventsetup::DataProxyProvider
void createKeyedProxies (EventSetupRecordKey const &key, unsigned int nConcurrentIOVs)
 
 DataProxyProvider ()
 
 DataProxyProvider (const DataProxyProvider &)=delete
 
const ComponentDescriptiondescription () const
 
void fillRecordsNotAllowingConcurrentIOVs (std::set< EventSetupRecordKey > &recordsNotAllowingConcurrentIOVs) const
 
virtual void initConcurrentIOVs (EventSetupRecordKey const &key, unsigned int nConcurrentIOVs)
 
bool isUsingRecord (const EventSetupRecordKey &key) const
 
KeyedProxieskeyedProxies (const EventSetupRecordKey &iRecordKey, unsigned int iovIndex=0)
 
const DataProxyProvideroperator= (const DataProxyProvider &)=delete
 
void setAppendToDataLabel (const edm::ParameterSet &)
 
void setDescription (const ComponentDescription &iDescription)
 
std::set< EventSetupRecordKeyusingRecords () const
 
virtual ~DataProxyProvider () noexcept(false)
 
- Public Member Functions inherited from edm::EventSetupRecordIntervalFinder
bool concurrentFinder () const
 
const eventsetup::ComponentDescriptiondescriptionForFinder () const
 
 EventSetupRecordIntervalFinder ()
 
 EventSetupRecordIntervalFinder (const EventSetupRecordIntervalFinder &)=delete
 
std::set< eventsetup::EventSetupRecordKeyfindingForRecords () const
 
const ValidityIntervalfindIntervalFor (const eventsetup::EventSetupRecordKey &, const IOVSyncValue &)
 
bool nonconcurrentAndIOVNeedsUpdate (const eventsetup::EventSetupRecordKey &key, const IOVSyncValue &syncValue) const
 
const EventSetupRecordIntervalFinderoperator= (const EventSetupRecordIntervalFinder &)=delete
 
void resetInterval (const eventsetup::EventSetupRecordKey &)
 
void setDescriptionForFinder (const eventsetup::ComponentDescription &iDescription)
 
virtual ~EventSetupRecordIntervalFinder () noexcept(false)
 

Static Public Member Functions

static void fillDescriptions (edm::ConfigurationDescriptions &)
 
- Static Public Member Functions inherited from edm::eventsetup::DataProxyProvider
static void prevalidate (ConfigurationDescriptions &)
 

Protected Member Functions

void setIntervalFor (const edm::eventsetup::EventSetupRecordKey &, const edm::IOVSyncValue &, edm::ValidityInterval &) override
 
- Protected Member Functions inherited from edm::ESProducer
template<typename T >
auto setWhatProduced (T *iThis, const char *iLabel)
 
template<typename T >
auto setWhatProduced (T *iThis, const es::Label &iLabel={})
 
template<typename T >
auto setWhatProduced (T *iThis, const std::string &iLabel)
 
template<typename T , typename TDecorator >
auto setWhatProduced (T *iThis, const TDecorator &iDec, const es::Label &iLabel={})
 
template<typename T , typename TReturn , typename TRecord >
auto setWhatProduced (T *iThis, TReturn(T ::*iMethod)(const TRecord &), const es::Label &iLabel={})
 
template<typename T , typename TReturn , typename TRecord , typename TArg >
ESConsumesCollectorT< TRecord > setWhatProduced (T *iThis, TReturn(T ::*iMethod)(const TRecord &), const TArg &iDec, const es::Label &iLabel={})
 
void usesResources (std::vector< std::string > const &)
 
- Protected Member Functions inherited from edm::ESProxyFactoryProducer
template<class TFactory >
void registerFactory (std::unique_ptr< TFactory > iFactory, const std::string &iLabel=std::string())
 
virtual void registerFactoryWithKey (const EventSetupRecordKey &iRecord, std::unique_ptr< eventsetup::ProxyFactoryBase > iFactory, const std::string &iLabel=std::string())
 
KeyedProxiesVector registerProxies (const EventSetupRecordKey &, unsigned int iovIndex) override
 
- Protected Member Functions inherited from edm::eventsetup::DataProxyProvider
template<class T >
void usingRecord ()
 
void usingRecordWithKey (const EventSetupRecordKey &key)
 
- Protected Member Functions inherited from edm::EventSetupRecordIntervalFinder
template<class T >
void findingRecord ()
 
void findingRecordWithKey (const eventsetup::EventSetupRecordKey &)
 

Private Attributes

const edm::ParameterSet pset_
 

Additional Inherited Members

- Protected Types inherited from edm::ESProxyFactoryProducer
using EventSetupRecordKey = eventsetup::EventSetupRecordKey
 
- Protected Types inherited from edm::eventsetup::DataProxyProvider
using KeyedProxiesVector = std::vector< std::pair< DataKey, std::shared_ptr< DataProxy > >>
 

Detailed Description

Definition at line 22 of file EcalRecHitParametersGPUESProducer.cc.

Constructor & Destructor Documentation

◆ EcalRecHitParametersGPUESProducer()

EcalRecHitParametersGPUESProducer::EcalRecHitParametersGPUESProducer ( edm::ParameterSet const &  pset)

Definition at line 39 of file EcalRecHitParametersGPUESProducer.cc.

39  : pset_{pset} {
40  setWhatProduced(this);
41  findingRecord<JobConfigurationGPURecord>();
42 }

References muonDTDigis_cfi::pset.

◆ ~EcalRecHitParametersGPUESProducer()

EcalRecHitParametersGPUESProducer::~EcalRecHitParametersGPUESProducer ( )
overridedefault

Member Function Documentation

◆ fillDescriptions()

void EcalRecHitParametersGPUESProducer::fillDescriptions ( edm::ConfigurationDescriptions desc)
static

Definition at line 50 of file EcalRecHitParametersGPUESProducer.cc.

50  {
52 
53  //---- db statuses to be exluded from reconstruction
54  d.add<std::vector<std::string>>("ChannelStatusToBeExcluded",
55  {
56  "kDAC",
57  "kNoisy",
58  "kNNoisy",
59  "kFixedG6",
60  "kFixedG1",
61  "kFixedG0",
62  "kNonRespondingIsolated",
63  "kDeadVFE",
64  "kDeadFE",
65  "kNoDataNoTP",
66  });
67 
68  // reco flags association to DB flag
69  edm::ParameterSetDescription desc_list_flagsMapDBReco;
70  desc_list_flagsMapDBReco.add<std::vector<std::string>>("kGood", {"kOk", "kDAC", "kNoLaser", "kNoisy"});
71  desc_list_flagsMapDBReco.add<std::vector<std::string>>("kNoisy", {"kNNoisy", "kFixedG6", "kFixedG1"});
72  desc_list_flagsMapDBReco.add<std::vector<std::string>>("kNeighboursRecovered",
73  {"kFixedG0", "kNonRespondingIsolated", "kDeadVFE"});
74  desc_list_flagsMapDBReco.add<std::vector<std::string>>("kTowerRecovered", {"kDeadFE"});
75  desc_list_flagsMapDBReco.add<std::vector<std::string>>("kDead", {"kNoDataNoTP"});
76 
77  d.add<edm::ParameterSetDescription>("flagsMapDBReco", desc_list_flagsMapDBReco);
78 
79  desc.addWithDefaultLabel(d);
80 }

References edm::ParameterSetDescription::add(), ztail::d, and submitPVResolutionJobs::desc.

◆ produce()

std::unique_ptr< EcalRecHitParametersGPU > EcalRecHitParametersGPUESProducer::produce ( JobConfigurationGPURecord const &  )

Definition at line 82 of file EcalRecHitParametersGPUESProducer.cc.

82  {
83  auto const& channelStatusToBeExcluded = StringToEnumValue<EcalChannelStatusCode::Code>(
84  pset_.getParameter<std::vector<std::string>>("ChannelStatusToBeExcluded"));
85 
86  // https://github.com/cms-sw/cmssw/blob/266e21cfc9eb409b093e4cf064f4c0a24c6ac293/RecoLocalCalo/EcalRecProducers/plugins/EcalRecHitWorkerSimple.cc
87 
88  // Translate string representation of flagsMapDBReco into enum values
89  const edm::ParameterSet& p = pset_.getParameter<edm::ParameterSet>("flagsMapDBReco");
90  std::vector<std::string> recoflagbitsStrings = p.getParameterNames();
91 
92  std::vector<EcalRecHitParametersGPU::DBStatus> status;
93  status.reserve(recoflagbitsStrings.size());
94  for (auto const& recoflagbitsString : recoflagbitsStrings) {
95  EcalRecHit::Flags recoflagbit = (EcalRecHit::Flags)StringToEnumValue<EcalRecHit::Flags>(recoflagbitsString);
96  std::vector<std::string> dbstatus_s = p.getParameter<std::vector<std::string>>(recoflagbitsString);
97 
98  std::vector<uint32_t> db_reco_flags;
99  db_reco_flags.reserve(dbstatus_s.size());
100  for (auto const& dbstatusString : dbstatus_s) {
101  EcalChannelStatusCode::Code dbstatus =
102  (EcalChannelStatusCode::Code)StringToEnumValue<EcalChannelStatusCode::Code>(dbstatusString);
103  db_reco_flags.push_back(dbstatus);
104  }
105  status.emplace_back(static_cast<int>(recoflagbit), db_reco_flags);
106  }
107 
108  return std::make_unique<EcalRecHitParametersGPU>(channelStatusToBeExcluded, status);
109 }

References edm::ParameterSet::getParameter(), AlCaHLTBitMon_ParallelJobs::p, pset_, and mps_update::status.

◆ setIntervalFor()

void EcalRecHitParametersGPUESProducer::setIntervalFor ( const edm::eventsetup::EventSetupRecordKey iKey,
const edm::IOVSyncValue iTime,
edm::ValidityInterval oInterval 
)
overrideprotectedvirtual

Member Data Documentation

◆ pset_

const edm::ParameterSet EcalRecHitParametersGPUESProducer::pset_
private

Definition at line 36 of file EcalRecHitParametersGPUESProducer.cc.

Referenced by produce().

EcalRecHitParametersGPUESProducer::pset_
const edm::ParameterSet pset_
Definition: EcalRecHitParametersGPUESProducer.cc:36
edm::ParameterSetDescription::add
ParameterDescriptionBase * add(U const &iLabel, T const &value)
Definition: ParameterSetDescription.h:95
mps_update.status
status
Definition: mps_update.py:68
EcalRecHit::Flags
Flags
Definition: EcalRecHit.h:20
edm::ESProducer::setWhatProduced
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
Definition: ESProducer.h:163
edm::ParameterSetDescription
Definition: ParameterSetDescription.h:52
edm::ParameterSet
Definition: ParameterSet.h:47
AlCaHLTBitMon_ParallelJobs.p
def p
Definition: AlCaHLTBitMon_ParallelJobs.py:153
edm::IOVSyncValue::endOfTime
static const IOVSyncValue & endOfTime()
Definition: IOVSyncValue.cc:82
EcalChannelStatusCode::Code
Code
Definition: EcalChannelStatusCode.h:20
cond::ValidityInterval
std::pair< Time_t, Time_t > ValidityInterval
Definition: Time.h:17
submitPVResolutionJobs.desc
string desc
Definition: submitPVResolutionJobs.py:251
edm::IOVSyncValue::beginOfTime
static const IOVSyncValue & beginOfTime()
Definition: IOVSyncValue.cc:88
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
ztail.d
d
Definition: ztail.py:151
muonDTDigis_cfi.pset
pset
Definition: muonDTDigis_cfi.py:27