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 -309142137143483328 \lor \neg \left(z \le 78127593777363569792550561904590848\right):\\
\;\;\;\;\mathsf{fma}\left(y, 3.130605476229999961645944495103321969509 + \frac{t}{{z}^{2}}, x\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{y}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.2346874069999991263557603815570473671, z, 31.46901157490000144889563671313226222992\right), z, 11.94009057210000079862766142468899488449\right), z, 0.6077713877710000378584709324059076607227\right)}, \mathsf{fma}\left(\mathsf{fma}\left(\left(\sqrt[3]{\mathsf{fma}\left(\mathsf{fma}\left(z, 3.130605476229999961645944495103321969509, 11.16675412620000074070958362426608800888\right), z, t\right)} \cdot \sqrt[3]{\mathsf{fma}\left(\mathsf{fma}\left(z, 3.130605476229999961645944495103321969509, 11.16675412620000074070958362426608800888\right), z, t\right)}\right) \cdot \sqrt[3]{\mathsf{fma}\left(\mathsf{fma}\left(z, 3.130605476229999961645944495103321969509, 11.16675412620000074070958362426608800888\right), z, t\right)}, z, a\right), z, b\right), x\right)\\
\end{array}double f(double x, double y, double z, double t, double a, double b) {
double r399269 = x;
double r399270 = y;
double r399271 = z;
double r399272 = 3.13060547623;
double r399273 = r399271 * r399272;
double r399274 = 11.1667541262;
double r399275 = r399273 + r399274;
double r399276 = r399275 * r399271;
double r399277 = t;
double r399278 = r399276 + r399277;
double r399279 = r399278 * r399271;
double r399280 = a;
double r399281 = r399279 + r399280;
double r399282 = r399281 * r399271;
double r399283 = b;
double r399284 = r399282 + r399283;
double r399285 = r399270 * r399284;
double r399286 = 15.234687407;
double r399287 = r399271 + r399286;
double r399288 = r399287 * r399271;
double r399289 = 31.4690115749;
double r399290 = r399288 + r399289;
double r399291 = r399290 * r399271;
double r399292 = 11.9400905721;
double r399293 = r399291 + r399292;
double r399294 = r399293 * r399271;
double r399295 = 0.607771387771;
double r399296 = r399294 + r399295;
double r399297 = r399285 / r399296;
double r399298 = r399269 + r399297;
return r399298;
}
double f(double x, double y, double z, double t, double a, double b) {
double r399299 = z;
double r399300 = -3.091421371434833e+17;
bool r399301 = r399299 <= r399300;
double r399302 = 7.812759377736357e+34;
bool r399303 = r399299 <= r399302;
double r399304 = !r399303;
bool r399305 = r399301 || r399304;
double r399306 = y;
double r399307 = 3.13060547623;
double r399308 = t;
double r399309 = 2.0;
double r399310 = pow(r399299, r399309);
double r399311 = r399308 / r399310;
double r399312 = r399307 + r399311;
double r399313 = x;
double r399314 = fma(r399306, r399312, r399313);
double r399315 = 15.234687407;
double r399316 = r399299 + r399315;
double r399317 = 31.4690115749;
double r399318 = fma(r399316, r399299, r399317);
double r399319 = 11.9400905721;
double r399320 = fma(r399318, r399299, r399319);
double r399321 = 0.607771387771;
double r399322 = fma(r399320, r399299, r399321);
double r399323 = r399306 / r399322;
double r399324 = 11.1667541262;
double r399325 = fma(r399299, r399307, r399324);
double r399326 = fma(r399325, r399299, r399308);
double r399327 = cbrt(r399326);
double r399328 = r399327 * r399327;
double r399329 = r399328 * r399327;
double r399330 = a;
double r399331 = fma(r399329, r399299, r399330);
double r399332 = b;
double r399333 = fma(r399331, r399299, r399332);
double r399334 = fma(r399323, r399333, r399313);
double r399335 = r399305 ? r399314 : r399334;
return r399335;
}




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 | 28.9 |
|---|---|
| Target | 1.0 |
| Herbie | 1.3 |
if z < -3.091421371434833e+17 or 7.812759377736357e+34 < z Initial program 58.4
Simplified56.0
Taylor expanded around inf 8.9
Simplified2.0
if -3.091421371434833e+17 < z < 7.812759377736357e+34Initial program 1.0
Simplified0.6
rmApplied add-cube-cbrt0.7
Final simplification1.3
herbie shell --seed 2019350 +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))))