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
|
/*----------------------------------------------------------------------
Toy EDProducers and EDProducts for testing purposes only.
----------------------------------------------------------------------*/
#include <stdexcept>
#include <string>
#include <iostream>
#include <map>
#include <vector>
#include "FWCore/Framework/interface/global/EDAnalyzer.h"
#include "FWCore/Framework/interface/Event.h"
#include "FWCore/Framework/interface/ESHandle.h"
#include "FWCore/Framework/interface/MakerMacros.h"
#include "FWCore/Framework/interface/EventSetup.h"
#include "FWCore/Utilities/interface/ESGetToken.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "CondFormats/CSCObjects/interface/CSCcrosstalk.h"
#include "CondFormats/DataRecord/interface/CSCcrosstalkRcd.h"
using namespace std;
namespace edmtest {
class CSCCrossTalkReadAnalyzer : public edm::global::EDAnalyzer<> {
public:
explicit CSCCrossTalkReadAnalyzer(edm::ParameterSet const& p) : crosstalkToken_{esConsumes()} {}
~CSCCrossTalkReadAnalyzer() override {}
void analyze(edm::StreamID, const edm::Event& e, const edm::EventSetup& c) const override;
private:
edm::ESGetToken<CSCcrosstalk, CSCcrosstalkRcd> crosstalkToken_;
};
void CSCCrossTalkReadAnalyzer::analyze(edm::StreamID, const edm::Event& e, const edm::EventSetup& context) const {
using namespace edm::eventsetup;
// Context is not used.
edm::LogSystem log("CSCCrossTalk");
log << " I AM IN RUN NUMBER " << e.id().run() << std::endl;
log << " ---EVENT NUMBER " << e.id().event() << std::endl;
const CSCcrosstalk* mycrosstalk = &context.getData(crosstalkToken_);
std::map<int, std::vector<CSCcrosstalk::Item> >::const_iterator it;
for (it = mycrosstalk->crosstalk.begin(); it != mycrosstalk->crosstalk.end(); ++it) {
log << "layer id found " << it->first << std::endl;
std::vector<CSCcrosstalk::Item>::const_iterator crosstalkit;
for (crosstalkit = it->second.begin(); crosstalkit != it->second.end(); ++crosstalkit) {
log << " crosstalk_slope_right: " << crosstalkit->xtalk_slope_right
<< " crosstalk_intercept_right: " << crosstalkit->xtalk_intercept_right << std::endl;
}
}
}
DEFINE_FWK_MODULE(CSCCrossTalkReadAnalyzer);
} // namespace edmtest
|