CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions | Private Member Functions | Private Attributes
ElectronLikelihoodESSource Class Reference

#include <ElectronLikelihoodESSource.h>

Inheritance diagram for ElectronLikelihoodESSource:
edm::ESProducer edm::EventSetupRecordIntervalFinder edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Public Types

typedef std::unique_ptr< ElectronLikelihoodReturnType
 define the return type More...
 
- Public Types inherited from edm::eventsetup::DataProxyProvider
typedef std::vector< std::pair< DataKey, edm::propagate_const< std::shared_ptr< DataProxy > > > > KeyedProxies
 
typedef std::vector< EventSetupRecordKeyKeys
 
typedef std::map< EventSetupRecordKey, KeyedProxiesRecordProxies
 

Public Member Functions

 ElectronLikelihoodESSource (const edm::ParameterSet &)
 constructor from parameter set More...
 
ReturnType produce (const ElectronLikelihoodRcd &)
 return the particle table More...
 
void setIntervalFor (const edm::eventsetup::EventSetupRecordKey &, const edm::IOVSyncValue &, edm::ValidityInterval &) override
 set validity interval More...
 
 ~ElectronLikelihoodESSource () override
 destructor More...
 
- Public Member Functions inherited from edm::ESProducer
 ESProducer ()
 
 ~ESProducer ()(false) override
 
- Public Member Functions inherited from edm::ESProxyFactoryProducer
 ESProxyFactoryProducer ()
 
void newInterval (const eventsetup::EventSetupRecordKey &iRecordType, const ValidityInterval &iInterval) override
 overrides DataProxyProvider method More...
 
 ~ESProxyFactoryProducer () noexcept(false) override
 
- Public Member Functions inherited from edm::eventsetup::DataProxyProvider
 DataProxyProvider ()
 
const ComponentDescriptiondescription () const
 
bool isUsingRecord (const EventSetupRecordKey &) const
 
const KeyedProxieskeyedProxies (const EventSetupRecordKey &iRecordKey) const
 
void resetProxies (const EventSetupRecordKey &iRecordType)
 
void resetProxiesIfTransient (const EventSetupRecordKey &iRecordType)
 
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
const eventsetup::ComponentDescriptiondescriptionForFinder () const
 
 EventSetupRecordIntervalFinder ()
 
std::set< eventsetup::EventSetupRecordKeyfindingForRecords () const
 
const ValidityIntervalfindIntervalFor (const eventsetup::EventSetupRecordKey &, const IOVSyncValue &)
 
void setDescriptionForFinder (const eventsetup::ComponentDescription &iDescription)
 
virtual ~EventSetupRecordIntervalFinder () noexcept(false)
 

Private Member Functions

const ElectronLikelihoodCalibrationreadPdfFromDB (const ElectronLikelihoodRcd &)
 read PDF's from CondDB More...
 

Private Attributes

std::string m_backgroundWeightSplitting
 
LikelihoodSwitches m_eleIDSwitches
 general parameters of the id algorithm More...
 
std::string m_signalWeightSplitting
 signal pdf splitting More...
 
bool m_splitBackgroundPdfs
 
bool m_splitSignalPdfs
 

Additional Inherited Members

- Static Public Member Functions inherited from edm::eventsetup::DataProxyProvider
static void prevalidate (ConfigurationDescriptions &)
 
- Protected Member Functions inherited from edm::ESProducer
template<typename T >
void setWhatProduced (T *iThis, const es::Label &iLabel=es::Label())
 
template<typename T >
void setWhatProduced (T *iThis, const char *iLabel)
 
template<typename T >
void setWhatProduced (T *iThis, const std::string &iLabel)
 
template<typename T , typename TDecorator >
void setWhatProduced (T *iThis, const TDecorator &iDec, const es::Label &iLabel=es::Label())
 
template<typename T , typename TReturn , typename TRecord >
void setWhatProduced (T *iThis, TReturn(T::*iMethod)(const TRecord &), const es::Label &iLabel=es::Label())
 
template<typename T , typename TReturn , typename TRecord , typename TArg >
void setWhatProduced (T *iThis, TReturn(T::*iMethod)(const TRecord &), const TArg &iDec, const es::Label &iLabel=es::Label())
 
- 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 eventsetup::EventSetupRecordKey &iRecord, std::unique_ptr< eventsetup::ProxyFactoryBase > iFactory, const std::string &iLabel=std::string())
 
void registerProxies (const eventsetup::EventSetupRecordKey &iRecord, KeyedProxies &aProxyList) override
 override DataProxyProvider method More...
 
- Protected Member Functions inherited from edm::eventsetup::DataProxyProvider
void eraseAll (const EventSetupRecordKey &iRecordKey)
 deletes all the Proxies in aStream More...
 
void invalidateProxies (const EventSetupRecordKey &iRecordKey)
 
template<class T >
void usingRecord ()
 
void usingRecordWithKey (const EventSetupRecordKey &)
 
- Protected Member Functions inherited from edm::EventSetupRecordIntervalFinder
template<class T >
void findingRecord ()
 
void findingRecordWithKey (const eventsetup::EventSetupRecordKey &)
 

Detailed Description

Definition at line 38 of file ElectronLikelihoodESSource.h.

Member Typedef Documentation

define the return type

Definition at line 45 of file ElectronLikelihoodESSource.h.

Constructor & Destructor Documentation

ElectronLikelihoodESSource::ElectronLikelihoodESSource ( const edm::ParameterSet cfg)

constructor from parameter set

Definition at line 3 of file ElectronLikelihoodESSource.cc.

References edm::ParameterSet::getParameter(), m_eleIDSwitches, LikelihoodSwitches::m_useDeltaEta, LikelihoodSwitches::m_useDeltaPhi, LikelihoodSwitches::m_useEoverP, LikelihoodSwitches::m_useFBrem, LikelihoodSwitches::m_useHoverE, LikelihoodSwitches::m_useOneOverEMinusOneOverP, LikelihoodSwitches::m_useSigmaEtaEta, LikelihoodSwitches::m_useSigmaPhiPhi, and edm::ESProducer::setWhatProduced().

3  :
4  m_signalWeightSplitting (cfg.getParameter<std::string> ("signalWeightSplitting")) ,
5  m_backgroundWeightSplitting (cfg.getParameter<std::string> ("backgroundWeightSplitting")) ,
6  m_splitSignalPdfs (cfg.getParameter<bool> ("splitSignalPdfs")) ,
7  m_splitBackgroundPdfs (cfg.getParameter<bool> ("splitBackgroundPdfs"))
8 {
9  setWhatProduced (this) ;
10  findingRecord<ElectronLikelihoodRcd> () ;
11 
12  m_eleIDSwitches.m_useDeltaEta = cfg.getParameter<bool> ("useDeltaEta") ;
13  m_eleIDSwitches.m_useDeltaPhi = cfg.getParameter<bool> ("useDeltaPhi") ;
14  m_eleIDSwitches.m_useHoverE = cfg.getParameter<bool> ("useHoverE") ;
15  m_eleIDSwitches.m_useEoverP = cfg.getParameter<bool> ("useEoverP") ;
16  m_eleIDSwitches.m_useSigmaEtaEta = cfg.getParameter<bool> ("useSigmaEtaEta") ;
17  m_eleIDSwitches.m_useSigmaPhiPhi = cfg.getParameter<bool> ("useSigmaPhiPhi") ;
18  m_eleIDSwitches.m_useFBrem = cfg.getParameter<bool> ("useFBrem") ;
19  m_eleIDSwitches.m_useOneOverEMinusOneOverP = cfg.getParameter<bool> ("useOneOverEMinusOneOverP") ;
20 
21 }
T getParameter(std::string const &) const
std::string m_signalWeightSplitting
signal pdf splitting
void setWhatProduced(T *iThis, const es::Label &iLabel=es::Label())
Definition: ESProducer.h:115
LikelihoodSwitches m_eleIDSwitches
general parameters of the id algorithm
ElectronLikelihoodESSource::~ElectronLikelihoodESSource ( )
override

destructor

Definition at line 27 of file ElectronLikelihoodESSource.cc.

27  {
28 }

Member Function Documentation

ElectronLikelihoodESSource::ReturnType ElectronLikelihoodESSource::produce ( const ElectronLikelihoodRcd iRecord)

return the particle table

Definition at line 35 of file ElectronLikelihoodESSource.cc.

References m_backgroundWeightSplitting, m_eleIDSwitches, m_signalWeightSplitting, m_splitBackgroundPdfs, m_splitSignalPdfs, and readPdfFromDB().

36 {
37 
38  const ElectronLikelihoodCalibration *calibration = readPdfFromDB (iRecord) ;
39 
40  ReturnType LHAlgo (new ElectronLikelihood (&(*calibration),
44  ) );
45 
46  return LHAlgo;
47 }
std::string m_signalWeightSplitting
signal pdf splitting
const ElectronLikelihoodCalibration * readPdfFromDB(const ElectronLikelihoodRcd &)
read PDF&#39;s from CondDB
LikelihoodSwitches m_eleIDSwitches
general parameters of the id algorithm
std::unique_ptr< ElectronLikelihood > ReturnType
define the return type
const ElectronLikelihoodCalibration * ElectronLikelihoodESSource::readPdfFromDB ( const ElectronLikelihoodRcd iRecord)
private

read PDF's from CondDB

Definition at line 66 of file ElectronLikelihoodESSource.cc.

References edm::eventsetup::DependentRecordImplementation< RecordT, ListT >::getRecord(), and edm::ESHandle< T >::product().

Referenced by produce().

66  {
67 
68  // setup the PDF's from DB
69  const ElectronLikelihoodCalibration *calibration = nullptr;
71  iRecord.getRecord<ElectronLikelihoodPdfsRcd>().get(calibHandle);
72  calibration = calibHandle.product();
73 
74  return calibration;
75 }
T const * product() const
Definition: ESHandle.h:86
void ElectronLikelihoodESSource::setIntervalFor ( const edm::eventsetup::EventSetupRecordKey ,
const edm::IOVSyncValue ,
edm::ValidityInterval oInterval 
)
overridevirtual

set validity interval

Implements edm::EventSetupRecordIntervalFinder.

Definition at line 54 of file ElectronLikelihoodESSource.cc.

References edm::IOVSyncValue::beginOfTime(), and edm::IOVSyncValue::endOfTime().

56  {
57  // the same PDF's is valid for any time
60 }
static const IOVSyncValue & endOfTime()
Definition: IOVSyncValue.cc:97
std::pair< Time_t, Time_t > ValidityInterval
Definition: Time.h:19
static const IOVSyncValue & beginOfTime()

Member Data Documentation

std::string ElectronLikelihoodESSource::m_backgroundWeightSplitting
private

Definition at line 64 of file ElectronLikelihoodESSource.h.

Referenced by produce().

LikelihoodSwitches ElectronLikelihoodESSource::m_eleIDSwitches
private

general parameters of the id algorithm

Definition at line 60 of file ElectronLikelihoodESSource.h.

Referenced by ElectronLikelihoodESSource(), and produce().

std::string ElectronLikelihoodESSource::m_signalWeightSplitting
private

signal pdf splitting

Definition at line 63 of file ElectronLikelihoodESSource.h.

Referenced by produce().

bool ElectronLikelihoodESSource::m_splitBackgroundPdfs
private

Definition at line 66 of file ElectronLikelihoodESSource.h.

Referenced by produce().

bool ElectronLikelihoodESSource::m_splitSignalPdfs
private

Definition at line 65 of file ElectronLikelihoodESSource.h.

Referenced by produce().