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);
|