CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
List of all members | Public Member Functions | Public Attributes | Private Member Functions | Private Attributes
magneticfield::AutoMagneticFieldESProducer Class Reference

#include <AutoMagneticFieldESProducer.h>

Inheritance diagram for magneticfield::AutoMagneticFieldESProducer:
edm::ESProducer edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Public Member Functions

 AutoMagneticFieldESProducer (const edm::ParameterSet &)
 
std::auto_ptr< MagneticFieldproduce (const IdealMagneticFieldRecord &)
 
 ~AutoMagneticFieldESProducer ()
 
- Public Member Functions inherited from edm::ESProducer
 ESProducer ()
 
virtual ~ESProducer ()
 
- Public Member Functions inherited from edm::ESProxyFactoryProducer
 ESProxyFactoryProducer ()
 
virtual void newInterval (const eventsetup::EventSetupRecordKey &iRecordType, const ValidityInterval &iInterval)
 overrides DataProxyProvider method More...
 
virtual ~ESProxyFactoryProducer ()
 
- 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 ()
 

Public Attributes

edm::ParameterSet pset
 

Private Member Functions

std::string closerModel (float current)
 

Private Attributes

std::vector< std::string > maps
 
std::vector< int > nominalCurrents
 

Additional Inherited Members

- Public Types inherited from edm::eventsetup::DataProxyProvider
typedef std::vector< std::pair
< DataKey, boost::shared_ptr
< DataProxy > > > 
KeyedProxies
 
typedef std::vector
< EventSetupRecordKey
Keys
 
typedef std::map
< EventSetupRecordKey,
KeyedProxies
RecordProxies
 
- 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::auto_ptr< TFactory > iFactory, const std::string &iLabel=std::string())
 
virtual void registerFactoryWithKey (const eventsetup::EventSetupRecordKey &iRecord, std::auto_ptr< eventsetup::ProxyFactoryBase > &iFactory, const std::string &iLabel=std::string())
 
virtual void registerProxies (const eventsetup::EventSetupRecordKey &iRecord, KeyedProxies &aProxyList)
 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 &)
 

Detailed Description

Definition at line 24 of file AutoMagneticFieldESProducer.h.

Constructor & Destructor Documentation

AutoMagneticFieldESProducer::AutoMagneticFieldESProducer ( const edm::ParameterSet iConfig)

Definition at line 32 of file AutoMagneticFieldESProducer.cc.

References edm::hlt::Exception, edm::ParameterSet::getUntrackedParameter(), maps, nominalCurrents, pset, edm::ESProducer::setWhatProduced(), and AlCaHLTBitMon_QueryRunRegistry::string.

32  : pset(iConfig) {
34  nominalCurrents = pset.getUntrackedParameter<vector<int> >("nominalCurrents");
35  maps = pset.getUntrackedParameter<vector<string> >("mapLabels");
36 
37  if (maps.size()==0 || (maps.size() != nominalCurrents.size())) {
38  throw cms::Exception("InvalidParameter") << "Invalid values for parameters \"nominalCurrents\" and \"maps\"";
39  }
40 }
T getUntrackedParameter(std::string const &, T const &) const
void setWhatProduced(T *iThis, const es::Label &iLabel=es::Label())
Definition: ESProducer.h:115
AutoMagneticFieldESProducer::~AutoMagneticFieldESProducer ( )

Definition at line 43 of file AutoMagneticFieldESProducer.cc.

44 {
45 }

Member Function Documentation

std::string AutoMagneticFieldESProducer::closerModel ( float  current)
private

Definition at line 81 of file AutoMagneticFieldESProducer.cc.

References i, maps, and nominalCurrents.

Referenced by produce().

81  {
82  int i=0;
83  for(;i<(int)maps.size()-1;i++) {
84  if(2*current < nominalCurrents[i]+nominalCurrents[i+1] )
85  return maps[i];
86  }
87  return maps[i];
88 }
int i
Definition: DBlmapReader.cc:9
std::auto_ptr< MagneticField > AutoMagneticFieldESProducer::produce ( const IdealMagneticFieldRecord iRecord)

Definition at line 49 of file AutoMagneticFieldESProducer.cc.

References closerModel(), cond::rpcobimon::current, edm::eventsetup::EventSetupRecord::get(), edm::ParameterSet::getParameter(), edm::eventsetup::DependentRecordImplementation< RecordT, ListT >::getRecord(), Association::map, python.rootplot.argparse::message, edm::ESHandle< class >::product(), pset, query::result, and alignCSCRings::s.

50 {
51  float current = pset.getParameter<int>("valueOverride");
52 
53  string message;
54 
55  if (current < 0) {
56  ESHandle<RunInfo> rInfo;
57  iRecord.getRecord<RunInfoRcd>().get(rInfo);
58  current = rInfo->m_avg_current;
59  message = " (from RunInfo DB)";
60  } else {
61  message = " (from valueOverride card)";
62  }
63 
64  string model = closerModel(current);
65 
66  edm::LogInfo("MagneticField|AutoMagneticField") << "Current: " << current << message << "; using map with label: " << model;
67 
68 
70 
71  iRecord.get(model,map);
72 
73  MagneticField* result = map.product()->clone();
74 
75  std::auto_ptr<MagneticField> s(result);
76 
77  return s;
78 }
T getParameter(std::string const &) const
dictionary map
Definition: Association.py:205
tuple result
Definition: query.py:137
void get(HolderT &iHolder) const
T const * product() const
Definition: ESHandle.h:62

Member Data Documentation

std::vector<std::string> magneticfield::AutoMagneticFieldESProducer::maps
private

Definition at line 35 of file AutoMagneticFieldESProducer.h.

Referenced by AutoMagneticFieldESProducer(), and closerModel().

std::vector<int> magneticfield::AutoMagneticFieldESProducer::nominalCurrents
private

Definition at line 34 of file AutoMagneticFieldESProducer.h.

Referenced by AutoMagneticFieldESProducer(), and closerModel().

edm::ParameterSet magneticfield::AutoMagneticFieldESProducer::pset

Definition at line 31 of file AutoMagneticFieldESProducer.h.

Referenced by AutoMagneticFieldESProducer(), and produce().