CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Groups Pages
List of all members | Classes | Public Member Functions | Private Member Functions | Private Attributes
SiStripGainESProducer Class Reference
Inheritance diagram for SiStripGainESProducer:
edm::ESProducer edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Classes

class  GainGetter
 
class  GainGetterT
 

Public Member Functions

std::unique_ptr< SiStripGainproduce (const SiStripGainRcd &)
 
 SiStripGainESProducer (const edm::ParameterSet &)
 
 ~SiStripGainESProducer () override
 
- 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)
 

Private Member Functions

template<typename Record >
auto make_GainGetter (edm::ESConsumesCollector &cc, std::string record, std::string label)
 

Private Attributes

SiStripGainFactor factor_
 
std::vector< std::unique_ptr
< GainGetter > > 
gainGetters_
 

Additional Inherited Members

- Static Public Member Functions inherited from edm::eventsetup::DataProxyProvider
static void prevalidate (ConfigurationDescriptions &)
 
- 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 >>>
 
- Protected Member Functions inherited from edm::ESProducer
template<typename T >
auto setWhatProduced (T *iThis, const es::Label &iLabel={})
 
template<typename T >
auto setWhatProduced (T *iThis, const char *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)
 

Detailed Description

Definition at line 23 of file SiStripGainESProducer.cc.

Constructor & Destructor Documentation

SiStripGainESProducer::SiStripGainESProducer ( const edm::ParameterSet iConfig)

Definition at line 66 of file SiStripGainESProducer.cc.

66  : factor_{iConfig} {
67  auto cc = setWhatProduced(this);
68 
69  auto apvGainLabels = iConfig.getParameter<std::vector<edm::ParameterSet>>("APVGain");
70  if (apvGainLabels.empty()) {
71  throw cms::Exception("Configuration") << "Got empty APVGain vector, but need at least one entry";
72  }
73 
74  // Fill the vector of apv labels
75  for (const auto& gainPSet : apvGainLabels) {
76  // Shouldn't all these parameters be tracked?
77  auto record = gainPSet.getParameter<std::string>("Record");
78  auto label = gainPSet.getUntrackedParameter<std::string>("Label", "");
79  if (record == "SiStripApvGainRcd")
80  gainGetters_.emplace_back(make_GainGetter<SiStripApvGainRcd>(cc, record, label));
81  else if (record == "SiStripApvGain2Rcd")
82  gainGetters_.emplace_back(make_GainGetter<SiStripApvGain2Rcd>(cc, record, label));
83  else if (record == "SiStripApvGain3Rcd")
84  gainGetters_.emplace_back(make_GainGetter<SiStripApvGain3Rcd>(cc, record, label));
85  else
86  throw cms::Exception("Configuration")
87  << "SiStripGainESProducer::ctor ERROR: unrecognized record name " << record << std::endl
88  << "please specify one of: SiStripApvGainRcd, SiStripApvGain2Rcd, SiStripApvGain3Rcd";
89  factor_.push_back_norm(gainPSet.getUntrackedParameter<double>("NormalizationFactor", 1.));
90  }
92 }
auto setWhatProduced(T *iThis, const es::Label &iLabel={})
Definition: ESProducer.h:163
void push_back_norm(double norm)
char const * label
std::vector< std::unique_ptr< GainGetter > > gainGetters_
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
SiStripGainESProducer::~SiStripGainESProducer ( )
inlineoverride

Definition at line 26 of file SiStripGainESProducer.cc.

26 {};

Member Function Documentation

template<typename Record >
auto SiStripGainESProducer::make_GainGetter ( edm::ESConsumesCollector cc,
std::string  record,
std::string  label 
)
inlineprivate

Definition at line 57 of file SiStripGainESProducer.cc.

References eostools::move().

57  {
58  return std::make_unique<GainGetterT<Record>>(cc, std::move(record), std::move(label));
59  }
char const * label
def move
Definition: eostools.py:511
std::unique_ptr< SiStripGain > SiStripGainESProducer::produce ( const SiStripGainRcd iRecord)

Definition at line 94 of file SiStripGainESProducer.cc.

References factor_, gainGetters_, SiStripGainFactor::get(), mps_fire::i, SiStripDetInfoFileReader::kDefaultFile, and SiStripDetInfoFileReader::read().

94  {
95  const auto detInfo =
97 
98  const auto& apvGain = gainGetters_[0]->gain(iRecord);
99  // Create a new gain object and insert the ApvGain
100  auto gain = std::make_unique<SiStripGain>(apvGain, factor_.get(apvGain, 0), gainGetters_[0]->recordLabel(), detInfo);
101 
102  for (unsigned int i = 1; i < gainGetters_.size(); ++i) {
103  const auto& apvGain = gainGetters_[i]->gain(iRecord);
104  // Add the new ApvGain to the gain object
105  gain->multiply(apvGain, factor_.get(apvGain, i), gainGetters_[i]->recordLabel(), detInfo);
106  }
107 
108  return gain;
109 }
std::vector< std::unique_ptr< GainGetter > > gainGetters_
SiStripDetInfo read(std::string filePath)
double get(const SiStripApvGain &gain, const int apvGainIndex) const
static constexpr char const *const kDefaultFile

Member Data Documentation

SiStripGainFactor SiStripGainESProducer::factor_
private

Definition at line 63 of file SiStripGainESProducer.cc.

Referenced by produce().

std::vector<std::unique_ptr<GainGetter> > SiStripGainESProducer::gainGetters_
private

Definition at line 61 of file SiStripGainESProducer.cc.

Referenced by produce().