Skip to content

Commit

Permalink
avoid division by 0 (#132)
Browse files Browse the repository at this point in the history
  • Loading branch information
giovannimarchiori authored Nov 16, 2024
1 parent 6e45712 commit ec34380
Showing 1 changed file with 32 additions and 20 deletions.
52 changes: 32 additions & 20 deletions RecFCCeeCalorimeter/src/components/AugmentClustersFCCee.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -294,7 +294,6 @@ StatusCode AugmentClustersFCCee::execute([[maybe_unused]] const EventContext &ev
nCells++;
} // end of loop over cells
} // end of loop over system / readout
//std::cout << "Ecl = " << E << std::endl;

// any number close to two pi should do, because if a cluster contains
// the -pi<->pi transition, phiMin should be close to -pi and phiMax close to pi
Expand Down Expand Up @@ -615,29 +614,32 @@ StatusCode AugmentClustersFCCee::execute([[maybe_unused]] const EventContext &ev

int systemID = m_systemIDs[k];
// loop over layers
for (unsigned layer = 0; layer < m_numLayers[k]; layer++)
{
for (unsigned layer = 0; layer < m_numLayers[k]; layer++) {
// theta
if (m_thetaRecalcLayerWeights[k][layer]<0)
{
if (sumEnLayer[layer+startPositionToFill] != 0.0)
{
if (m_thetaRecalcLayerWeights[k][layer]<0) {
if (sumEnLayer[layer+startPositionToFill] != 0.0) {
sumThetaLayer[layer+startPositionToFill] /= sumEnLayer[layer+startPositionToFill];
}
else {
sumThetaLayer[layer+startPositionToFill] = 0.;
}
}
else
{
if (sumWeightLayer[layer+startPositionToFill] != 0.0)
{
else {
if (sumWeightLayer[layer+startPositionToFill] != 0.0) {
sumThetaLayer[layer+startPositionToFill] /= sumWeightLayer[layer+startPositionToFill];
}
else {
sumThetaLayer[layer+startPositionToFill] = 0.;
}
}

// phi
if (sumEnLayer[layer+startPositionToFill] != 0.0)
{
if (sumEnLayer[layer+startPositionToFill] != 0.0) {
sumPhiLayer[layer+startPositionToFill] /= sumEnLayer[layer+startPositionToFill];
}
else {
sumPhiLayer[layer+startPositionToFill] = 0.;
}
// make sure phi is in range -pi..pi
if (sumPhiLayer[layer+startPositionToFill] > TMath::Pi())
sumPhiLayer[layer+startPositionToFill] -= TMath::TwoPi();
Expand All @@ -649,18 +651,24 @@ StatusCode AugmentClustersFCCee::execute([[maybe_unused]] const EventContext &ev
// do pi0/photon shape var only for EMB
if (m_do_photon_shapeVar && systemID == systemID_EMB) {
if (m_do_widthTheta_logE_weights) {
double w_theta2 = theta2_E_layer[layer+startPositionToFill] / sumWeightLayer[layer+startPositionToFill] - std::pow(theta_E_layer[layer+startPositionToFill] / sumWeightLayer[layer+startPositionToFill], 2);
double w_theta2(0.0);
if (sumWeightLayer[layer+startPositionToFill] != 0.) {
w_theta2 = theta2_E_layer[layer+startPositionToFill] / sumWeightLayer[layer+startPositionToFill] - std::pow(theta_E_layer[layer+startPositionToFill] / sumWeightLayer[layer+startPositionToFill], 2);
}
// Negative values can happen when noise is on and not filtered
// Negative values very close to zero can happen due to numerical precision
if (w_theta2 < 0.) {
PrintDebugMessage(warning(), "w_theta2 in theta width calculation is negative: " + std::to_string(w_theta2) + " , will set theta width to zero (this might happen when noise simulation is on)");
PrintDebugMessage(warning(), "w_theta2 in theta width calculation is negative: " + std::to_string(w_theta2) + " , will set theta width to zero (this might happen when noise simulation is on)");
width_theta[layer+startPositionToFill] = 0.;
}
else {
width_theta[layer+startPositionToFill] = std::sqrt(w_theta2);
}
} else {
double w_theta2 = theta2_E_layer[layer+startPositionToFill] / sumEnLayer[layer+startPositionToFill] - std::pow(theta_E_layer[layer+startPositionToFill] / sumEnLayer[layer+startPositionToFill], 2);
double w_theta2(0.0);
if (sumEnLayer[layer+startPositionToFill] != 0.) {
w_theta2 = theta2_E_layer[layer+startPositionToFill] / sumEnLayer[layer+startPositionToFill] - std::pow(theta_E_layer[layer+startPositionToFill] / sumEnLayer[layer+startPositionToFill], 2);
}
// Negative values can happen when noise is on and not filtered
// Negative values very close to zero can happen due to numerical precision
if (w_theta2 < 0.) {
Expand All @@ -671,7 +679,11 @@ StatusCode AugmentClustersFCCee::execute([[maybe_unused]] const EventContext &ev
width_theta[layer+startPositionToFill] = std::sqrt(w_theta2);
}
}
double w_module2 = module2_E_layer[layer+startPositionToFill] / sumEnLayer[layer+startPositionToFill] - std::pow(module_E_layer[layer+startPositionToFill] / sumEnLayer[layer+startPositionToFill], 2);
double w_module2(0.0);
if (sumEnLayer[layer+startPositionToFill] != 0.)
{
w_module2 = module2_E_layer[layer+startPositionToFill] / sumEnLayer[layer+startPositionToFill] - std::pow(module_E_layer[layer+startPositionToFill] / sumEnLayer[layer+startPositionToFill], 2);
}
// Negative values can happen when noise is on and not filtered
// Negative values very close to zero can happen due to numerical precision
if (w_module2 < 0) {
Expand Down Expand Up @@ -837,21 +849,21 @@ StatusCode AugmentClustersFCCee::execute([[maybe_unused]] const EventContext &ev
width_theta_3Bin[layer+startPositionToFill] = std::sqrt(_w_theta_3Bin2);
}
if (_w_theta_5Bin2 < 0) {
PrintDebugMessage(warning(), "_w_theta_5Bin2 in theta width calculation is negative: " + std::to_string(_w_theta_5Bin2) + " , will set theta width to zero (this might happen when noise simulation is on)");
PrintDebugMessage(warning(), "_w_theta_5Bin2 in theta width calculation is negative: " + std::to_string(_w_theta_5Bin2) + " , will set theta width to zero (this might happen when noise simulation is on)");
width_theta_5Bin[layer+startPositionToFill] = 0.;
}
else {
width_theta_5Bin[layer+startPositionToFill] = std::sqrt(_w_theta_5Bin2);
}
if (_w_theta_7Bin2 < 0) {
PrintDebugMessage(warning(), "_w_theta_7Bin2 in theta width calculation is negative: " + std::to_string(_w_theta_7Bin2) + " , will set theta width to zero (this might happen when noise simulation is on)");
PrintDebugMessage(warning(), "_w_theta_7Bin2 in theta width calculation is negative: " + std::to_string(_w_theta_7Bin2) + " , will set theta width to zero (this might happen when noise simulation is on)");
width_theta_7Bin[layer+startPositionToFill] = 0.;
}
else {
width_theta_7Bin[layer+startPositionToFill] = std::sqrt(_w_theta_7Bin2);
}
if (_w_theta_9Bin2 < 0) {
PrintDebugMessage(warning(), "_w_theta_9Bin2 in theta width calculation is negative: " + std::to_string(_w_theta_9Bin2) + " , will set theta width to zero (this might happen when noise simulation is on)");
PrintDebugMessage(warning(), "_w_theta_9Bin2 in theta width calculation is negative: " + std::to_string(_w_theta_9Bin2) + " , will set theta width to zero (this might happen when noise simulation is on)");
width_theta_9Bin[layer+startPositionToFill] = 0.;
}
else {
Expand Down

0 comments on commit ec34380

Please sign in to comment.