x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.130605476229999961645944495103321969509 + 11.16675412620000074070958362426608800888\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.2346874069999991263557603815570473671\right) \cdot z + 31.46901157490000144889563671313226222992\right) \cdot z + 11.94009057210000079862766142468899488449\right) \cdot z + 0.6077713877710000378584709324059076607227}\begin{array}{l}
\mathbf{if}\;z \le -3.076810882413635365417964376133599293418 \cdot 10^{56} \lor \neg \left(z \le 128535262688296208\right):\\
\;\;\;\;\mathsf{fma}\left(y, 3.130605476229999961645944495103321969509 + \frac{t}{{z}^{2}}, x\right)\\
\mathbf{else}:\\
\;\;\;\;x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.130605476229999961645944495103321969509 + 11.16675412620000074070958362426608800888\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.2346874069999991263557603815570473671\right) \cdot z + 31.46901157490000144889563671313226222992\right) \cdot z + 11.94009057210000079862766142468899488449\right) \cdot z + 0.6077713877710000378584709324059076607227}\\
\end{array}double f(double x, double y, double z, double t, double a, double b) {
double r212439 = x;
double r212440 = y;
double r212441 = z;
double r212442 = 3.13060547623;
double r212443 = r212441 * r212442;
double r212444 = 11.1667541262;
double r212445 = r212443 + r212444;
double r212446 = r212445 * r212441;
double r212447 = t;
double r212448 = r212446 + r212447;
double r212449 = r212448 * r212441;
double r212450 = a;
double r212451 = r212449 + r212450;
double r212452 = r212451 * r212441;
double r212453 = b;
double r212454 = r212452 + r212453;
double r212455 = r212440 * r212454;
double r212456 = 15.234687407;
double r212457 = r212441 + r212456;
double r212458 = r212457 * r212441;
double r212459 = 31.4690115749;
double r212460 = r212458 + r212459;
double r212461 = r212460 * r212441;
double r212462 = 11.9400905721;
double r212463 = r212461 + r212462;
double r212464 = r212463 * r212441;
double r212465 = 0.607771387771;
double r212466 = r212464 + r212465;
double r212467 = r212455 / r212466;
double r212468 = r212439 + r212467;
return r212468;
}
double f(double x, double y, double z, double t, double a, double b) {
double r212469 = z;
double r212470 = -3.0768108824136354e+56;
bool r212471 = r212469 <= r212470;
double r212472 = 1.2853526268829621e+17;
bool r212473 = r212469 <= r212472;
double r212474 = !r212473;
bool r212475 = r212471 || r212474;
double r212476 = y;
double r212477 = 3.13060547623;
double r212478 = t;
double r212479 = 2.0;
double r212480 = pow(r212469, r212479);
double r212481 = r212478 / r212480;
double r212482 = r212477 + r212481;
double r212483 = x;
double r212484 = fma(r212476, r212482, r212483);
double r212485 = r212469 * r212477;
double r212486 = 11.1667541262;
double r212487 = r212485 + r212486;
double r212488 = r212487 * r212469;
double r212489 = r212488 + r212478;
double r212490 = r212489 * r212469;
double r212491 = a;
double r212492 = r212490 + r212491;
double r212493 = r212492 * r212469;
double r212494 = b;
double r212495 = r212493 + r212494;
double r212496 = r212476 * r212495;
double r212497 = 15.234687407;
double r212498 = r212469 + r212497;
double r212499 = r212498 * r212469;
double r212500 = 31.4690115749;
double r212501 = r212499 + r212500;
double r212502 = r212501 * r212469;
double r212503 = 11.9400905721;
double r212504 = r212502 + r212503;
double r212505 = r212504 * r212469;
double r212506 = 0.607771387771;
double r212507 = r212505 + r212506;
double r212508 = r212496 / r212507;
double r212509 = r212483 + r212508;
double r212510 = r212475 ? r212484 : r212509;
return r212510;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
| Original | 29.8 |
|---|---|
| Target | 1.0 |
| Herbie | 1.8 |
if z < -3.0768108824136354e+56 or 1.2853526268829621e+17 < z Initial program 59.6
Simplified57.8
Taylor expanded around inf 8.6
Simplified1.8
if -3.0768108824136354e+56 < z < 1.2853526268829621e+17Initial program 1.8
Final simplification1.8
herbie shell --seed 2019323 +o rules:numerics
(FPCore (x y z t a b)
:name "Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2, D"
:precision binary64
:herbie-target
(if (< z -6.499344996252632e+53) (+ x (* (+ (- 3.13060547623 (/ 36.527041698806414 z)) (/ t (* z z))) (/ y 1))) (if (< z 7.066965436914287e+59) (+ x (/ y (/ (+ (* (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721) z) 0.607771387771) (+ (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z) b)))) (+ x (* (+ (- 3.13060547623 (/ 36.527041698806414 z)) (/ t (* z z))) (/ y 1)))))
(+ x (/ (* y (+ (* (+ (* (+ (* (+ (* z 3.13060547623) 11.1667541262) z) t) z) a) z) b)) (+ (* (+ (* (+ (* (+ z 15.234687407) z) 31.4690115749) z) 11.9400905721) z) 0.607771387771))))