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
#include "DataFormats/HcalRecHit/interface/HFPreRecHit.h"

std::pair<float, bool> HFPreRecHit::chargeAsymmetry(const float chargeThreshold) const {
  std::pair<float, bool> result(0.f, false);
  if (hasInfo_[0] && hasInfo_[1]) {
    const float q0 = hfQIE10Info_[0].charge();
    const float q1 = hfQIE10Info_[1].charge();
    const float qsum = q0 + q1;
    if (qsum > 0.f && qsum >= chargeThreshold) {
      result.first = (q1 - q0) / qsum;
      result.second = true;
    }
  }
  return result;
}

std::pair<float, bool> HFPreRecHit::energyAsymmetry(const float energyThreshold) const {
  std::pair<float, bool> result(0.f, false);
  if (hasInfo_[0] && hasInfo_[1]) {
    const float e0 = hfQIE10Info_[0].energy();
    const float e1 = hfQIE10Info_[1].energy();
    const float esum = e0 + e1;
    if (esum > 0.f && esum >= energyThreshold) {
      result.first = (e1 - e0) / esum;
      result.second = true;
    }
  }
  return result;
}