CMS 3D CMS Logo

 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Properties Friends Macros Pages
CSCVTMBHeaderFormat.h
Go to the documentation of this file.
1 #ifndef CSCVTMBHeaderFormat_h
2 #define CSCVTMBHeaderFormat_h
3 
8 #include <vector>
9 #include <iosfwd>
10 #include <strings.h>
11 class CSCDMBHeader;
12 
13 
15 public:
16  virtual ~CSCVTMBHeaderFormat() {}
17  void init() {
18  bzero(this, sizeInWords()*2);
19  }
20 
21  virtual void setEventInformation(const CSCDMBHeader &) = 0;
22  virtual uint16_t BXNCount() const = 0;
23  virtual uint16_t ALCTMatchTime() const = 0;
24  virtual uint16_t CLCTOnly() const = 0;
25  virtual uint16_t ALCTOnly() const = 0;
26  virtual uint16_t TMBMatch() const = 0;
27  virtual uint16_t Bxn0Diff() const = 0;
28  virtual uint16_t Bxn1Diff() const = 0;
29  virtual uint16_t L1ANumber() const = 0;
30  uint16_t sizeInBytes() const {
31  return sizeInWords()*2;
32  }
33  virtual uint16_t NTBins() const = 0;
34  virtual uint16_t NCFEBs() const = 0;
35  virtual uint16_t firmwareRevision() const = 0;
37  virtual std::vector<CSCCLCTDigi> CLCTDigis(uint32_t idlayer) = 0;
39  virtual std::vector<CSCCorrelatedLCTDigi> CorrelatedLCTDigis(uint32_t idlayer) const = 0;
40 
41 
44  virtual unsigned short int sizeInWords() const = 0;
45 
46  virtual unsigned short int NHeaderFrames() const = 0;
47  virtual unsigned short * data() = 0;
48  virtual bool check() const = 0;
49 
51  //void setChamberId(const CSCDetId & detId) {theChamberId = detId;}
52 
54  virtual void addCLCT0(const CSCCLCTDigi & digi) = 0;
55  virtual void addCLCT1(const CSCCLCTDigi & digi) = 0;
56  virtual void addALCT0(const CSCALCTDigi & digi) = 0;
57  virtual void addALCT1(const CSCALCTDigi & digi) = 0;
58  virtual void addCorrelatedLCT0(const CSCCorrelatedLCTDigi & digi) = 0;
59  virtual void addCorrelatedLCT1(const CSCCorrelatedLCTDigi & digi) = 0;
60 
61 
62  virtual void print(std::ostream & os) const = 0;
63 protected:
64 
65  void swapCLCTs(CSCCLCTDigi& digi1, CSCCLCTDigi& digi2);
66 };
67 
68 #endif
69 
virtual void addCorrelatedLCT0(const CSCCorrelatedLCTDigi &digi)=0
virtual unsigned short * data()=0
virtual uint16_t NCFEBs() const =0
virtual uint16_t CLCTOnly() const =0
virtual uint16_t TMBMatch() const =0
virtual void addCorrelatedLCT1(const CSCCorrelatedLCTDigi &digi)=0
virtual uint16_t ALCTMatchTime() const =0
virtual void addALCT1(const CSCALCTDigi &digi)=0
virtual uint16_t firmwareRevision() const =0
virtual void print(std::ostream &os) const =0
virtual void addCLCT0(const CSCCLCTDigi &digi)=0
Needed before data packing.
uint16_t sizeInBytes() const
virtual unsigned short int NHeaderFrames() const =0
virtual void addALCT0(const CSCALCTDigi &digi)=0
virtual std::vector< CSCCorrelatedLCTDigi > CorrelatedLCTDigis(uint32_t idlayer) const =0
returns CorrelatedLCT digis
virtual uint16_t Bxn0Diff() const =0
virtual void setEventInformation(const CSCDMBHeader &)=0
virtual uint16_t ALCTOnly() const =0
virtual uint16_t Bxn1Diff() const =0
virtual void addCLCT1(const CSCCLCTDigi &digi)=0
virtual std::vector< CSCCLCTDigi > CLCTDigis(uint32_t idlayer)=0
returns CLCT digis
virtual unsigned short int sizeInWords() const =0
virtual uint16_t BXNCount() const =0
void swapCLCTs(CSCCLCTDigi &digi1, CSCCLCTDigi &digi2)
virtual uint16_t NTBins() const =0
virtual uint16_t L1ANumber() const =0
virtual bool check() const =0