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
#include "CaloOnlineTools/HcalOnlineDb/interface/HcalLutGenerator.h"

#include "FWCore/Framework/interface/ESHandle.h"
#include "DataFormats/HcalDetId/interface/HcalDetId.h"
#include "CondFormats/HcalObjects/interface/HcalElectronicsMap.h"
#include "CaloOnlineTools/HcalOnlineDb/interface/HcalLutManager.h"

#include "CaloOnlineTools/HcalOnlineDb/interface/LMap.h"

#include <iostream>

HcalLutGenerator::HcalLutGenerator(const edm::ParameterSet& iConfig) {
  _tag = iConfig.getParameter<std::string>("tag");
  _lin_file = iConfig.getParameter<std::string>("HO_master_file");
  _status_word_to_mask = iConfig.getParameter<uint32_t>("status_word_to_mask");
  tok_inCoder_ = esConsumes<HcalTPGCoder, HcalTPGRecord>();
  tok_dbservice_ = esConsumes<HcalDbService, HcalDbRecord>();
  tok_hcalChStatus_ = esConsumes<HcalChannelQuality, HcalChannelQualityRcd>(edm::ESInputTag("", "withTopo"));
  tok_hcalCoder_ = esConsumes<CaloTPGTranscoder, CaloTPGRecord>();
}

void HcalLutGenerator::analyze(const edm::Event& iEvent, const edm::EventSetup& iSetup) {
  const HcalTPGCoder* inputCoder = &iSetup.getData(tok_inCoder_);
  const HcalDbService* hcalcond = &iSetup.getData(tok_dbservice_);
  const HcalChannelQuality* _cq = &iSetup.getData(tok_hcalChStatus_);

  edm::ESHandle<CaloTPGTranscoder> outTranscoder = iSetup.getHandle(tok_hcalCoder_);
  edm::ESHandle<CaloTPGTranscoderULUT> transcoder;
  transcoder.swap(outTranscoder);

  HcalLutManager manager(hcalcond, _cq, _status_word_to_mask);
  bool split_by_crate = true;

  manager.createLutXmlFiles_HBEFFromCoder_HOFromAscii_ZDC(_tag, *inputCoder, *transcoder, _lin_file, split_by_crate);
}