Vertex

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
#ifndef DataFormats_L1TVertex_Vertex_h
#define DataFormats_L1TVertex_Vertex_h

#include <vector>

#include "DataFormats/Common/interface/Ptr.h"
#include "DataFormats/L1TrackTrigger/interface/TTTrack.h"
#include "DataFormats/L1TrackTrigger/interface/TTTypes.h"

namespace l1t {

  class Vertex {
  public:
    typedef TTTrack<Ref_Phase2TrackerDigi_> Track_t;

    Vertex() : pt_(0.0), z0_(0.0) {}
    Vertex(float pt, float z0, const std::vector<edm::Ptr<Track_t>>& tracks) : pt_(pt), z0_(z0), tracks_(tracks) {}
    ~Vertex() {}

    float pt() const { return pt_; }
    float z0() const { return z0_; }

    const std::vector<edm::Ptr<Track_t>>& tracks() const { return tracks_; }

  private:
    float pt_;
    float z0_;
    std::vector<edm::Ptr<Track_t>> tracks_;
  };

  typedef std::vector<Vertex> VertexCollection;

}  // namespace l1t

#endif