GlobalPositionRcdRead

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
#include <string>
#include <map>
#include <vector>

#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Framework/interface/one/EDAnalyzer.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "CondFormats/Alignment/interface/Alignments.h"
#include "CondFormats/Alignment/interface/AlignTransform.h"
#include "CondFormats/AlignmentRecord/interface/GlobalPositionRcd.h"
#include "DataFormats/DetId/interface/DetId.h"

class GlobalPositionRcdRead : public edm::one::EDAnalyzer<> {
public:
  explicit GlobalPositionRcdRead(const edm::ParameterSet& iConfig) : GPRToken_(esConsumes()), nEventCalls_(0) {}
  ~GlobalPositionRcdRead() {}
  void analyze(const edm::Event&, const edm::EventSetup&) override;

private:
  const edm::ESGetToken<Alignments, GlobalPositionRcd> GPRToken_;
  unsigned int nEventCalls_;
};

void GlobalPositionRcdRead::analyze(const edm::Event& iEvent, const edm::EventSetup& iSetup) {
  if (nEventCalls_ > 0) {
    edm::LogPrint("GlobalPositionRcdRead")
        << "Reading from DB to be done only once, "
        << "set 'untracked PSet maxEvents = {untracked int32 input = 1}'." << std::endl;

    return;
  }

  edm::LogPrint("GlobalPositionRcdRead") << "Reading from database in GlobalPositionRcdRead::analyze..." << std::endl;

  const Alignments* globalPositionRcd = &iSetup.getData(GPRToken_);

  edm::LogPrint("GlobalPositionRcdRead") << "Expecting entries in " << DetId(DetId::Tracker).rawId() << " "
                                         << DetId(DetId::Muon).rawId() << " " << DetId(DetId::Ecal).rawId() << " "
                                         << DetId(DetId::Hcal).rawId() << " " << DetId(DetId::Calo).rawId()
                                         << std::endl;
  for (std::vector<AlignTransform>::const_iterator i = globalPositionRcd->m_align.begin();
       i != globalPositionRcd->m_align.end();
       ++i) {
    edm::LogPrint("GlobalPositionRcdRead") << "entry " << i->rawId() << " translation " << i->translation()
                                           << " angles " << i->rotation().eulerAngles() << std::endl;
    edm::LogPrint("GlobalPositionRcdRead") << i->rotation() << std::endl;
  }

  edm::LogPrint("GlobalPositionRcdRead") << "done!" << std::endl;
  nEventCalls_++;
}

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