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
59
60
61
62
63
64
65
66
|
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include "FWCore/ParameterSet/interface/FileInPath.h"
#include "FWCore/ParameterSet/interface/ParameterSet.h"
#include "FWCore/Utilities/interface/Exception.h"
#include "CommonTools/ConditionDBWriter/interface/ConditionDBWriter.h"
#include "CondFormats/SiStripObjects/interface/SiStripBadStrip.h"
#include "CalibTracker/SiStripCommon/interface/SiStripDetInfoFileReader.h"
#include <vector>
#include <iostream>
#include <fstream>
class SiStripBadModuleByHandBuilder : public ConditionDBWriter<SiStripBadStrip> {
public:
explicit SiStripBadModuleByHandBuilder(const edm::ParameterSet&);
~SiStripBadModuleByHandBuilder() override = default;
private:
std::unique_ptr<SiStripBadStrip> getNewObject() override;
private:
edm::FileInPath fp_;
bool printdebug_;
std::vector<uint32_t> BadModuleList_;
};
SiStripBadModuleByHandBuilder::SiStripBadModuleByHandBuilder(const edm::ParameterSet& iConfig)
: ConditionDBWriter<SiStripBadStrip>(iConfig) {
fp_ = iConfig.getUntrackedParameter<edm::FileInPath>("file", edm::FileInPath(SiStripDetInfoFileReader::kDefaultFile));
BadModuleList_ = iConfig.getUntrackedParameter<std::vector<uint32_t> >("BadModuleList");
printdebug_ = iConfig.getUntrackedParameter<bool>("printDebug", false);
}
std::unique_ptr<SiStripBadStrip> SiStripBadModuleByHandBuilder::getNewObject() {
const auto detInfo = SiStripDetInfoFileReader::read(fp_.fullPath());
auto obj = std::make_unique<SiStripBadStrip>();
unsigned int firstBadStrip = 0;
unsigned short NconsecutiveBadStrips;
unsigned int theBadStripRange;
for (std::vector<uint32_t>::const_iterator it = BadModuleList_.begin(); it != BadModuleList_.end(); ++it) {
std::vector<unsigned int> theSiStripVector;
NconsecutiveBadStrips = detInfo.getNumberOfApvsAndStripLength(*it).first * 128;
theBadStripRange = obj->encode(firstBadStrip, NconsecutiveBadStrips);
if (printdebug_)
edm::LogInfo("SiStripBadModuleByHandBuilder")
<< " BadModule " << *it << " \t"
<< " firstBadStrip " << firstBadStrip << "\t "
<< " NconsecutiveBadStrips " << NconsecutiveBadStrips << "\t "
<< " packed integer " << std::hex << theBadStripRange << std::dec << std::endl;
theSiStripVector.push_back(theBadStripRange);
SiStripBadStrip::Range range(theSiStripVector.begin(), theSiStripVector.end());
if (!obj->put(*it, range))
edm::LogError("SiStripBadModuleByHandBuilder")
<< "[SiStripBadModuleByHandBuilder::analyze] detid already exists" << std::endl;
}
return obj;
}
#include "FWCore/Framework/interface/MakerMacros.h"
DEFINE_FWK_MODULE(SiStripBadModuleByHandBuilder);
|