Go to the documentation of this file. 1 #ifndef RecoParticleFlow_PFClusterProducer_PFHcalRecHitCreator_h
2 #define RecoParticleFlow_PFClusterProducer_PFHcalRecHitCreator_h
21 template <
typename Digi,
typename Geometry, PFLayer::Layer Layer,
int Detector>
31 std::unique_ptr<reco::PFRecHitCollection>& cleaned,
43 const Geometry* hcalGeo = dynamic_cast<const Geometry*>(gTmp);
47 for (
const auto& erh : *recHitHandle) {
56 detid = theHcalTopology->
idFront(detid);
59 auto energy = erh.energy();
60 auto time = erh.time();
63 auto thisCell = hcalGeo->getGeometry(detid);
68 <<
"warning detid " << detid.
rawId() <<
" not found in geometry" << std::endl;
76 bool rcleaned =
false;
81 if (!qtest->test(rh, erh, rcleaned)) {
PFHcalRecHitCreator< HORecHit, CaloSubdetectorGeometry, PFLayer::HCAL_BARREL2, HcalOuter > PFHORecHitCreator
T const * product() const
HcalDetId idFront(const HcalDetId &id) const
void beginEvent(const edm::Event &event, const edm::EventSetup &setup)
PFHcalRecHitCreator(const edm::ParameterSet &iConfig, edm::ConsumesCollector &cc)
const CaloSubdetectorGeometry * getSubdetectorGeometry(const DetId &id) const
access the subdetector geometry for the given subdetector directly
constexpr int depth() const
get the tower depth
bool getMergePositionFlag() const
SeedingLayerSetsHits::SeedingLayer Layer
std::vector< std::unique_ptr< PFRecHitQTestBase > > qualityTests_
PFHcalRecHitCreator< HBHERecHit, CaloSubdetectorGeometry, PFLayer::HCAL_BARREL1, HcalBarrel > PFHBRecHitCreator
PFHcalRecHitCreator< HFRecHit, CaloSubdetectorGeometry, PFLayer::HF_EM, HcalForward > PFHFEMRecHitCreator
edm::ESGetToken< HcalTopology, HcalRecNumberingRecord > topoToken_
PFHcalRecHitCreator< HFRecHit, CaloSubdetectorGeometry, PFLayer::HF_HAD, HcalForward > PFHFHADRecHitCreator
constexpr int subdetId() const
get the contents of the subdetector field (not cast into any detector's numbering enum)
ESHandle< T > getHandle(const ESGetToken< T, R > &iToken) const
Log< level::Error, false > LogError
PFHcalRecHitCreator< HBHERecHit, CaloSubdetectorGeometry, PFLayer::HCAL_ENDCAP, HcalEndcap > PFHERecHitCreator
edm::EDGetTokenT< edm::SortedCollection< Digi > > recHitToken_
void importRecHits(std::unique_ptr< reco::PFRecHitCollection > &out, std::unique_ptr< reco::PFRecHitCollection > &cleaned, const edm::Event &iEvent, const edm::EventSetup &iSetup) override
constexpr uint32_t rawId() const
get the raw id
Particle flow rechit (rechit + geometry and topology information). See clustering algorithm in PFClus...
edm::ESGetToken< CaloGeometry, CaloGeometryRecord > geomToken_
void setTime(double time)
Class Geometry Contains vector for fit parameters (mean, sigma, etc.) obtained from multiple IOVs See...