CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
PixelTracksProducer.cc
Go to the documentation of this file.
1 #include <memory>
3 
7 
10 
13 
14 //Pixel Specific stuff
17 
20 
25 
30 #include <vector>
31 
32 using namespace pixeltrackfitting;
33 
35  theFitter(0),
36  theFilter(0),
37  theRegionProducer(0)
38 {
39 
40  produces<reco::TrackCollection>();
41  produces<TrackingRecHitCollection>();
42  produces<reco::TrackExtraCollection>();
43 
44  const edm::ParameterSet& regfactoryPSet = conf.getParameter<edm::ParameterSet>("RegionFactoryPSet");
45  std::string regfactoryName = regfactoryPSet.getParameter<std::string>("ComponentName");
46  theRegionProducer = TrackingRegionProducerFactory::get()->create(regfactoryName,
47  regfactoryPSet, consumesCollector());
48 
49  const edm::ParameterSet& fitterPSet = conf.getParameter<edm::ParameterSet>("FitterPSet");
50  std::string fitterName = fitterPSet.getParameter<std::string>("ComponentName");
51  theFitter = PixelFitterFactory::get()->create( fitterName, fitterPSet);
52 
54  const edm::ParameterSet& filterPSet = conf.getParameter<edm::ParameterSet>("FilterPSet");
55  std::string filterName = filterPSet.getParameter<std::string>("ComponentName");
56  theFilter = PixelTrackFilterFactory::get()->create( filterName, filterPSet, iC);
57 
58  // The name of the seed producer
59  seedProducer = conf.getParameter<edm::InputTag>("SeedProducer");
60 
61 }
62 
63 
64 // Virtual destructor needed.
66 
67  delete theFilter;
68  delete theFitter;
69  delete theRegionProducer;
70 
71 }
72 
73 
74 // Functions that gets called by framework every event
75 void
77 
78  std::auto_ptr<reco::TrackCollection> tracks(new reco::TrackCollection);
79  std::auto_ptr<TrackingRecHitCollection> recHits(new TrackingRecHitCollection);
80  std::auto_ptr<reco::TrackExtraCollection> trackExtras(new reco::TrackExtraCollection);
81  typedef std::vector<const TrackingRecHit *> RecHits;
82 
83  TracksWithRecHits pixeltracks;
84  TracksWithRecHits cleanedTracks;
85 
87  e.getByLabel(seedProducer,theSeeds);
88 
89  // No seed -> output an empty track collection
90  if(theSeeds->size() == 0) {
91  e.put(tracks);
92  e.put(recHits);
93  e.put(trackExtras);
94  return;
95  }
96 
97  //only one region Global, but it is called at every event...
98  //maybe there is a smarter way to set it only once
99  //NEED TO FIX
100  typedef std::vector<TrackingRegion* > Regions;
101  typedef Regions::const_iterator IR;
102  Regions regions = theRegionProducer->regions(e,es);
103  for (IR ir=regions.begin(), irEnd=regions.end(); ir < irEnd; ++ir) {
104  const TrackingRegion & region = **ir;
105 
106  // Loop over the seeds
107  TrajectorySeedCollection::const_iterator aSeed = theSeeds->begin();
108  TrajectorySeedCollection::const_iterator lastSeed = theSeeds->end();
109  for ( ; aSeed!=lastSeed; ++aSeed ) {
110 
111  // Find the first hit and last hit of the Seed
112  TrajectorySeed::range theSeedingRecHitRange = aSeed->recHits();
113  edm::OwnVector<TrackingRecHit>::const_iterator aSeedingRecHit = theSeedingRecHitRange.first;
114  edm::OwnVector<TrackingRecHit>::const_iterator theLastSeedingRecHit = theSeedingRecHitRange.second;
115 
116  // Loop over the rechits
117  std::vector<const TrackingRecHit*> TripletHits(3,static_cast<const TrackingRecHit*>(0));
118  for ( unsigned i=0; aSeedingRecHit!=theLastSeedingRecHit; ++i,++aSeedingRecHit )
119  TripletHits[i] = &(*aSeedingRecHit);
120 
121  // fitting the triplet
122  reco::Track* track = theFitter->run(es, TripletHits, region);
123 
124  // decide if track should be skipped according to filter
125  if ( ! (*theFilter)(track) ) {
126  delete track;
127  continue;
128  }
129 
130  // add tracks
131  pixeltracks.push_back(TrackWithRecHits(track, TripletHits));
132 
133  }
134  }
135 
136  int cc=0;
137  int nTracks = pixeltracks.size();
138  for (int i = 0; i < nTracks; ++i) {
139 
140  reco::Track* track = pixeltracks.at(i).first;
141  const RecHits & hits = pixeltracks.at(i).second;
142 
143  for (unsigned int k = 0; k < hits.size(); k++) {
144  TrackingRecHit *hit = (hits.at(k))->clone();
145  track->setHitPattern(*hit, k);
146  recHits->push_back(hit);
147  }
148 
149  tracks->push_back(*track);
150  delete track;
151 
152  }
153 
155 
156  for (int k = 0; k < nTracks; ++k) {
157 
158  // reco::TrackExtra* theTrackExtra = new reco::TrackExtra();
159  reco::TrackExtra theTrackExtra;
160 
161  //fill the TrackExtra with TrackingRecHitRef
162  // unsigned int nHits = tracks->at(k).numberOfValidHits();
163  unsigned nHits = 3; // We are dealing with triplets!
164  for(unsigned int i = 0; i < nHits; ++i) {
165  theTrackExtra.add(TrackingRecHitRef(ohRH,cc++));
166  //theTrackExtra->add(TrackingRecHitRef(ohRH,cc));
167  //cc++;
168  }
169 
170  trackExtras->push_back(theTrackExtra);
171  //trackExtras->push_back(*theTrackExtra);
172  //delete theTrackExtra;
173  }
174 
176 
177  for (int k = 0; k < nTracks; k++) {
178 
179  const reco::TrackExtraRef theTrackExtraRef(ohTE,k);
180  (tracks->at(k)).setExtra(theTrackExtraRef);
181 
182  }
183 
184  e.put(tracks);
185 
186  // Avoid a memory leak !
187  unsigned nRegions = regions.size();
188  for ( unsigned iRegions=0; iRegions<nRegions; ++iRegions ) {
189  delete regions[iRegions];
190  }
191 
192 }
193 
T getParameter(std::string const &) const
int i
Definition: DBlmapReader.cc:9
edm::InputTag seedProducer
PixelTracksProducer(const edm::ParameterSet &conf)
virtual reco::Track * run(const edm::EventSetup &es, const std::vector< const TrackingRecHit * > &hits, const TrackingRegion &region) const
Definition: PixelFitter.h:17
std::vector< Track > TrackCollection
collection of Tracks
Definition: TrackFwd.h:10
virtual void produce(edm::Event &ev, const edm::EventSetup &es)
TrackingRegionProducer * theRegionProducer
OrphanHandle< PROD > put(std::auto_ptr< PROD > product)
Put a new product.
Definition: Event.h:116
edm::Ref< TrackingRecHitCollection > TrackingRecHitRef
persistent reference to a TrackingRecHit
ConsumesCollector consumesCollector()
Use a ConsumesCollector to gather consumes information from helper functions.
const PixelTrackFilter * theFilter
std::pair< const_iterator, const_iterator > range
bool getByLabel(InputTag const &tag, Handle< PROD > &result) const
Definition: Event.h:390
std::pair< reco::Track *, std::vector< const TrackingRecHit * > > TrackWithRecHits
tuple conf
Definition: dbtoconf.py:185
int k[5][pyjets_maxn]
void setHitPattern(const C &c)
set hit patterns from vector of hit references
Definition: TrackBase.h:244
std::vector< TrackExtra > TrackExtraCollection
collection of TrackExtra objects
Definition: TrackExtraFwd.h:9
tuple tracks
Definition: testEve_cfg.py:39
void add(const TrackingRecHitRef &r)
add a reference to a RecHit
const PixelFitter * theFitter
std::vector< TrackWithRecHits > TracksWithRecHits
tuple clone
Definition: statics.py:58
T get(const Candidate &c)
Definition: component.h:55
virtual std::vector< TrackingRegion * > regions(const edm::Event &ev, const edm::EventSetup &es) const =0