File indexing completed on 2024-04-06 12:25:47
0001 #ifndef RecoLocalCalo_HcalRecAlgos_SimplePlan1RechitCombiner_h_
0002 #define RecoLocalCalo_HcalRecAlgos_SimplePlan1RechitCombiner_h_
0003
0004
0005 #include "RecoLocalCalo/HcalRecAlgos/interface/AbsPlan1RechitCombiner.h"
0006
0007 class SimplePlan1RechitCombiner : public AbsPlan1RechitCombiner {
0008 public:
0009 SimplePlan1RechitCombiner();
0010
0011 inline ~SimplePlan1RechitCombiner() override {}
0012
0013 void setTopo(const HcalTopology* topo) override;
0014 void clear() override;
0015 void add(const HBHERecHit& rh) override;
0016 void combine(HBHERecHitCollection* toFill) override;
0017
0018 protected:
0019
0020 virtual HcalDetId mapRechit(HcalDetId from) const;
0021
0022
0023 virtual HBHERecHit makeRechit(HcalDetId idToMake, const std::vector<const HBHERecHit*>& rechits) const;
0024
0025
0026 virtual void combineAuxInfo(const std::vector<const HBHERecHit*>& rechits, HBHERecHit* rh) const;
0027
0028 const HcalTopology* topo_;
0029
0030 private:
0031
0032
0033 typedef std::pair<HcalDetId, const HBHERecHit*> MapItem;
0034
0035 std::vector<MapItem> rechitMap_;
0036 std::vector<const HBHERecHit*> ptrbuf_;
0037 };
0038
0039 #endif