SiStripFEDDumpPlugin

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
#include <sstream>

#include "FWCore/Utilities/interface/EDGetToken.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/Utilities/interface/InputTag.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"

#include "EventFilter/SiStripRawToDigi/interface/SiStripFEDBuffer.h"
#include "DataFormats/FEDRawData/interface/FEDRawDataCollection.h"
#include "DataFormats/FEDRawData/interface/FEDRawData.h"
#include "DataFormats/FEDRawData/interface/FEDNumbering.h"

#include "DQMServices/Core/interface/DQMEDAnalyzer.h"

//
// Class declaration
//

class SiStripFEDDumpPlugin : public DQMEDAnalyzer {
public:
  explicit SiStripFEDDumpPlugin(const edm::ParameterSet&);
  ~SiStripFEDDumpPlugin() override;

private:
  void analyze(const edm::Event&, const edm::EventSetup&) override;
  void bookHistograms(DQMStore::IBooker&, edm::Run const&, edm::EventSetup const&) override;

  //tag of FEDRawData collection
  edm::InputTag rawDataTag_;
  edm::EDGetTokenT<FEDRawDataCollection> rawDataToken_;
  //FED ID to dump
  unsigned int fedIdToDump_;
};

//
// Constructors and destructor
//

SiStripFEDDumpPlugin::SiStripFEDDumpPlugin(const edm::ParameterSet& iConfig)
    : rawDataTag_(iConfig.getUntrackedParameter<edm::InputTag>("RawDataTag", edm::InputTag("source", ""))),
      fedIdToDump_(iConfig.getUntrackedParameter<unsigned int>("FEDID", 50)) {
  rawDataToken_ = consumes<FEDRawDataCollection>(rawDataTag_);
  if ((fedIdToDump_ > FEDNumbering::MAXSiStripFEDID) || (fedIdToDump_ < FEDNumbering::MINSiStripFEDID))
    edm::LogError("SiStripFEDDump") << "FED ID " << fedIdToDump_ << " is not valid. "
                                    << "SiStrip FED IDs are " << uint16_t(FEDNumbering::MINSiStripFEDID) << "-"
                                    << uint16_t(FEDNumbering::MAXSiStripFEDID);
}

SiStripFEDDumpPlugin::~SiStripFEDDumpPlugin() {}

//
// Member functions
//

// ------------ method called to for each event  ------------
void SiStripFEDDumpPlugin::analyze(const edm::Event& iEvent, const edm::EventSetup& iSetup) {
  //get raw data
  edm::Handle<FEDRawDataCollection> rawDataCollectionHandle;
  iEvent.getByToken(rawDataToken_, rawDataCollectionHandle);
  const FEDRawDataCollection& rawDataCollection = *rawDataCollectionHandle;

  const FEDRawData& rawData = rawDataCollection.FEDData(fedIdToDump_);
  const auto st_buffer = sistrip::preconstructCheckFEDBufferBase(rawData, false);
  if (sistrip::FEDBufferStatusCode::SUCCESS != st_buffer) {
    throw cms::Exception("FEDBuffer") << st_buffer;
  }
  const sistrip::FEDBufferBase buffer{rawData};
  std::ostringstream os;
  os << buffer << std::endl;
  buffer.dump(os);
  edm::LogVerbatim("SiStripFEDDump") << os.str();
}

void SiStripFEDDumpPlugin::bookHistograms(DQMStore::IBooker& ibooker,
                                          const edm::Run& run,
                                          const edm::EventSetup& eSetup) {}

//
// Define as a plug-in
//

#include "FWCore/Framework/interface/MakerMacros.h"
DEFINE_FWK_MODULE(SiStripFEDDumpPlugin);