CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
TkTransientTrackingRecHitBuilderESProducer.cc
Go to the documentation of this file.
5 
6 
11 
12 #include <string>
13 #include <memory>
14 
16 
17 using namespace edm;
18 
20 {
21  std::string myname = p.getParameter<std::string>("ComponentName");
22  pset_ = p;
23  setWhatProduced(this,myname);
24 }
25 
27 
28 boost::shared_ptr<TransientTrackingRecHitBuilder>
30 // if (_propagator){
31 // delete _propagator;
32 // _propagator = 0;
33 // }
34 
35  std::string sname = pset_.getParameter<std::string>("StripCPE");
36  std::string pname = pset_.getParameter<std::string>("PixelCPE");
37  std::string mname = pset_.getParameter<std::string>("Matcher");
38 
44  const SiStripRecHitMatcher * mp ;
45 
46  if (sname == "Fake") {
47  sp = 0;
48  }else{
49  iRecord.getRecord<TkStripCPERecord>().get( sname, se );
50  sp = se.product();
51  }
52 
53  if (pname == "Fake") {
54  pp = 0;
55  }else{
56  iRecord.getRecord<TkPixelCPERecord>().get( pname, pe );
57  pp = pe.product();
58  }
59 
60  if (mname == "Fake") {
61  mp = 0;
62  }else{
63  iRecord.getRecord<TkStripCPERecord>().get( mname, me );
64  mp = me.product();
65  }
66 
67  bool computeCoarseLocalPositionFromDisk = pset_.getParameter<bool>("ComputeCoarseLocalPositionFromDisk");
68  if (computeCoarseLocalPositionFromDisk)
69  edm::LogWarning("TkTransientTrackingRecHitBuilderESProducer")<<" The tracking rec hit positions and errors are not a persistent in data formats.\n"
70  <<" They are not available from disk.\n"
71  <<" However, TkTransientTrackingRecHitBuilderESProducer::ComputeCoarseLocalPositionFromDisk=True \n"
72  <<" will make the coarse estimation of this position/error available without track refit.\n"
73  <<" Position/error obtained from rechit with already defined position/error are not recomputed.\n"
74  <<" Position/error obtained from track refit are precise.";
75 
77  iRecord.getRecord<TrackerDigiGeometryRecord>().get( pDD );
78 
79  _builder = boost::shared_ptr<TransientTrackingRecHitBuilder>(new TkTransientTrackingRecHitBuilder(pDD.product(), pp, sp, mp, computeCoarseLocalPositionFromDisk));
80  return _builder;
81 }
82 
83 
T getParameter(std::string const &) const
tuple pp
Definition: createTree.py:15
T const * product() const
Definition: ESHandle.h:62
boost::shared_ptr< TransientTrackingRecHitBuilder > produce(const TransientRecHitRecord &)