Skip to content

Commit

Permalink
Merge pull request #46544 from hjbossi/PRfor_14_1_X_HCALLUTScaling
Browse files Browse the repository at this point in the history
[14_1_X] Backport of modifications to make ZDC trigger spacing configurable with TP channel parameters.
  • Loading branch information
cmsbuild authored Nov 2, 2024
2 parents 6e2aeb3 + 38697ae commit d54f536
Show file tree
Hide file tree
Showing 2 changed files with 22 additions and 12 deletions.
1 change: 0 additions & 1 deletion CalibCalorimetry/HcalTPGAlgos/interface/HcaluLUTTPGCoder.h
Original file line number Diff line number Diff line change
Expand Up @@ -32,7 +32,6 @@ class HcalDbService;
class HcaluLUTTPGCoder : public HcalTPGCoder {
public:
static const float lsb_;
static const float zdc_lsb_;

HcaluLUTTPGCoder();
HcaluLUTTPGCoder(const HcalTopology* topo, const HcalTimeSlew* delay);
Expand Down
33 changes: 22 additions & 11 deletions CalibCalorimetry/HcalTPGAlgos/src/HcaluLUTTPGCoder.cc
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,7 @@
#include <fstream>
#include <cmath>
#include <string>
#include <algorithm>
#include "CalibCalorimetry/HcalTPGAlgos/interface/HcaluLUTTPGCoder.h"
#include "CalibFormats/HcalObjects/interface/HcalCoderDb.h"
#include "CalibFormats/HcalObjects/interface/HcalCalibrations.h"
Expand Down Expand Up @@ -29,7 +30,6 @@
#include "CalibCalorimetry/HcalTPGAlgos/interface/LutXml.h"

const float HcaluLUTTPGCoder::lsb_ = 1. / 16;
const float HcaluLUTTPGCoder::zdc_lsb_ = 50.;

const int HcaluLUTTPGCoder::QIE8_LUT_BITMASK;
const int HcaluLUTTPGCoder::QIE10_LUT_BITMASK;
Expand Down Expand Up @@ -275,10 +275,10 @@ void HcaluLUTTPGCoder::update(const char* filename, bool appendMSB) {
} else
inputLUT_[lutId][adc] = lutFromFile[i][adc];
} // for adc
} // for depth
} // for iphi
} // for ieta
} // for nCol
} // for depth
} // for iphi
} // for ieta
} // for nCol
}

void HcaluLUTTPGCoder::updateXML(const char* filename) {
Expand Down Expand Up @@ -595,10 +595,21 @@ void HcaluLUTTPGCoder::update(const HcalDbService& conditions) {
const HcalLutMetadatum* meta = metadata->getValues(cell);

auto tpParam = conditions.getHcalTPChannelParameter(cell, false);
int weight = tpParam->getauxi1();
const int weight = tpParam->getauxi1();
int factorGeVPerCount = tpParam->getauxi2();
if (factorGeVPerCount == 0) {
edm::LogWarning("HcaluLUTTPGCoder")
<< "WARNING: ZDC trigger spacing factor, taken from auxi2 field of HCALTPChannelParameters for the cell "
"with (zside, section, channel) = ("
<< cell.zside() << " , " << cell.section() << " , " << cell.channel()
<< ") is set to the "
"default value of 0, which is an incompatible value for a spacing factor. Setting the value to 50 and "
"continuing.";
factorGeVPerCount = 50;
}

int lutId = getLUTId(cell);
int lutId_ootpu = lutId + sizeZDC_;
const int lutId = getLUTId(cell);
const int lutId_ootpu = lutId + sizeZDC_;
Lut& lut = inputLUT_[lutId];
Lut& lut_ootpu = inputLUT_[lutId_ootpu];
float ped = 0;
Expand Down Expand Up @@ -656,9 +667,9 @@ void HcaluLUTTPGCoder::update(const HcalDbService& conditions) {
lut[adc] = 0;
lut_ootpu[adc] = 0;
} else {
lut[adc] = std::min(std::max(0, int((adc2fC(adc) - ped) * gain * rcalib / zdc_lsb_)), MASK);
lut_ootpu[adc] =
std::min(std::max(0, int((adc2fC(adc) - ped) * gain * rcalib * weight / (zdc_lsb_ * 256))), MASK);
auto lut_term = (adc2fC(adc) - ped) * gain * rcalib / factorGeVPerCount;
lut[adc] = std::clamp(int(lut_term), 0, MASK);
lut_ootpu[adc] = std::clamp(int(lut_term * weight / 256), 0, MASK);
}
}
}
Expand Down

0 comments on commit d54f536

Please sign in to comment.