CMS 3D CMS Logo

PFRecHitDualNavigator.h
Go to the documentation of this file.
1 #ifndef RecoParticleFlow_PFClusterProducer_PFRecHitDualNavigator_h
2 #define RecoParticleFlow_PFClusterProducer_PFRecHitDualNavigator_h
3 
7 
8 template <PFLayer::Layer D1, typename barrel, PFLayer::Layer D2, typename endcap>
10 public:
11  PFRecHitDualNavigator() = default;
12 
14  barrelNav_ = new barrel(iConfig.getParameter<edm::ParameterSet>("barrel"), cc);
15  endcapNav_ = new endcap(iConfig.getParameter<edm::ParameterSet>("endcap"), cc);
16  }
17 
18  void init(const edm::EventSetup& iSetup) override {
19  barrelNav_->init(iSetup);
20  endcapNav_->init(iSetup);
21  }
22 
24  std::unique_ptr<reco::PFRecHitCollection>& hits,
25  edm::RefProd<reco::PFRecHitCollection>& refProd) override {
26  if (hit.layer() == D1)
27  barrelNav_->associateNeighbours(hit, hits, refProd);
28  else if (hit.layer() == D2)
29  endcapNav_->associateNeighbours(hit, hits, refProd);
30  }
31 
32 protected:
35 };
36 
37 #endif
edm::RefProd
Definition: EDProductfwd.h:25
funct::D1
Divides< A, C > D1
Definition: Factorize.h:136
Reference_intrackfit_cff.barrel
list barrel
Definition: Reference_intrackfit_cff.py:37
hfClusterShapes_cfi.hits
hits
Definition: hfClusterShapes_cfi.py:5
funct::D2
Divides< B, C > D2
Definition: Factorize.h:137
makeMuonMisalignmentScenario.endcap
endcap
Definition: makeMuonMisalignmentScenario.py:320
PFRecHitDualNavigator::associateNeighbours
void associateNeighbours(reco::PFRecHit &hit, std::unique_ptr< reco::PFRecHitCollection > &hits, edm::RefProd< reco::PFRecHitCollection > &refProd) override
Definition: PFRecHitDualNavigator.h:23
PFRecHitDualNavigator
Definition: PFRecHitDualNavigator.h:9
PFRecHitNavigatorBase.h
PFLayer.h
PFRecHitDualNavigator::PFRecHitDualNavigator
PFRecHitDualNavigator()=default
PFRecHitDualNavigator::init
void init(const edm::EventSetup &iSetup) override
Definition: PFRecHitDualNavigator.h:18
PFRecHitDualNavigator::barrelNav_
barrel * barrelNav_
Definition: PFRecHitDualNavigator.h:33
edm::ParameterSet
Definition: ParameterSet.h:47
PFRecHitNavigatorBase
Definition: PFRecHitNavigatorBase.h:25
PFRecHitDualNavigator::PFRecHitDualNavigator
PFRecHitDualNavigator(const edm::ParameterSet &iConfig, edm::ConsumesCollector &cc)
Definition: PFRecHitDualNavigator.h:13
PFRecHitDualNavigator::endcapNav_
endcap * endcapNav_
Definition: PFRecHitDualNavigator.h:34
edm::EventSetup
Definition: EventSetup.h:58
cc
edm::ParameterSet::getParameter
T getParameter(std::string const &) const
Definition: ParameterSet.h:303
reco::PFRecHit
Particle flow rechit (rechit + geometry and topology information). See clustering algorithm in PFClus...
Definition: PFRecHit.h:31
ConsumesCollector.h
edm::ConsumesCollector
Definition: ConsumesCollector.h:45
hit
Definition: SiStripHitEffFromCalibTree.cc:88