[poincare] Avoid infinite loop in binomial/permute coefficients

Change-Id: I528bf2a4fcfb269511aa9128990807524e9c3945
This commit is contained in:
Émilie Feral
2017-12-04 17:46:41 +01:00
parent 1edd7ac095
commit 9efba84ba9
2 changed files with 2 additions and 2 deletions

View File

@@ -100,7 +100,7 @@ Expression * BinomialCoefficient::templatedApproximate(Context& context, AngleUn
T result = 1;
for (int i = 0; i < k; i++) {
result *= (n-(T)i)/(k-(T)i);
if (std::isinf(result)) {
if (std::isinf(result) || std::isnan(result)) {
return new Complex<T>(Complex<T>::Float(result));
}
}

View File

@@ -87,7 +87,7 @@ Complex<T> * PermuteCoefficient::templatedApproximate(Context& context, AngleUni
T result = 1;
for (int i = (int)n-(int)k+1; i <= (int)n; i++) {
result *= i;
if (std::isinf(result)) {
if (std::isinf(result) || std::isnan(result)) {
return new Complex<T>(Complex<T>::Float(result));
}
}