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 71 72 73 74 75 76 77 78 79 80 81 82 83 84 85 86 87 88 89 90 91 92 93 94 95 96 97
#include "DQM/SiStripCommissioningSources/interface/VpspScanTask.h"
#include "DataFormats/SiStripCommon/interface/SiStripConstants.h"
#include "DataFormats/SiStripCommon/interface/SiStripFecKey.h"
#include "DataFormats/SiStripCommon/interface/SiStripHistoTitle.h"
#include "DQMServices/Core/interface/DQMStore.h"
#include "FWCore/MessageLogger/interface/MessageLogger.h"
#include <algorithm>

using namespace sistrip;

// -----------------------------------------------------------------------------
//
VpspScanTask::VpspScanTask(DQMStore* dqm, const FedChannelConnection& conn)
    : CommissioningTask(dqm, conn, "VpspScanTask"), vpsp_() {}

// -----------------------------------------------------------------------------
//
VpspScanTask::~VpspScanTask() {}

// -----------------------------------------------------------------------------
//
void VpspScanTask::book() {
  uint16_t nbins = 60;

  std::string title;

  vpsp_.resize(2);
  for (uint16_t iapv = 0; iapv < 2; iapv++) {
    if (connection().i2cAddr(iapv)) {
      std::stringstream extra_info;
      extra_info << sistrip::apv_ << iapv;

      title = SiStripHistoTitle(sistrip::EXPERT_HISTO,
                                sistrip::VPSP_SCAN,
                                sistrip::FED_KEY,
                                fedKey(),
                                sistrip::LLD_CHAN,
                                connection().lldChannel(),
                                extra_info.str())
                  .title();

      vpsp_[iapv].histo(dqm()->bookProfile(title, title, nbins, -0.5, nbins * 1. - 0.5, 1025, 0., 1025.));

      vpsp_[iapv].vNumOfEntries_.resize(nbins, 0);
      vpsp_[iapv].vSumOfContents_.resize(nbins, 0);
      vpsp_[iapv].vSumOfSquares_.resize(nbins, 0);
    }
  }
}

// -----------------------------------------------------------------------------
//
void VpspScanTask::fill(const SiStripEventSummary& summary, const edm::DetSet<SiStripRawDigi>& digis) {
  // Retrieve VPSP setting and CCU channel
  uint32_t vpsp = summary.vpsp();
  uint32_t ccu_chan = summary.vpspCcuChan();

  // Check CCU channel from EventSummary is consistent with this module
  if (SiStripFecKey(fecKey()).ccuChan() != ccu_chan) {
    return;
  }

  if (digis.data.size() != 256) {
    edm::LogWarning(mlDqmSource_) << "[VpspScanTask::" << __func__ << "]"
                                  << " Unexpected number of digis! " << digis.data.size();
    return;
  }

  // Fill histo with baseline(calc'ed from median value of data)
  for (uint16_t iapv = 0; iapv < 2; iapv++) {
    if (vpsp >= vpsp_[iapv].vNumOfEntries_.size()) {
      edm::LogWarning(mlDqmSource_) << "[VpspScanTask::" << __func__ << "]"
                                    << " Unexpected VPSP value! " << vpsp;
      return;
    }

    std::vector<uint16_t> baseline;
    baseline.reserve(128);
    for (uint16_t idigi = 128 * iapv; idigi < 128 * (iapv + 1); idigi++) {
      baseline.push_back(digis.data[idigi].adc());
    }
    sort(baseline.begin(), baseline.end());
    uint16_t index = baseline.size() % 2 ? baseline.size() / 2 : baseline.size() / 2 - 1;

    if (!baseline.empty()) {
      updateHistoSet(vpsp_[iapv], vpsp, baseline[index]);
    }
  }
}

// -----------------------------------------------------------------------------
//
void VpspScanTask::update() {
  for (uint32_t iapv = 0; iapv < vpsp_.size(); iapv++) {
    updateHistoSet(vpsp_[iapv]);
  }
}