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
#include "DPGAnalysis/HcalNanoAOD/interface/QIE11DigiSortedTable.h"

QIE11DigiSortedTable::QIE11DigiSortedTable(const std::vector<HcalDetId>& dids, const unsigned int nTS) {
  dids_ = dids;
  for (std::vector<HcalDetId>::const_iterator it_did = dids_.begin(); it_did != dids_.end(); ++it_did) {
    did_indexmap_[*it_did] = (unsigned int)(it_did - dids_.begin());
  }

  nTS_ = nTS;
  ietas_.resize(dids_.size());
  iphis_.resize(dids_.size());
  subdets_.resize(dids_.size());
  depths_.resize(dids_.size());
  rawIds_.resize(dids_.size());
  linkErrors_.resize(dids_.size());
  capidErrors_.resize(dids_.size());
  flags_.resize(dids_.size());
  sois_.resize(dids_.size());
  valids_.resize(dids_.size());
  sipmTypes_.resize(dids_.size());

  adcs_.resize(nTS_, std::vector<int>(dids_.size()));
  fcs_.resize(nTS_, std::vector<float>(dids_.size()));
  pedestalfcs_.resize(nTS_, std::vector<float>(dids_.size()));
  tdcs_.resize(nTS_, std::vector<int>(dids_.size()));
  capids_.resize(nTS_, std::vector<int>(dids_.size()));
}

void QIE11DigiSortedTable::add(const QIE11DataFrame* digi, const edm::ESHandle<HcalDbService>& dbService) {
  HcalDetId did = digi->detid();
  unsigned int index = did_indexmap_.at(did);

  CaloSamples digiCaloSamples = hcaldqm::utilities::loadADC2fCDB<QIE11DataFrame>(dbService, did, *digi);
  HcalCalibrations calibrations = dbService->getHcalCalibrations(did);

  ietas_[index] = did.ieta();
  iphis_[index] = did.iphi();
  subdets_[index] = did.subdet();
  depths_[index] = did.depth();
  rawIds_[index] = did.rawId();
  linkErrors_[index] = digi->linkError();
  capidErrors_[index] = digi->capidError();
  flags_[index] = digi->flags();
  sipmTypes_[index] = (uint8_t)dbService->getHcalSiPMParameter(did)->getType();

  for (unsigned int iTS = 0; iTS < (unsigned int)digi->samples(); ++iTS) {
    if ((*digi)[iTS].soi()) {
      sois_[index] = iTS;
    }
    adcs_[iTS][index] = (*digi)[iTS].adc();
    tdcs_[iTS][index] = (*digi)[iTS].tdc();
    capids_[iTS][index] = (*digi)[iTS].capid();
    fcs_[iTS][index] = digiCaloSamples[iTS];
    pedestalfcs_[iTS][index] = calibrations.pedestal((*digi)[iTS].capid());
  }
  valids_[index] = true;
}

void QIE11DigiSortedTable::reset() {
  std::fill(ietas_.begin(), ietas_.end(), 0);
  std::fill(iphis_.begin(), iphis_.end(), 0);
  std::fill(subdets_.begin(), subdets_.end(), 0);
  std::fill(depths_.begin(), depths_.end(), 0);
  std::fill(rawIds_.begin(), rawIds_.end(), 0);
  std::fill(linkErrors_.begin(), linkErrors_.end(), false);
  std::fill(capidErrors_.begin(), capidErrors_.end(), false);
  std::fill(flags_.begin(), flags_.end(), 0);
  std::fill(sois_.begin(), sois_.end(), 0);
  std::fill(valids_.begin(), valids_.end(), false);
  std::fill(sipmTypes_.begin(), sipmTypes_.end(), 0);

  for (auto& it : adcs_) {
    std::fill(it.begin(), it.end(), 0);
  }
  for (auto& it : fcs_) {
    std::fill(it.begin(), it.end(), 0);
  }
  for (auto& it : pedestalfcs_) {
    std::fill(it.begin(), it.end(), 0);
  }
  for (auto& it : tdcs_) {
    std::fill(it.begin(), it.end(), 0);
  }
  for (auto& it : capids_) {
    std::fill(it.begin(), it.end(), 0);
  }
}