HGCalMultiCluster

Macros

Line Code
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37
#ifndef DataFormats_ParticleFlowReco_HGCalMultiCluster
#define DataFormats_ParticleFlowReco_HGCalMultiCluster

#include <vector>
#include <limits>

#include "DataFormats/Common/interface/PtrVector.h"
#include "DataFormats/EgammaReco/interface/BasicCluster.h"
#include "DataFormats/ParticleFlowReco/interface/PFCluster.h"

namespace reco {
  class HGCalMultiCluster : public reco::PFCluster {
  public:
    typedef edm::PtrVector<reco::BasicCluster>::const_iterator component_iterator;
    typedef edm::PtrVector<reco::BasicCluster> ClusterCollection;

    HGCalMultiCluster() : PFCluster() { this->setLayer(PFLayer::HGCAL); }

    HGCalMultiCluster(double energy, double x, double y, double z, ClusterCollection& thecls);

    void push_back(const edm::Ptr<reco::BasicCluster>& b) { myclusters.push_back(b); }

    const edm::PtrVector<reco::BasicCluster>& clusters() const { return myclusters; }

    unsigned int size() const { return myclusters.size(); }
    component_iterator begin() const { return myclusters.begin(); }
    component_iterator end() const { return myclusters.end(); }

    bool operator>(const HGCalMultiCluster& rhs) const { return (energy() > rhs.energy()); }

  private:
    edm::PtrVector<reco::BasicCluster> myclusters;
  };

  typedef std::vector<HGCalMultiCluster> HGCalMultiClusterCollection;
}  // namespace reco
#endif