L1aInfo

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

//---------------------------------------------------------------------------
//!  \class L1aInfo
//!  \brief Class to contain L1 accept history information from TCDS FED
//!
//!  \author Remi Mommsen - Fermilab
//---------------------------------------------------------------------------

#include <cstdint>
#include <ostream>

#include "DataFormats/TCDS/interface/TCDSRaw.h"

class L1aInfo {
public:
  L1aInfo();

  L1aInfo(const tcds::L1aInfo_v1&);

  L1aInfo(int16_t index, uint64_t orbitNr, uint16_t bxid, uint8_t eventtype) {
    index_ = index;
    orbitNr_ = orbitNr;
    bxid_ = bxid;
    eventType_ = eventtype;
  };

  // The history index, where -1 means the previous L1 accept, -2 the one before that, etc.
  int16_t getIndex() const { return index_; }

  // The orbit number when the L1 accept occured
  uint64_t getOrbitNr() const { return orbitNr_; }

  // The bunch-crossing counter for the L1 accept
  uint16_t getBXID() const { return bxid_; }

  // The event type of the L1 accept corresponding to edm::EventAuxiliary::ExperimentType
  uint8_t getEventType() const { return eventType_; }

private:
  uint64_t orbitNr_;
  uint16_t bxid_;
  int16_t index_;
  uint8_t eventType_;
};

/// Pretty-print operator for L1aInfo
std::ostream& operator<<(std::ostream&, const L1aInfo&);

#endif  // DATAFORMATS_TCDS_L1AINFO_H