CMS 3D CMS Logo

List of all members | Public Member Functions | Static Public Member Functions | Private Attributes
PixelTrackReconstruction Class Reference

#include <PixelTrackReconstruction.h>

Public Member Functions

 PixelTrackReconstruction (const edm::ParameterSet &conf, edm::ConsumesCollector &&iC)
 
void run (pixeltrackfitting::TracksWithTTRHs &tah, edm::Event &ev, const edm::EventSetup &es)
 
 ~PixelTrackReconstruction ()
 

Static Public Member Functions

static void fillDescriptions (edm::ParameterSetDescription &desc)
 

Private Attributes

std::string theCleanerName
 
edm::EDGetTokenT< PixelTrackFiltertheFilterToken
 
edm::EDGetTokenT< PixelFittertheFitterToken
 
edm::EDGetTokenT< RegionsSeedingHitSetstheHitSetsToken
 

Detailed Description

Definition at line 19 of file PixelTrackReconstruction.h.

Constructor & Destructor Documentation

PixelTrackReconstruction::PixelTrackReconstruction ( const edm::ParameterSet conf,
edm::ConsumesCollector &&  iC 
)

Definition at line 23 of file PixelTrackReconstruction.cc.

References edm::ParameterSet::getParameter(), edm::InputTag::label(), and theFilterToken.

25  : theHitSetsToken(iC.consumes<RegionsSeedingHitSets>(cfg.getParameter<edm::InputTag>("SeedingHitSets"))),
26  theFitterToken(iC.consumes<PixelFitter>(cfg.getParameter<edm::InputTag>("Fitter"))),
27  theCleanerName(cfg.getParameter<std::string>("Cleaner"))
28 {
29  edm::InputTag filterTag = cfg.getParameter<edm::InputTag>("Filter");
30  if (not filterTag.label().empty()) {
31  theFilterToken = iC.consumes<PixelTrackFilter>(filterTag);
32  }
33 }
EDGetTokenT< ProductType > consumes(edm::InputTag const &tag)
edm::EDGetTokenT< PixelTrackFilter > theFilterToken
std::string const & label() const
Definition: InputTag.h:36
edm::EDGetTokenT< RegionsSeedingHitSets > theHitSetsToken
edm::EDGetTokenT< PixelFitter > theFitterToken
PixelTrackReconstruction::~PixelTrackReconstruction ( )

Definition at line 35 of file PixelTrackReconstruction.cc.

36 {
37 }

Member Function Documentation

void PixelTrackReconstruction::fillDescriptions ( edm::ParameterSetDescription desc)
static

Definition at line 39 of file PixelTrackReconstruction.cc.

References edm::ParameterSetDescription::add(), and AlCaHLTBitMon_QueryRunRegistry::string.

Referenced by PixelTrackProducer::fillDescriptions().

39  {
40  desc.add<edm::InputTag>("SeedingHitSets", edm::InputTag("pixelTracksHitTriplets"));
41  desc.add<edm::InputTag>("Fitter", edm::InputTag("pixelFitterByHelixProjections"));
42  desc.add<edm::InputTag>("Filter", edm::InputTag("pixelTrackFilterByKinematics"));
43  desc.add<std::string>("Cleaner", "pixelTrackCleanerBySharedHits");
44 }
ParameterDescriptionBase * add(U const &iLabel, T const &value)
void PixelTrackReconstruction::run ( pixeltrackfitting::TracksWithTTRHs tah,
edm::Event ev,
const edm::EventSetup es 
)

FIXME at some point we need to migrate the fitter...

Definition at line 46 of file PixelTrackReconstruction.cc.

References PixelTrackCleanerWrapper::clean(), ALCARECOTkAlBeamHalo_cff::filter, edm::EventSetup::get(), edm::Event::getByToken(), hfClusterShapes_cfi::hits, edm::EDGetTokenT< T >::isUninitialized(), edm::Handle< T >::product(), theCleanerName, theFilterToken, theFitterToken, theHitSetsToken, and HiIsolationCommonParameters_cff::track.

Referenced by PixelTrackProducer::produce().

47 {
49  ev.getByToken(theHitSetsToken, hhitSets);
50  const auto& hitSets = *hhitSets;
51 
53  ev.getByToken(theFitterToken, hfitter);
54  const auto& fitter = *hfitter;
55 
56  const PixelTrackFilter *filter = nullptr;
59  ev.getByToken(theFilterToken, hfilter);
60  filter = hfilter.product();
61  }
62 
63  std::vector<const TrackingRecHit *> hits;hits.reserve(4);
64  for(const auto& regionHitSets: hitSets) {
65  const TrackingRegion& region = regionHitSets.region();
66 
67  for(const SeedingHitSet& tuplet: regionHitSets) {
69  auto nHits = tuplet.size(); hits.resize(nHits);
70  for (unsigned int iHit = 0; iHit < nHits; ++iHit) hits[iHit] = tuplet[iHit];
71 
72  // fitting
73  std::unique_ptr<reco::Track> track = fitter.run(hits, region, es);
74  if (!track) continue;
75 
76  if (filter) {
77  if (!(*filter)(track.get(), hits)) {
78  continue;
79  }
80  }
81 
82  // add tracks
83  tracks.emplace_back(track.release(), tuplet);
84  }
85  }
86 
87  // skip ovelrapped tracks
88  if(!theCleanerName.empty()) {
90  es.get<PixelTrackCleaner::Record>().get(theCleanerName, hcleaner);
91  const auto& cleaner = *hcleaner;
92  if(cleaner.fast())
93  cleaner.cleanTracks(tracks);
94  else
96  }
97 }
bool getByToken(EDGetToken token, Handle< PROD > &result) const
Definition: Event.h:517
pixeltrackfitting::TracksWithTTRHs clean(const pixeltrackfitting::TracksWithTTRHs &initialT_TTRHs) const
edm::EDGetTokenT< PixelTrackFilter > theFilterToken
T const * product() const
Definition: Handle.h:74
T get() const
Definition: EventSetup.h:71
bool isUninitialized() const
Definition: EDGetToken.h:70
edm::EDGetTokenT< RegionsSeedingHitSets > theHitSetsToken
edm::EDGetTokenT< PixelFitter > theFitterToken

Member Data Documentation

std::string PixelTrackReconstruction::theCleanerName
private

Definition at line 34 of file PixelTrackReconstruction.h.

Referenced by run().

edm::EDGetTokenT<PixelTrackFilter> PixelTrackReconstruction::theFilterToken
private

Definition at line 33 of file PixelTrackReconstruction.h.

Referenced by PixelTrackReconstruction(), and run().

edm::EDGetTokenT<PixelFitter> PixelTrackReconstruction::theFitterToken
private

Definition at line 32 of file PixelTrackReconstruction.h.

Referenced by run().

edm::EDGetTokenT<RegionsSeedingHitSets> PixelTrackReconstruction::theHitSetsToken
private

Definition at line 31 of file PixelTrackReconstruction.h.

Referenced by run().