17 const std::shared_ptr<const PedeLabelerBase>&
pedeLabeler,
18 const std::shared_ptr<const AlignPCLThresholdsHG>& theThresholds,
19 const std::shared_ptr<const PixelTopologyMap>& pixelTopologyMap)
21 theThresholds_(theThresholds),
22 pixelTopologyMap_(pixelTopologyMap),
24 millePedeEndFile_(
config.getParameter<
std::
string>(
"millePedeEndFile")),
25 millePedeLogFile_(
config.getParameter<
std::
string>(
"millePedeLogFile")),
26 millePedeResFile_(
config.getParameter<
std::
string>(
"millePedeResFile")),
47 std::ifstream endFile;
50 if (endFile.is_open()) {
51 edm::LogInfo(
"MillePedeFileReader") <<
"Reading millepede end-file";
53 getline(endFile,
line);
55 if (
line.find(
"-1") != std::string::npos) {
56 getline(endFile,
line);
58 std::istringstream iss(
line);
64 std::istringstream iss(
line);
70 edm::LogError(
"MillePedeFileReader") <<
"Could not read millepede end-file.";
80 edm::LogInfo(
"MillePedeFileReader") <<
"Reading millepede log-file";
87 if (
line.find(Nrec_string) != std::string::npos) {
88 std::istringstream iss(
line);
90 iss >> trash >> trash >>
Nrec_;
92 if (Nrec_ < theThresholds_->getNrecords()) {
94 <<
"Number of records used " <<
theThresholds_->getNrecords() << std::endl;
99 if (
line.find(Binaries_string) != std::string::npos) {
104 edm::LogError(
"MillePedeFileReader") <<
"Could not read millepede log-file.";
113 std::map<std::string, std::array<float, 6> > cutoffs_;
114 std::map<std::string, std::array<float, 6> > significances_;
115 std::map<std::string, std::array<float, 6> > thresholds_;
116 std::map<std::string, std::array<float, 6> > errors_;
117 std::map<std::string, std::array<float, 6> > fractions_;
119 std::map<std::string, std::array<int, 6> > countsAbove_;
120 std::map<std::string, std::array<int, 6> > countsTotal_;
124 std::vector<std::string> alignables_ =
theThresholds_->getAlignableList();
125 for (
auto& ali : alignables_) {
133 countsAbove_[ali] = {{0, 0, 0, 0, 0, 0}};
134 countsTotal_[ali] = {{0, 0, 0, 0, 0, 0}};
140 std::ifstream resFile;
143 if (resFile.is_open()) {
144 edm::LogInfo(
"MillePedeFileReader") <<
"Reading millepede result-file";
147 getline(resFile,
line);
149 while (getline(resFile,
line)) {
150 std::istringstream iss(
line);
152 std::vector<std::string> tokens;
154 while (iss >>
token) {
155 tokens.push_back(
token);
158 auto alignableLabel = std::stoul(tokens[0]);
159 const auto alignable =
pedeLabeler_->alignableFromLabel(alignableLabel);
160 auto det =
getHLS(alignable);
161 int detIndex =
static_cast<int>(det);
162 auto alignableIndex = alignableLabel % 10 - 1;
165 countsTotal_[
detLabel][alignableIndex]++;
167 if (tokens.size() > 4 ) {
168 const auto paramNum =
pedeLabeler_->paramNumFromLabel(alignableLabel);
172 double ObsMove = std::stof(tokens[3]) *
multiplier_[alignableIndex];
173 double ObsErr = std::stof(tokens[4]) *
multiplier_[alignableIndex];
181 Xobs_[detIndex] = ObsMove;
185 Yobs_[detIndex] = ObsMove;
189 Zobs_[detIndex] = ObsMove;
193 tXobs_[detIndex] = ObsMove;
197 tYobs_[detIndex] = ObsMove;
201 tZobs_[detIndex] = ObsMove;
205 edm::LogError(
"MillePedeFileReader") <<
"Currently not able to handle DOF " << coord << std::endl;
236 edm::LogError(
"MillePedeFileReader") <<
"Currently not able to handle DOF " << coord << std::endl;
243 <<
"Currently not able to handle coordinate: " << coord <<
" (" << paramNum <<
") " 244 << Form(
" %s with ID %d (subdet %d)", alignableObjectId.idToString(
type),
id,
DetId(
id).
subdetId())
250 <<
" alignableLabel: " << alignableLabel <<
" with alignableIndex " << alignableIndex <<
" detIndex " 252 <<
" i.e. detLabel: " <<
detLabel <<
" (" << coord <<
")\n" 253 <<
" has movement: " << ObsMove <<
" +/- " << ObsErr <<
"\n" 254 <<
" cutoff (cutoffs_[" <<
detLabel <<
"][" << coord <<
"]): " << cutoffs_[
detLabel][alignableIndex] <<
"\n" 255 <<
" significance (significances_[" <<
detLabel <<
"][" << coord
256 <<
"]): " << significances_[
detLabel][alignableIndex] <<
"\n" 257 <<
" error thresolds (errors_[" <<
detLabel <<
"][" << coord <<
"]): " << errors_[
detLabel][alignableIndex]
259 <<
" max movement (thresholds_[" <<
detLabel <<
"][" << coord
260 <<
"]): " << thresholds_[
detLabel][alignableIndex] <<
"\n" 261 <<
" fraction (fractions_[" <<
detLabel <<
"][" << coord <<
"]): " << fractions_[
detLabel][alignableIndex]
263 <<
"=============" << std::endl;
267 <<
" Exceeding maximum thresholds for movement: " <<
std::abs(ObsMove)
268 <<
" for" <<
detLabel <<
"(" << coord <<
")";
278 <<
" Exceeding maximum thresholds for error: " <<
std::abs(ObsErr)
279 <<
" for" <<
detLabel <<
"(" << coord <<
")";
284 if (
std::abs(ObsMove / ObsErr) < significances_[
detLabel][alignableIndex]) {
292 <<
"This correction: " << ObsMove <<
"+/-" << ObsErr <<
" for " <<
detLabel <<
"(" << coord
293 <<
") will trigger a new Tracker Alignment payload!";
295 countsAbove_[
detLabel][alignableIndex]++;
300 edm::LogError(
"MillePedeFileReader") <<
"Could not read millepede result-file.";
308 std::stringstream
ss;
309 for (
auto& ali : alignables_) {
310 ss << ali << std::endl;
311 for (
long unsigned int i = 0;
i < countsTotal_[ali].size();
i++) {
312 if (countsTotal_[ali][
i] != 0 && fractions_[ali][
i] != -1) {
313 float fraction_ = countsAbove_[ali][
i] / (1.0 * countsTotal_[ali][
i]);
314 ss << static_cast<AlignPCLThresholdsHG::coordType>(
i) <<
": Fraction = " << fraction_
315 <<
" Fraction Threshold = " << fractions_[ali][
i];
316 if (fraction_ >= fractions_[ali][
i]) {
318 ss <<
" above fraction threshold" << std::endl;
325 ss <<
"No entries available or no fraction thresholds defined" << std::endl;
327 ss <<
"===================" << std::endl;
330 ss <<
"Alignment will be updated" << std::endl;
332 ss <<
"Alignment will NOT be updated" << std::endl;
342 const auto& tns =
pedeLabeler_->alignableTracker()->trackerNameSpace();
347 switch (tns.tpb().halfBarrelNumber(
id)) {
354 <<
"@SUB=MillePedeFileReader::getHLS\n" 355 <<
"Found a pixel half-barrel number that should not exist: " << tns.tpb().halfBarrelNumber(
id);
358 switch (tns.tpe().endcapNumber(
id)) {
360 switch (tns.tpe().halfCylinderNumber(
id)) {
367 <<
"@SUB=MillePedeFileReader::getHLS\n" 368 <<
"Found a pixel half-cylinder number that should not exist: " << tns.tpe().halfCylinderNumber(
id);
371 switch (tns.tpe().halfCylinderNumber(
id)) {
378 <<
"@SUB=MillePedeFileReader::getHLS\n" 379 <<
"Found a pixel half-cylinder number that should not exist: " << tns.tpe().halfCylinderNumber(
id);
383 <<
"@SUB=MillePedeFileReader::getHLS\n" 384 <<
"Found a pixel endcap number that should not exist: " << tns.tpe().endcapNumber(
id);
387 switch (tns.tpb().layerNumber(
id)) {
398 <<
"@SUB=MillePedeFileReader::getHLS\n" 399 <<
"Found a pixel layer number that should not exist: " << tns.tpb().layerNumber(
id);
402 switch (static_cast<signed int>((tns.tpe().endcapNumber(
id) == 1) ? -1 * tns.tpe().halfDiskNumber(
id)
403 : tns.tpe().halfDiskNumber(
id))) {
418 <<
"@SUB=MillePedeFileReader::getHLS\n" 419 <<
"Found a pixel disk number that should not exist: " 420 <<
static_cast<signed int>((tns.tpe().endcapNumber(
id) == 1) ? -1 * tns.tpe().halfDiskNumber(
id)
421 : tns.tpe().halfDiskNumber(
id));
431 return "TPBHalfBarrelXminus";
433 return "TPBHalfBarrelXplus";
435 return "TPEHalfCylinderXminusZminus";
437 return "TPEHalfCylinderXplusZminus";
439 return "TPEHalfCylinderXminusZplus";
441 return "TPEHalfCylinderXplusZplus";
443 return "TPBLadderLayer1";
445 return "TPBLadderLayer2";
447 return "TPBLadderLayer3";
449 return "TPBLadderLayer4";
451 return "TPEPanelDisk1";
453 return "TPEPanelDisk2";
455 return "TPEPanelDisk3";
457 return "TPEPanelDiskM1";
459 return "TPEPanelDiskM2";
461 return "TPEPanelDiskM3";
465 <<
"@SUB=MillePedeFileReader::getStringFromHLS\n" 466 <<
"Found an alignable structure not possible to map in the default AlignPCLThresholdsHG partitions";
474 std::make_pair(currentSum, currentSum +
pixelTopologyMap_->getPXBLadders(1) / 2);
477 std::make_pair(currentSum, currentSum +
pixelTopologyMap_->getPXBLadders(2) / 2);
480 std::make_pair(currentSum, currentSum +
pixelTopologyMap_->getPXBLadders(3) / 2);
483 std::make_pair(currentSum, currentSum +
pixelTopologyMap_->getPXBLadders(4) / 2);
502 const auto& tns =
pedeLabeler_->alignableTracker()->trackerNameSpace();
506 return (tns.tpb().halfBarrelNumber(
id) == 1) ? tns.tpb().ladderNumber(
id) +
indexHelper[HLS].first
507 : tns.tpb().ladderNumber(
id) +
indexHelper[HLS].second;
509 return (tns.tpb().halfBarrelNumber(
id) == 1) ? tns.tpb().ladderNumber(
id) +
indexHelper[HLS].first
510 : tns.tpb().ladderNumber(
id) +
indexHelper[HLS].second;
512 return (tns.tpb().halfBarrelNumber(
id) == 1) ? tns.tpb().ladderNumber(
id) +
indexHelper[HLS].first
513 : tns.tpb().ladderNumber(
id) +
indexHelper[HLS].second;
515 return (tns.tpb().halfBarrelNumber(
id) == 1) ? tns.tpb().ladderNumber(
id) +
indexHelper[HLS].first
516 : tns.tpb().ladderNumber(
id) +
indexHelper[HLS].second;
518 return (tns.tpe().halfCylinderNumber(
id) == 1)
519 ? (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].first
520 : (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].second;
522 return (tns.tpe().halfCylinderNumber(
id) == 1)
523 ? (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].first
524 : (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].second;
526 return (tns.tpe().halfCylinderNumber(
id) == 1)
527 ? (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].first
528 : (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].second;
530 return (tns.tpe().halfCylinderNumber(
id) == 1)
531 ? (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].first
532 : (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].second;
534 return (tns.tpe().halfCylinderNumber(
id) == 1)
535 ? (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].first
536 : (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].second;
538 return (tns.tpe().halfCylinderNumber(
id) == 1)
539 ? (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].first
540 : (tns.tpe().bladeNumber(
id) * 2 - (tns.tpe().panelNumber(
id) % 2)) +
indexHelper[HLS].second;
std::array< double, SIZE_LG_STRUCTS > Zobs_
Log< level::Info, true > LogVerbatim
MillePedeFileReader(const edm::ParameterSet &, const std::shared_ptr< const PedeLabelerBase > &, const std::shared_ptr< const AlignPCLThresholdsHG > &, const std::shared_ptr< const PixelTopologyMap > &)
std::array< double, SIZE_HG_STRUCTS > tXobs_HG_
std::array< double, SIZE_LG_STRUCTS > tYobs_
std::array< double, SIZE_LG_STRUCTS > tZobsErr_
std::array< double, SIZE_LG_STRUCTS > Yobs_
const std::shared_ptr< const AlignPCLThresholdsHG > theThresholds_
std::array< double, SIZE_HG_STRUCTS > XobsErr_HG_
std::bitset< 4 > updateBits_
std::array< double, SIZE_LG_STRUCTS > YobsErr_
std::array< double, SIZE_HG_STRUCTS > YobsErr_HG_
const std::shared_ptr< const PixelTopologyMap > pixelTopologyMap_
PclHLS getHLS(const Alignable *)
Log< level::Error, false > LogError
void readMillePedeLogFile()
std::array< double, SIZE_HG_STRUCTS > Zobs_HG_
std::array< double, SIZE_LG_STRUCTS > Xobs_
static constexpr std::array< double, 6 > multiplier_
std::array< double, SIZE_HG_STRUCTS > Xobs_HG_
std::array< double, SIZE_HG_STRUCTS > tYobs_HG_
const std::string millePedeLogFile_
std::array< double, SIZE_LG_STRUCTS > tXobs_
void initializeIndexHelper()
void readMillePedeResultFile()
std::array< double, SIZE_LG_STRUCTS > tYobsErr_
std::array< double, SIZE_HG_STRUCTS > ZobsErr_HG_
virtual StructureType alignableObjectId() const =0
Return the alignable type identifier.
Abs< T >::type abs(const T &t)
std::array< double, SIZE_HG_STRUCTS > tZobs_HG_
Allows conversion between type and name, and vice-versa.
constexpr int subdetId() const
get the contents of the subdetector field (not cast into any detector's numbering enum) ...
std::string getStringFromHLS(PclHLS HLS)
Log< level::Info, false > LogInfo
align::ID id() const
Return the ID of Alignable, i.e. DetId of 'first' component GeomDet(Unit).
const std::string millePedeResFile_
std::array< double, SIZE_LG_STRUCTS > tXobsErr_
std::unordered_map< PclHLS, std::pair< int, int > > indexHelper
std::array< double, SIZE_HG_STRUCTS > tZobsErr_HG_
std::array< double, SIZE_LG_STRUCTS > XobsErr_
int getIndexForHG(align::ID id, PclHLS HLS)
const std::shared_ptr< const PedeLabelerBase > pedeLabeler_
const std::string millePedeEndFile_
std::array< double, SIZE_HG_STRUCTS > tXobsErr_HG_
std::array< double, SIZE_HG_STRUCTS > Yobs_HG_
void readMillePedeEndFile()
std::array< double, SIZE_LG_STRUCTS > tZobs_
std::map< std::string, std::array< bool, 6 > > fractionExceeded_
Log< level::Warning, false > LogWarning
std::array< double, SIZE_LG_STRUCTS > ZobsErr_
std::array< double, SIZE_HG_STRUCTS > tYobsErr_HG_