SiPixelCalibDigiProducer

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 93 94 95 96 97 98 99 100 101 102 103 104 105 106
#ifndef CALIBTRACKER_SIPIXELCALIBDIGIPRODUCER_H
#define CALIBTRACKER_SIPIXELCALIBDIGIPRODUCER_H

//
// Package:    SiPixelCalibDigiProducer
// Class:      SiPixelCalibDigiProducer
//
/**\class SiPixelCalibDigiProducer SiPixelCalibDigiProducer.cc CalibTracker/SiPixelGainCalibration/src/SiPixelCalibDigiProducer.cc

 Description: <one line class summary>

 Implementation:
     <Notes on implementation>
*/
//
// Original Author:  Freya Blekman
//         Created:  Wed Oct 31 15:28:52 CET 2007
//
//

// system include files
#include <memory>

// user include files
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/stream/EDProducer.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/MakerMacros.h"

#include "FWCore/ServiceRegistry/interface/Service.h"

#include "FWCore/Utilities/interface/InputTag.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"

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

#include "DataFormats/SiPixelDigi/interface/SiPixelCalibDigifwd.h"
#include "DataFormats/SiPixelDigi/interface/SiPixelCalibDigi.h"
#include "DataFormats/SiPixelDigi/interface/PixelDigi.h"
#include "DataFormats/SiPixelDigi/interface/SiPixelCalibDigiError.h"

#include "Geometry/TrackerGeometryBuilder/interface/TrackerGeometry.h"
#include "CondFormats/SiPixelObjects/interface/SiPixelCalibConfiguration.h"
#include "CondFormats/DataRecord/interface/SiPixelCalibConfigurationRcd.h"
#include "CondFormats/DataRecord/interface/SiPixelFedCablingMapRcd.h"
#include "CondFormats/SiPixelObjects/interface/SiPixelFedCablingMap.h"

#include <map>
#include <vector>
#include <iostream>
//
// class decleration
//

class SiPixelCalibDigiProducer : public edm::stream::EDProducer<> {
public:
  explicit SiPixelCalibDigiProducer(const edm::ParameterSet& iConfig);
  ~SiPixelCalibDigiProducer() override;

private:
  void produce(edm::Event& iEvent, const edm::EventSetup& iSetup) override;
  virtual bool store();
  virtual void setPattern();
  virtual void fill(edm::Event& iEvent, const edm::EventSetup& iSetup);
  virtual void fillPixel(uint32_t detid, short row, short col, short ipoint, short adc);
  virtual bool checkPixel(uint32_t detid, short row, short col);
  virtual bool checkFED(uint32_t detid);
  virtual void clear();
  typedef std::pair<uint32_t, std::pair<short, short>> pixelstruct;
  // ----------member data ---------------------------
  edm::InputTag src_;
  edm::EDGetTokenT<edm::DetSetVector<PixelDigi>> tPixelDigi;
  uint32_t iEventCounter_;

  bool ignore_non_pattern_;
  bool control_pattern_size_;
  bool includeErrors_;
  int errorType;
  edm::ParameterSet conf_;
  std::string label_;
  std::string instance_;
  uint32_t number_of_pixels_per_pattern_;
  bool use_realeventnumber_;

  edm::ESHandle<SiPixelCalibConfiguration> calib_;  // keeps track of the calibration constants
  edm::ESHandle<TrackerGeometry> theGeometry_;      // the tracker geometry
  edm::ESHandle<SiPixelFedCablingMap> theCablingMap_;

  edm::ESGetToken<SiPixelCalibConfiguration, SiPixelCalibConfigurationRcd> calibToken_;
  edm::ESGetToken<TrackerGeometry, TrackerDigiGeometryRecord> trackerGeomToken_;
  edm::ESGetToken<SiPixelFedCablingMap, SiPixelFedCablingMapRcd> cablingMapToken_;

  // worker variables
  std::map<pixelstruct, SiPixelCalibDigi>
      intermediate_data_;  // data container, copied over into the event every pattern_repeat_ events
  std::map<pixelstruct, SiPixelCalibDigiError> error_data_;
  //      std::vector<SiPixelCalibDigi> intermediate_data_; // data container, copied over into the event every pattern_repeat_ events
  std::vector<pixelstruct> detPixelMap_;  // map to keep track of which pixels are filled where in intermediate_data_
  uint32_t pattern_repeat_;               // keeps track of when the pattern should change
  std::map<uint32_t, uint32_t> detid_to_fedid_;  // keeps track in which fed each detid is present.

  std::vector<std::pair<short, short>> currentpattern_;  // keeps track of which pattern we are at
  std::pair<short, short> currentpair_;                  //worker class to keep track of pairs
};

#endif