HcalCellSizeCheck

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
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "Geometry/HcalCommonData/interface/HcalDDDRecConstants.h"
#include "Geometry/Records/interface/CaloGeometryRecord.h"
#include "Geometry/CaloGeometry/interface/CaloGeometry.h"
#include "Geometry/CaloGeometry/interface/CaloCellGeometry.h"
#include "Geometry/HcalTowerAlgo/interface/HcalGeometry.h"
#include "Geometry/HcalTowerAlgo/interface/HcalFlexiHardcodeGeometryLoader.h"
#include "Geometry/HcalTowerAlgo/interface/HcalHardcodeGeometryLoader.h"
#include "Geometry/HcalTowerAlgo/interface/HcalTrigTowerGeometry.h"
#include "DataFormats/HcalDetId/interface/HcalTrigTowerDetId.h"
#include <iostream>
#include <string>

class HcalCellSizeCheck : public edm::one::EDAnalyzer<> {
public:
  explicit HcalCellSizeCheck(const edm::ParameterSet&);
  ~HcalCellSizeCheck(void) override {}

  void beginJob() override {}
  void analyze(edm::Event const&, edm::EventSetup const&) override;
  void endJob() override {}

private:
  edm::ESGetToken<HcalDDDRecConstants, HcalRecNumberingRecord> tok_ddrec_;
  edm::ESGetToken<HcalTopology, HcalRecNumberingRecord> tok_htopo_;
};

HcalCellSizeCheck::HcalCellSizeCheck(const edm::ParameterSet& iConfig) {
  tok_ddrec_ = esConsumes<HcalDDDRecConstants, HcalRecNumberingRecord>();
  tok_htopo_ = esConsumes<HcalTopology, HcalRecNumberingRecord>();
}

void HcalCellSizeCheck::analyze(const edm::Event& /*iEvent*/, const edm::EventSetup& iSetup) {
  const HcalDDDRecConstants hcons = iSetup.getData(tok_ddrec_);
  const HcalTopology topology = iSetup.getData(tok_htopo_);

  HcalFlexiHardcodeGeometryLoader m_loader;
  CaloSubdetectorGeometry* geom = m_loader.load(topology, hcons);

  const std::vector<DetId>& idsb = geom->getValidDetIds(DetId::Hcal, HcalBarrel);
  for (auto id : idsb) {
    HcalDetId hid(id.rawId());
    std::pair<double, double> rz = hcons.getRZ(hid);
    edm::LogVerbatim("HCalGeom") << hid << " Front " << rz.first << " Back " << rz.second;
  }

  const std::vector<DetId>& idse = geom->getValidDetIds(DetId::Hcal, HcalEndcap);
  for (auto id : idse) {
    HcalDetId hid(id.rawId());
    std::pair<double, double> rz = hcons.getRZ(hid);
    edm::LogVerbatim("HCalGeom") << hid << " Front " << rz.first << " Back " << rz.second;
  }
}

DEFINE_FWK_MODULE(HcalCellSizeCheck);