L1DataEmulRecord

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

/*\class L1DataEmulRecord
 *\description L1 trigger data|emulation event record
 *\author Nuno Leonardo (CERN)
 *\date 07.06
 */

#include <ostream>
#include <vector>
#include <array>

#include "DataFormats/L1Trigger/interface/L1DataEmulDigi.h"

class L1DataEmulRecord {
public:
  static const int DEnsys = 12;
  typedef std::vector<L1DataEmulDigi> L1DEDigiCollection;

  L1DataEmulRecord();
  L1DataEmulRecord(bool evt_match,
                   bool sys_comp[DEnsys],
                   bool sys_match[DEnsys],
                   int nCand[DEnsys][2],
                   const L1DEDigiCollection&,
                   const GltDEDigi&);
  L1DataEmulRecord(bool evt_match,
                   std::array<bool, DEnsys> const& sys_comp,
                   std::array<bool, DEnsys> const& sys_match,
                   std::array<std::array<int, 2>, DEnsys> const& nCand,
                   const L1DEDigiCollection&,
                   const GltDEDigi&);
  ~L1DataEmulRecord();

  bool get_status() const { return deAgree; }
  bool get_status(int s) const { return deMatch[s]; }
  void get_status(bool result[]) const;
  L1DEDigiCollection getColl() const { return deColl; }
  GltDEDigi getGlt() const { return deGlt; }
  int getNCand(int i, int j) const { return deNCand[i][j]; }
  bool get_isComp(int i) const { return deSysCompared[i]; }

  void set_status(const bool result);
  void set_status(const bool result[]);
  void setColl(const L1DEDigiCollection& col) { deColl = col; }
  void setGlt(const GltDEDigi& glt) { deGlt = glt; }

  bool empty() const { return deColl.empty(); }

private:
  bool deAgree;
  bool deSysCompared[DEnsys];
  bool deMatch[DEnsys];
  int deNCand[DEnsys][2];
  L1DEDigiCollection deColl;
  GltDEDigi deGlt;
};

std::ostream& operator<<(std::ostream&, const L1DataEmulRecord&);

#endif