Multiplicity

MultiplicityPair

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 DPGAnalysis_SiStripTools_Multiplicities_H
#define DPGAnalysis_SiStripTools_Multiplicities_H

namespace sistriptools::values {
  class Multiplicity {
  public:
    explicit Multiplicity(int iMult) : m_mult{iMult} {}
    int mult() const { return m_mult; }

  private:
    int m_mult;
  };

  template <class T1, class T2>
  class MultiplicityPair {
  public:
    MultiplicityPair(T1 const& i1, T2 const& i2) : m_multiplicity1(i1), m_multiplicity2(i2) {}

    int mult1() const;
    int mult2() const;

  private:
    T1 m_multiplicity1;
    T2 m_multiplicity2;
  };

  template <class T1, class T2>
  int MultiplicityPair<T1, T2>::mult1() const {
    return m_multiplicity1.mult();
  }

  template <class T1, class T2>
  int MultiplicityPair<T1, T2>::mult2() const {
    return m_multiplicity2.mult();
  }
}  // namespace sistriptools::values
#endif  // DPGAnalysis_SiStripTools_Multiplicities_H