DigiToRaw

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

#ifndef EventFilter_SiStripRawToDigi_SiStripDigiToRaw_H
#define EventFilter_SiStripRawToDigi_SiStripDigiToRaw_H

#include "DataFormats/Common/interface/Handle.h"
#include "DataFormats/Common/interface/DetSetVector.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Utilities/interface/Visibility.h"
#include <string>

#include "EventFilter/SiStripRawToDigi/interface/SiStripFEDBufferGenerator.h"
#include "WarningSummary.h"
#include <cstdint>

class SiStripFedCabling;
class FEDRawDataCollection;
class SiStripDigi;
class SiStripRawDigi;

namespace sistrip {

  /**
     @file EventFilter/SiStripRawToDigi/interface/SiStripDigiToRaw.h
     @class sistrip::DigiToRaw 
   
     @brief Input: edm::DetSetVector<SiStripDigi>. 
     Output: FEDRawDataCollection.
  */
  class dso_hidden DigiToRaw {
  public:  // ----- public interface -----
    DigiToRaw(FEDReadoutMode mode, uint8_t packetCode, bool use_fed_key);
    ~DigiToRaw();

    //digi to raw with default headers
    void createFedBuffers(edm::Event&,
                          edm::ESHandle<SiStripFedCabling>& cabling,
                          edm::Handle<edm::DetSetVector<SiStripDigi> >& digis,
                          std::unique_ptr<FEDRawDataCollection>& buffers);
    void createFedBuffers(edm::Event&,
                          edm::ESHandle<SiStripFedCabling>& cabling,
                          edm::Handle<edm::DetSetVector<SiStripRawDigi> >& digis,
                          std::unique_ptr<FEDRawDataCollection>& buffers);

    //with input raw data for copying header
    void createFedBuffers(edm::Event&,
                          edm::ESHandle<SiStripFedCabling>& cabling,
                          edm::Handle<FEDRawDataCollection>& rawbuffers,
                          edm::Handle<edm::DetSetVector<SiStripDigi> >& digis,
                          std::unique_ptr<FEDRawDataCollection>& buffers);
    void createFedBuffers(edm::Event&,
                          edm::ESHandle<SiStripFedCabling>& cabling,
                          edm::Handle<FEDRawDataCollection>& rawbuffers,
                          edm::Handle<edm::DetSetVector<SiStripRawDigi> >& digis,
                          std::unique_ptr<FEDRawDataCollection>& buffers);

    inline void fedReadoutMode(FEDReadoutMode mode) { mode_ = mode; }

    void printWarningSummary() const { warnings_.printSummary(); }

  private:  // ----- private data members -----
    template <class Digi_t>
    void createFedBuffers_(edm::Event&,
                           edm::ESHandle<SiStripFedCabling>& cabling,
                           edm::Handle<edm::DetSetVector<Digi_t> >& digis,
                           std::unique_ptr<FEDRawDataCollection>& buffers,
                           bool zeroSuppressed);

    template <class Digi_t>
    void createFedBuffers_(edm::Event&,
                           edm::ESHandle<SiStripFedCabling>& cabling,
                           edm::Handle<FEDRawDataCollection>& rawbuffers,
                           edm::Handle<edm::DetSetVector<Digi_t> >& digis,
                           std::unique_ptr<FEDRawDataCollection>& buffers,
                           bool zeroSuppressed);

    uint16_t STRIP(const edm::DetSet<SiStripDigi>::const_iterator& it,
                   const edm::DetSet<SiStripDigi>::const_iterator& begin) const;
    uint16_t STRIP(const edm::DetSet<SiStripRawDigi>::const_iterator& it,
                   const edm::DetSet<SiStripRawDigi>::const_iterator& begin) const;

    FEDReadoutMode mode_;
    uint8_t packetCode_;
    bool useFedKey_;
    FEDBufferGenerator bufferGenerator_;

    WarningSummary warnings_;
  };

}  // namespace sistrip

#endif  // EventFilter_SiStripRawToDigi_SiStripDigiToRaw_H