CMS 3D CMS Logo

StripCPEESProducer.cc
Go to the documentation of this file.
13 
15 {
16  std::string name = p.getParameter<std::string>("ComponentName");
18  if (!p.exists("ComponentType"))
19  edm::LogWarning("StripCPEESProducer")<<" the CPE producer should contain a ComponentType, probably identical to ComponentName in the first step of migration. Falling back to:"<<type;
20  else
21  type=p.getParameter<std::string>("ComponentType");
22 
23  enumMap[std::string("SimpleStripCPE")]=SIMPLE;
24  enumMap[std::string("StripCPEfromTrackAngle")]=TRACKANGLE;
25  enumMap[std::string("StripCPEgeometric")]=GEOMETRIC;
26  enumMap[std::string("StripCPEfromTemplate")]=TEMPLATE;
27  if(enumMap.find(type)==enumMap.end())
28  throw cms::Exception("Unknown StripCPE type") << type;
29 
30  cpeNum = enumMap[type];
31  parametersPSet = (p.exists("parameters") ? p.getParameter<edm::ParameterSet>("parameters") : p);
32  setWhatProduced(this,name);
33 }
34 
35 std::shared_ptr<StripClusterParameterEstimator> StripCPEESProducer::
36 produce(const TkStripCPERecord & iRecord)
37 {
39  edm::ESHandle<MagneticField> magfield; iRecord.getRecord<IdealMagneticFieldRecord>().get(magfield );
40  edm::ESHandle<SiStripLorentzAngle> lorentzAngle; iRecord.getRecord<SiStripLorentzAngleDepRcd>().get(lorentzAngle);
41  edm::ESHandle<SiStripBackPlaneCorrection> backPlaneCorrection; iRecord.getRecord<SiStripBackPlaneCorrectionDepRcd>().get(backPlaneCorrection);
42  edm::ESHandle<SiStripConfObject> confObj; iRecord.getRecord<SiStripConfObjectRcd>().get(confObj);
44  edm::ESHandle<SiStripNoises> noise; iRecord.getRecord<SiStripNoisesRcd>().get(noise);
47 
48 
49  switch(cpeNum) {
50 
51  case SIMPLE:
52  cpe = std::make_shared<StripCPE>( parametersPSet, *magfield, *pDD, *lorentzAngle, *backPlaneCorrection, *confObj, *latency );
53  break;
54 
55  case TRACKANGLE:
56  cpe = std::make_shared<StripCPEfromTrackAngle>( parametersPSet, *magfield, *pDD, *lorentzAngle, *backPlaneCorrection, *confObj, *latency );
57  break;
58 
59  case GEOMETRIC:
60  cpe = std::make_shared<StripCPEgeometric>(parametersPSet, *magfield, *pDD, *lorentzAngle, *backPlaneCorrection, *confObj, *latency );
61  break;
62 
63  case TEMPLATE:
64  cpe = std::make_shared<StripCPEfromTemplate>( parametersPSet, *magfield, *pDD, *lorentzAngle, *backPlaneCorrection, *confObj, *latency );
65  break;
66 
67  }
68 
69  return cpe;
70 }
type
Definition: HCALResponse.h:21
T getParameter(std::string const &) const
std::shared_ptr< StripClusterParameterEstimator > produce(const TkStripCPERecord &)
edm::ParameterSet parametersPSet
bool exists(std::string const &parameterName) const
checks if a parameter exists
std::shared_ptr< StripClusterParameterEstimator > cpe
void setWhatProduced(T *iThis, const es::Label &iLabel=es::Label())
Definition: ESProducer.h:115
std::map< std::string, CPE_t > enumMap
latency
hardware algo
StripCPEESProducer(const edm::ParameterSet &)