SiStripHitEffData

Macros

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 63 64 65 66 67 68 69 70
#ifndef CalibTracker_SiStripHitEfficiency_SiStripHitEffData_h
#define CalibTracker_SiStripHitEfficiency_SiStripHitEffData_h

#include "DQM/SiStripCommon/interface/TkHistoMap.h"
#include "DQMServices/Core/interface/DQMStore.h"
#include "DQMServices/Core/interface/MonitorElement.h"
#include <unordered_map>

struct SiStripHitEffData {
public:
  SiStripHitEffData() : EventStats(), FEDErrorOccupancy(nullptr), m_isLoaded(false) {}

  void fillTkMapFromMap() {
    for (const auto& [id, count] : fedErrorCounts) {
      FEDErrorOccupancy->fill(id, count);
    }
  }

  void fillMapFromTkMap(const int nevents, const float threshold, const std::vector<DetId>& stripDetIds) {
    const auto& Maps = FEDErrorOccupancy->getAllMaps();
    std::vector<bool> isThere;
    isThere.reserve(Maps.size());
    std::transform(Maps.begin() + 1, Maps.end(), std::back_inserter(isThere), [](auto& x) { return !(x == nullptr); });

    int count{0};
    for (const auto& it : isThere) {
      count++;
      LogTrace("SiStripHitEffData") << " layer: " << count << " " << it << std::endl;
      if (it)
        LogTrace("SiStripHitEffData") << "resolving to " << Maps[count]->getName()
                                      << " with entries: " << Maps[count]->getEntries() << std::endl;
      // color the map
      Maps[count]->setOption("colz");
    }

    for (const auto& det : stripDetIds) {
      const auto& counts = FEDErrorOccupancy->getValue(det);

      if (counts > 0) {
        float fraction = counts / nevents;

        LogTrace("SiStripHitEffData") << det.rawId() << " has " << counts << " counts, " << fraction * 100
                                      << "% fraction of the " << nevents << " events processed" << std::endl;

        if (fraction > threshold) {
          fedErrorCounts.insert(std::make_pair(det, 1));
        }
      }  // do not check functioning modules
    }
    // the map has been loaded
    m_isLoaded = true;
  }

  const bool checkFedError(const DetId det) {
    if (m_isLoaded) {
      return (fedErrorCounts.find(det) == fedErrorCounts.end());
    } else {
      throw cms::Exception("LogicError") << __PRETTY_FUNCTION__ << "cannot check DetId when map not filled";
    }
  }

  dqm::reco::MonitorElement* EventStats;
  std::unordered_map<uint32_t, int> fedErrorCounts;
  std::unique_ptr<TkHistoMap> FEDErrorOccupancy;

private:
  bool m_isLoaded;
};

#endif