CTPPSRecord

RomanPot

Status

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 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78
#ifndef DATAFORMATS_ONLINEMETADATA_CTPPSRECORD_H
#define DATAFORMATS_ONLINEMETADATA_CTPPSRECORD_H

//---------------------------------------------------------------------------
//!  \class CTPPSRecord
//!  \brief Class to contain CTPPS information from soft FED 1022
//!
//!  \author Remi Mommsen - Fermilab
//---------------------------------------------------------------------------

#include <array>
#include <bitset>
#include <cstdint>
#include <ostream>
#include <string>

#include "DataFormats/OnlineMetaData/interface/OnlineMetaDataRaw.h"
#include "DataFormats/Provenance/interface/Timestamp.h"

class CTPPSRecord {
public:
  enum RomanPot {
    RP_45_210_FR_BT,
    RP_45_210_FR_HR,
    RP_45_210_FR_TP,
    RP_45_220_C1,
    RP_45_220_FR_BT,
    RP_45_220_FR_HR,
    RP_45_220_FR_TP,
    RP_45_220_NR_BT,
    RP_45_220_NR_HR,
    RP_45_220_NR_TP,
    RP_56_210_FR_BT,
    RP_56_210_FR_HR,
    RP_56_210_FR_TP,
    RP_56_220_C1,
    RP_56_220_FR_BT,
    RP_56_220_FR_HR,
    RP_56_220_FR_TP,
    RP_56_220_NR_BT,
    RP_56_220_NR_HR,
    RP_56_220_NR_TP,
    Last
  };

  enum Status { unused, bad, warning, ok };

  CTPPSRecord();
  explicit CTPPSRecord(const online::CTPPS_v1&);
  virtual ~CTPPSRecord();

  /// Return the time of the last change
  const edm::Timestamp& timestamp() const { return timestamp_; }

  /// Get the names of all roman pots
  typedef std::array<std::string, Last> RomanPotNames;
  const RomanPotNames& romanPotNames() const { return romanPotNames_; }

  /// Return the name of the roman pot
  const std::string& romanPotName(const uint8_t rp) const { return romanPotNames_.at(rp); }

  /// Return the status of the given roman pot
  Status status(const uint8_t rp) const { return Status((status_ >> (rp * 2)) & 0x3); }

  /// Return the status as string
  const std::string& statusName(const uint8_t rp) const { return statusNames_.at(status(rp)); }

private:
  edm::Timestamp timestamp_;
  uint64_t status_;
  static const std::array<std::string, 4> statusNames_;
  static const RomanPotNames romanPotNames_;
};

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

#endif  // DATAFORMATS_ONLINEMETADATA_CTPPSRECORD_H