|
|
Go to the documentation of this file. 1 #ifndef RecoParticleFlow_PFClusterProducer_PFHGCalRecHitCreator_h
2 #define RecoParticleFlow_PFClusterProducer_PFHGCalRecHitCreator_h
25 template <
typename DET, PFLayer::Layer Layer, DetId::Detector det,
unsigned subdet>
35 std::unique_ptr<reco::PFRecHitCollection>& cleaned,
52 unsigned skipped_rechits = 0;
53 for (
const auto& hgrh :
rechits) {
54 const DET detid(hgrh.detid());
56 if (det != detid.det()
or (subdet != 0 and subdet != detid.subdetId())) {
58 <<
"det expected: " << det <<
" det gotten: " << detid.det() <<
" ; "
59 <<
"subdet expected: " << subdet <<
" subdet gotten: " << detid.subdetId() << std::endl;
62 double energy = hgrh.energy();
63 double time = hgrh.time();
65 auto thisCell =
geom->getSubdetectorGeometry(det, subdet)->getGeometry(detid);
69 LogDebug(
"PFHGCalRecHitCreator") <<
"warning detid " << detid.rawId() <<
" not found in geometry" << std::endl;
76 bool rcleaned =
false;
90 cleaned->push_back(rh);
92 edm::LogInfo(
"HGCalRecHitCreator") <<
"Skipped " << skipped_rechits <<
" out of " <<
rechits.size() <<
" rechits!"
94 edm::LogInfo(
"HGCalRecHitCreator") <<
"Created " <<
out->size() <<
" PFRecHits!" << std::endl;
T const * product() const
PFHGCalRecHitCreator< HGCSiliconDetId, PFLayer::HGCAL, DetId::HGCalHSi, ForwardEmpty > PFHGCalHSiRecHitCreator
edm::ESGetToken< CaloGeometry, CaloGeometryRecord > geomToken_
hgcal::RecHitTools recHitTools_
PFHGCalRecHitCreator< HcalDetId, PFLayer::HGCAL, DetId::Hcal, HcalEndcap > PFHGCHEBRecHitCreator
std::string geometryInstance_
PFHGCalRecHitCreator(const edm::ParameterSet &iConfig, edm::ConsumesCollector &cc)
PFHGCalRecHitCreator< HGCalDetId, PFLayer::HGCAL, DetId::Forward, HGCEE > PFHGCEERecHitCreator
Log< level::Info, false > LogInfo
SeedingLayerSetsHits::SeedingLayer Layer
void importRecHits(std::unique_ptr< reco::PFRecHitCollection > &out, std::unique_ptr< reco::PFRecHitCollection > &cleaned, const edm::Event &iEvent, const edm::EventSetup &iSetup) override
std::vector< std::unique_ptr< PFRecHitQTestBase > > qualityTests_
PFHGCalRecHitCreator< HGCalDetId, PFLayer::HGCAL, DetId::Forward, HGCHEF > PFHGCHEFRecHitCreator
PFHGCalRecHitCreator< HGCScintillatorDetId, PFLayer::HGCAL, DetId::HGCalHSc, ForwardEmpty > PFHGCalHScRecHitCreator
ESHandle< T > getHandle(const ESGetToken< T, R > &iToken) const
The Signals That Services Can Subscribe To This is based on ActivityRegistry and is current per Services can connect to the signals distributed by the ActivityRegistry in order to monitor the activity of the application Each possible callback has some defined which we here list in angle e< void, edm::EventID const &, edm::Timestamp const & > We also list in braces which AR_WATCH_USING_METHOD_ is used for those or
PFHGCalRecHitCreator< HGCSiliconDetId, PFLayer::HGCAL, DetId::HGCalEE, ForwardEmpty > PFHGCalEERecHitCreator
Particle flow rechit (rechit + geometry and topology information). See clustering algorithm in PFClus...
edm::EDGetTokenT< HGCRecHitCollection > recHitToken_