corrResps

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
#include <cstdlib>
#include <iostream>
#include <fstream>
#include <vector>

#include "CalibCalorimetry/HcalAlgos/interface/HcalDbASCIIIO.h"
#include "CondFormats/HcalObjects/interface/HcalRespCorrs.h"
#include "Geometry/CaloTopology/interface/HcalTopology.h"
#include "FWCore/Framework/interface/Frameworkfwd.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "Geometry/Records/interface/HcalRecNumberingRecord.h"

class corrResps : public edm::one::EDAnalyzer<edm::one::WatchRuns> {
public:
  explicit corrResps(const edm::ParameterSet&);
  ~corrResps() override;

private:
  void beginRun(edm::Run const& iEvent, edm::EventSetup const&) override {}
  void analyze(edm::Event const&, edm::EventSetup const&) override;
  void endRun(edm::Run const& iEvent, edm::EventSetup const&) override {}
  std::string fileIn, fileOut, fileCorr;
  edm::ESGetToken<HcalTopology, HcalRecNumberingRecord> tok_htopo_;
};

corrResps::corrResps(const edm::ParameterSet& iConfig) {
  fileIn = iConfig.getUntrackedParameter<std::string>("FileIn");
  fileOut = iConfig.getUntrackedParameter<std::string>("FileOut");
  fileCorr = iConfig.getUntrackedParameter<std::string>("FileCorr");
  tok_htopo_ = esConsumes<HcalTopology, HcalRecNumberingRecord>();
}

corrResps::~corrResps() {}

void corrResps::analyze(edm::Event const&, edm::EventSetup const& iSetup) {
  HcalTopology topo = iSetup.getData(tok_htopo_);

  HcalRespCorrs respIn(&topo);
  std::ifstream inStream(fileIn.c_str());
  HcalDbASCIIIO::getObject(inStream, &respIn);
  inStream.close();

  HcalRespCorrs corrsIn(&topo);
  std::ifstream inCorr(fileCorr.c_str());
  HcalDbASCIIIO::getObject(inCorr, &corrsIn);
  inCorr.close();

  HcalRespCorrs respOut(&topo);
  std::vector<DetId> channels = respIn.getAllChannels();
  for (unsigned int i = 0; i < channels.size(); i++) {
    DetId id = channels[i];
    float scale = 1.0;
    if (corrsIn.exists(id))
      scale = corrsIn.getValues(id)->getValue();
    HcalRespCorr item(id, respIn.getValues(id)->getValue() * scale);
    respOut.addValues(item);
  }

  std::ofstream outStream(fileOut.c_str());
  HcalDbASCIIIO::dumpObject(outStream, respOut);
  outStream.close();
}

//define this as a plug-in
DEFINE_FWK_MODULE(corrResps);