CTPPSTotemDataFormatter

PPSStripIndex

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
/****************************************************************************
 *
 * This is a part of the TOTEM offline software.
 * Authors: 
 *
 ****************************************************************************/

#ifndef EventFilter_CTPPSRawToDigi_CTPPSTotemDataFormatter_h
#define EventFilter_CTPPSRawToDigi_CTPPSTotemDataFormatter_h

#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "DataFormats/Common/interface/DetSetVector.h"

#include "CondFormats/PPSObjects/interface/TotemDAQMapping.h"

#include "DataFormats/CTPPSDigi/interface/TotemRPDigi.h"
#include "DataFormats/CTPPSDigi/interface/TotemVFATStatus.h"
#include "DataFormats/CTPPSDigi/interface/CTPPSDiamondDigi.h"

#include "FWCore/Utilities/interface/typedefs.h"
#include "DataFormats/FEDRawData/interface/FEDRawData.h"
#include "DataFormats/FEDRawData/interface/FEDHeader.h"
#include "DataFormats/FEDRawData/interface/FEDTrailer.h"
#include <cstdint>
#include <vector>
#include <map>
#include "FWCore/Framework/interface/ESHandle.h"
#include "DataFormats/CTPPSDigi/interface/TotemVFATStatus.h"
#include "EventFilter/CTPPSRawToDigi/interface/VFATFrame.h"
#include "FWCore/Framework/interface/EventSetup.h"

//brief Collection of code to convert TOTEM raw data into digi.

class FEDRawData;
class CTPPSTotemDigiToRaw;

class CTPPSTotemDataFormatter {
private:
  typedef uint16_t Word16;
  typedef uint32_t Word32;
  typedef uint64_t Word64;

  int m_WordCounter;
  int m_DigiCounter;

public:
  typedef std::unordered_map<int, FEDRawData> RawData;
  typedef std::vector<TotemRPDigi> DetDigis;
  typedef std::unordered_map<cms_uint32_t, DetDigis> Digis;

  CTPPSTotemDataFormatter(std::map<TotemFramePosition, TotemVFATInfo> const& mapping);

  int nWords() const { return m_WordCounter; }
  int nDigis() const { return m_DigiCounter; }

  struct PPSStripIndex {
    uint32_t id;
    unsigned int hwid;
    short unsigned int fedid;
    short unsigned int idxinfiber;
    short unsigned int gohid;
  };

  void formatRawData(unsigned int lvl1_ID,
                     RawData& fedRawData,
                     const Digis& digis,
                     std::vector<PPSStripIndex> v_iDdet2fed);

  static bool compare(const PPSStripIndex& a, const PPSStripIndex& b) { return a.id < b.id; }

  std::string print(const Word64& word) const;
};

#endif