Skip to content

Commit

Permalink
Use std::floor instead of casting double -> int -> double
Browse files Browse the repository at this point in the history
This is the correct way to round down floating point numbers:

https://en.cppreference.com/w/cpp/numeric/math/floor

Closes cms-analysis#945.
  • Loading branch information
guitargeek authored and anigamova committed Nov 21, 2024
1 parent 7c8888a commit 865a330
Showing 1 changed file with 2 additions and 2 deletions.
4 changes: 2 additions & 2 deletions src/CMSHistErrorPropagator.cc
Original file line number Diff line number Diff line change
Expand Up @@ -341,7 +341,7 @@ RooArgList * CMSHistErrorPropagator::setupBinPars(double poissonThreshold) {
}

// Now check if we are below the poisson threshold
double n = int(0.5 + ((sub_sum * sub_sum) / (sub_err * sub_err)));
double n = std::floor(0.5 + ((sub_sum * sub_sum) / (sub_err * sub_err)));
double alpha = valsum_[j] / n;
std::cout << TString::Format(
"%-10i %-15f %-15f %-30s\n", j, n, std::sqrt(n),
Expand Down Expand Up @@ -373,7 +373,7 @@ RooArgList * CMSHistErrorPropagator::setupBinPars(double poissonThreshold) {
std::cout << TString::Format(" %-30s\n", "=> Cannot handle negative content, ignore");
bintypes_[j][i] = 4;
} else if (v_p > 0. && e_p > 0. && v_p >= (e_p*0.999)) {
double n_p_r = int(0.5 + ((v_p * v_p) / (e_p * e_p)));
double n_p_r = std::floor(0.5 + ((v_p * v_p) / (e_p * e_p)));
double alpha_p_r = v_p / n_p_r;
std::cout << TString::Format(
" %-20s %-15f %-15f %-30s\n", "", n_p_r, std::sqrt(n_p_r),
Expand Down

0 comments on commit 865a330

Please sign in to comment.