GEMPadDigi

InValid

NumberPartitions

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 51 52 53 54 55
#ifndef DataFormats_GEMDigi_GEMPadDigi_h
#define DataFormats_GEMDigi_GEMPadDigi_h

/** \class GEMPadDigi
 *
 * Digi for GEM-CSC trigger pads
 *
 * \author Vadim Khotilovich
 *
 */

#include "DataFormats/MuonDetId/interface/GEMSubDetId.h"

#include <cstdint>
#include <iosfwd>

class GEMPadDigi {
public:
  enum InValid { ME0InValid = 255, GE11InValid = 255, GE21InValid = 511 };
  // Newer GE2/1 geometries will have 16 eta partitions
  // instead of the usual 8.
  enum NumberPartitions { ME0 = 8, GE11 = 8, GE21 = 8, GE21SplitStrip = 16 };

  explicit GEMPadDigi(uint16_t pad,
                      int16_t bx,
                      enum GEMSubDetId::Station station = GEMSubDetId::Station::GE11,
                      unsigned nPart = NumberPartitions::GE11);
  GEMPadDigi();

  bool operator==(const GEMPadDigi& digi) const;
  bool operator!=(const GEMPadDigi& digi) const;
  bool operator<(const GEMPadDigi& digi) const;
  // only depends on the "InValid" enum so it also
  // works on unpacked data
  bool isValid() const;

  // return the pad number. counts from 0.
  uint16_t pad() const { return pad_; }
  int16_t bx() const { return bx_; }
  GEMSubDetId::Station station() const { return station_; }

  unsigned nPartitions() const { return part_; }
  void print() const;

private:
  uint16_t pad_;
  int16_t bx_;
  GEMSubDetId::Station station_;
  // number of eta partitions
  unsigned part_;
};

std::ostream& operator<<(std::ostream& o, const GEMPadDigi& digi);

#endif