1 |
#include "RecoTracker/TransientTrackingRecHit/plugins/TkTransientTrackingRecHitBuilderESProducer.h"
|
2 |
#include "RecoTracker/TransientTrackingRecHit/interface/TkTransientTrackingRecHitBuilder.h"
|
3 |
#include "MagneticField/Engine/interface/MagneticField.h"
|
4 |
#include "Geometry/Records/interface/TrackerDigiGeometryRecord.h"
|
5 |
|
6 |
|
7 |
#include "FWCore/Framework/interface/EventSetup.h"
|
8 |
#include "FWCore/Framework/interface/ESHandle.h"
|
9 |
#include "FWCore/Framework/interface/ModuleFactory.h"
|
10 |
#include "FWCore/Framework/interface/ESProducer.h"
|
11 |
|
12 |
#include <string>
|
13 |
#include <memory>
|
14 |
|
15 |
#include "FWCore/MessageLogger/interface/MessageLogger.h"
|
16 |
|
17 |
using namespace edm;
|
18 |
|
19 |
TkTransientTrackingRecHitBuilderESProducer::TkTransientTrackingRecHitBuilderESProducer(const edm::ParameterSet & p)
|
20 |
{
|
21 |
std::string myname = p.getParameter<std::string>("ComponentName");
|
22 |
pset_ = p;
|
23 |
setWhatProduced(this,myname);
|
24 |
}
|
25 |
|
26 |
TkTransientTrackingRecHitBuilderESProducer::~TkTransientTrackingRecHitBuilderESProducer() {}
|
27 |
|
28 |
boost::shared_ptr<TransientTrackingRecHitBuilder>
|
29 |
TkTransientTrackingRecHitBuilderESProducer::produce(const TransientRecHitRecord & iRecord){
|
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 |
|
39 |
edm::ESHandle<StripClusterParameterEstimator> se;
|
40 |
edm::ESHandle<PixelClusterParameterEstimator> pe;
|
41 |
edm::ESHandle<SiStripRecHitMatcher> me;
|
42 |
const StripClusterParameterEstimator * sp ;
|
43 |
const PixelClusterParameterEstimator * pp ;
|
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 |
|
76 |
edm::ESHandle<TrackerGeometry> pDD;
|
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 |
|