AMC13Header

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 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97 98 99 100 101 102 103 104 105 106
// Class for AMC13 Header

#ifndef __l1t_emtf_AMC13Header_h__
#define __l1t_emtf_AMC13Header_h__

#include <vector>
#include <cstdint>

namespace l1t {
  namespace emtf {
    class AMC13Header {
    public:
      explicit AMC13Header(uint64_t dataword);

      // Empty constructor
      AMC13Header()
          : orn(-99),
            lv1_id(-99),
            bx_id(-99),
            source_id(-99),
            evt_ty(-99),
            fov(-99),
            ufov(-99),
            res(-99),
            namc(-99),
            h(-99),
            x(-99),
            format_errors(0),
            dataword(-99) {}

      // Fill constructor
      AMC13Header(int int_orn,
                  int int_lv1_id,
                  int int_bx_id,
                  int int_source_id,
                  int int_evt_ty,
                  int int_fov,
                  int int_ufov,
                  int int_res,
                  int int_namc,
                  int int_h,
                  int int_x)
          : orn(int_orn),
            lv1_id(int_lv1_id),
            bx_id(int_bx_id),
            source_id(int_source_id),
            evt_ty(int_evt_ty),
            fov(int_fov),
            ufov(int_ufov),
            res(int_res),
            namc(int_namc),
            h(int_h),
            x(int_x),
            format_errors(0),
            dataword(-99) {}

      virtual ~AMC13Header() {}

      void set_orn(int bits) { orn = bits; }
      void set_lv1_id(int bits) { lv1_id = bits; }
      void set_bx_id(int bits) { bx_id = bits; }
      void set_source_id(int bits) { source_id = bits; }
      void set_evt_ty(int bits) { evt_ty = bits; }
      void set_fov(int bits) { fov = bits; }
      void set_ufov(int bits) { ufov = bits; }
      void set_res(int bits) { res = bits; }
      void set_namc(int bits) { namc = bits; }
      void set_h(int bits) { h = bits; }
      void set_x(int bits) { x = bits; }
      void add_format_error() { format_errors += 1; }
      void set_dataword(uint64_t bits) { dataword = bits; }

      int ORN() const { return orn; }
      int LV1_id() const { return lv1_id; }
      int BX_id() const { return bx_id; }
      int Source_id() const { return source_id; }
      int Evt_ty() const { return evt_ty; }
      int FOV() const { return fov; }
      int UFOV() const { return ufov; }
      int Res() const { return res; }
      int Namc() const { return namc; }
      int H() const { return h; }
      int X() const { return x; }
      int Format_Errors() const { return format_errors; }
      uint64_t Dataword() const { return dataword; }

    private:
      int orn;
      int lv1_id;
      int bx_id;
      int source_id;
      int evt_ty;
      int fov;
      int ufov;
      int res;
      int namc;
      int h;
      int x;
      int format_errors;
      uint64_t dataword;

    };  // End class AMC13Header
  }  // End namespace emtf
}  // End namespace l1t

#endif /* define __l1t_emtf_AMC13Header_h__ */