JetFlavour

Leptons

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 38 39 40 41 42 43 44 45 46 47 48 49 50
#ifndef DataFormats_JetMatching_JetFlavour_H
#define DataFormats_JetMatching_JetFlavour_H

#include <vector>
#include "DataFormats/Math/interface/Point3D.h"
#include "DataFormats/Math/interface/LorentzVector.h"

namespace reco {
  /**
 * JetFlavour class is meant to be used when the genEvent is dropped.
 * It can store by value the matching information about flavour and parton kinematics
 * The flavour definition and the corresponding parton information should be configured
 * in the producer.
 * The typedefs are taken from reco::Particle
 * */
  class JetFlavour {
  public:
    /// Lorentz vector
    typedef math::XYZTLorentzVector LorentzVector;
    /// point in the space
    typedef math::XYZPoint Point;
    /// lepton info struct
    struct Leptons {
      int electron;
      int muon;
      int tau;

      Leptons() : electron(0), muon(0), tau(0) {}
    };

    JetFlavour(void) {}
    JetFlavour(const LorentzVector& lv, const Point& pt, int fl, const Leptons& le)
        : m_partonMomentum(lv), m_partonVertex(pt), m_flavour(fl), m_leptons(le) {}
    JetFlavour(const LorentzVector& lv, const Point& pt, int fl)
        : m_partonMomentum(lv), m_partonVertex(pt), m_flavour(fl) {}

    const LorentzVector getLorentzVector() const { return m_partonMomentum; }
    const Point getPartonVertex() const { return m_partonVertex; }
    const int getFlavour() const { return m_flavour; }
    const Leptons getLeptons() const { return m_leptons; }

  private:
    LorentzVector m_partonMomentum;
    Point m_partonVertex;  // is it needed?
    int m_flavour;
    Leptons m_leptons;
  };

}  // namespace reco
#endif