CMS 3D CMS Logo

List of all members | Public Types | Public Member Functions
EcalShowerContainmentCorrectionsESProducer Class Reference
Inheritance diagram for EcalShowerContainmentCorrectionsESProducer:
edm::ESProducer edm::ESProxyFactoryProducer edm::eventsetup::DataProxyProvider

Public Types

typedef std::unique_ptr< EcalShowerContainmentCorrectionsReturnType
 
- 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

 EcalShowerContainmentCorrectionsESProducer (const edm::ParameterSet &)
 
ReturnType produce (const EcalShowerContainmentCorrectionsRcd &)
 
 ~EcalShowerContainmentCorrectionsESProducer ()
 
- Public Member Functions inherited from edm::ESProducer
 ESProducer ()
 
virtual ~ESProducer ()(false)
 
- Public Member Functions inherited from edm::ESProxyFactoryProducer
 ESProxyFactoryProducer ()
 
virtual void newInterval (const eventsetup::EventSetupRecordKey &iRecordType, const ValidityInterval &iInterval)
 overrides DataProxyProvider method More...
 
virtual ~ESProxyFactoryProducer () noexcept(false)
 
- 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)
 

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())
 
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

Description: Trivial ESProducer to provide EventSetup with (hard coded) shower containment corrections

Author
Stefano Argiro Created: Mon Mar 5 08:39:12 CET 2007

Definition at line 31 of file EcalShowerContainmentCorrectionsESProducer.cc.

Member Typedef Documentation

Constructor & Destructor Documentation

EcalShowerContainmentCorrectionsESProducer::EcalShowerContainmentCorrectionsESProducer ( const edm::ParameterSet iConfig)

Definition at line 46 of file EcalShowerContainmentCorrectionsESProducer.cc.

References edm::ESProducer::setWhatProduced().

47 {
48  setWhatProduced(this);
49 }
void setWhatProduced(T *iThis, const es::Label &iLabel=es::Label())
Definition: ESProducer.h:115
EcalShowerContainmentCorrectionsESProducer::~EcalShowerContainmentCorrectionsESProducer ( )

Definition at line 52 of file EcalShowerContainmentCorrectionsESProducer.cc.

52 { }

Member Function Documentation

EcalShowerContainmentCorrectionsESProducer::ReturnType EcalShowerContainmentCorrectionsESProducer::produce ( const EcalShowerContainmentCorrectionsRcd iRecord)

Definition at line 60 of file EcalShowerContainmentCorrectionsESProducer.cc.

References popcon2dropbox::copy(), EcalShowerContainmentCorrections::Coefficients::data, DEFINE_FWK_EVENTSETUP_MODULE, hcalTTPDigis_cfi::id, findQualityFiles::size, EBDetId::SMCRYSTALMODE, and MuonErrorMatrixValues_cff::values.

Referenced by JSONExport.JsonExport::export(), HTMLExport.HTMLExport::export(), and HTMLExport.HTMLExportStatic::export().

61 {
62 
63  using namespace edm::es;
64  using namespace std;
65 
66  auto pEcalShowerContainmentCorrections = std::make_unique<EcalShowerContainmentCorrections>();
67  int sm=1; // in testbeam data sw believes we always are on sm01
68 
69  // where is the n of xtals per sm coded ?
70  for (int xtal=1; xtal<=1700 ; ++xtal){
71 
72  // // from /afs/cern.ch/user/h/h4ecal/h4ana/data/gapCorrections/parametres_pol6_X204_2_1.out
73 
74  // corrections computed on module3 - (sm16, 1run)
75 
76  double values[] = { 0.998959, // 3x3 x right
77  0.00124547,
78  -0.000348259,
79  6.04065e-006,
80  0.999032, // 3x3 x left
81  7.90628e-005,
82  -0.000175699,
83  -2.60715e-007,
84  //
85  0.999983, // 3x3 y right
86  -0.000132085,
87  2.04773e-005,
88  -1.21629e-005,
89  1.00002, // 3x3 y left
90  0.00016518,
91  5.36343e-005,
92  1.32094e-005,
93  //
94  0.998944, // 5x5
95  0.00100987,
96  -0.000223207,
97  2.15615e-006,
98  0.999127,
99  0.000253437,
100  -9.80656e-005,
101  1.48651e-006,
102  1.00006,
103  -0.000179675,
104  8.15627e-005,
105  -1.21549e-005,
106  1.00022,
107  0.000363728,
108  0.000128066,
109  1.54473e-005 };
110 
111 
112 
113 
114  const size_t size = sizeof values / sizeof values[0];
116  std::copy(values,values+size,coeff.data);
117 
119 
120  // we are filling always the same group ...
121  pEcalShowerContainmentCorrections->fillCorrectionCoefficients(id,3,coeff);
122  }
123 
124  return pEcalShowerContainmentCorrections ;
125 }
size
Write out results.
Structure defining the container for correction coefficients.
static const int SMCRYSTALMODE
Definition: EBDetId.h:167