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 56 57 58 59 60 61 62
#include "CondFormats/SiStripObjects/interface/SiStripBaseDelay.h"

#include <algorithm>
#include <iterator>
#include <iostream>
#include <sstream>

bool SiStripBaseDelay::put(const uint32_t detId, const uint16_t coarseDelay, const uint16_t fineDelay) {
  delays_.push_back(Delay(detId, coarseDelay, fineDelay));
  return true;
}

uint16_t SiStripBaseDelay::coarseDelay(const uint32_t detId) {
  delayConstIt it = std::find_if(delays_.begin(), delays_.end(), [&](auto& x) { return x.detId == detId; });
  if (it != delays_.end()) {
    return it->coarseDelay;
  }
  return 0;
}

uint16_t SiStripBaseDelay::fineDelay(const uint32_t detId) const {
  delayConstIt it = std::find_if(delays_.begin(), delays_.end(), [&](auto& x) { return x.detId == detId; });
  if (it != delays_.end()) {
    return it->fineDelay;
  }
  return 0;
}

double SiStripBaseDelay::delay(const uint32_t detId) const {
  delayConstIt it = std::find_if(delays_.begin(), delays_.end(), [&](auto& x) { return x.detId == detId; });
  if (it != delays_.end()) {
    return makeDelay(it->coarseDelay, it->fineDelay);
  }
  return 0;
}

void SiStripBaseDelay::detIds(std::vector<uint32_t>& detIdVector) const {
  std::vector<Delay>::const_iterator it = delays_.begin();
  for (; it != delays_.end(); ++it) {
    detIdVector.push_back(it->detId);
  }
}

void SiStripBaseDelay::printSummary(std::stringstream& ss, const TrackerTopology* trackerTopo) const {
  ss << "Total number of delays = " << delays_.size() << std::endl;
  SiStripDetSummary summaryDelays{trackerTopo};
  delayConstIt it = delays_.begin();
  for (; it != delays_.end(); ++it) {
    summaryDelays.add(it->detId, makeDelay(it->coarseDelay, it->fineDelay));
  }
  ss << std::endl << "Summary:" << std::endl;
  summaryDelays.print(ss);
}

void SiStripBaseDelay::printDebug(std::stringstream& ss, const TrackerTopology* trackerTopo) const {
  printSummary(ss, trackerTopo);
  delayConstIt it = delays_.begin();
  ss << std::endl << "All pedestal values:" << std::endl;
  for (; it != delays_.end(); ++it) {
    ss << "detId = " << it->detId << " delay = " << makeDelay(it->coarseDelay, it->fineDelay) << std::endl;
  }
}