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 -1.72227048745086914677454525931351178413 \cdot 10^{48} \lor \neg \left(z \le 240528713233231009630516822165946368\right):\\
\;\;\;\;\mathsf{fma}\left(y, 3.130605476229999961645944495103321969509 + \frac{t}{{z}^{2}}, x\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(y \cdot \left(\sqrt{\frac{1}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.2346874069999991263557603815570473671, z, 31.46901157490000144889563671313226222992\right), z, 11.94009057210000079862766142468899488449\right), z, 0.6077713877710000378584709324059076607227\right)}} \cdot \sqrt{\frac{1}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.2346874069999991263557603815570473671, z, 31.46901157490000144889563671313226222992\right), z, 11.94009057210000079862766142468899488449\right), z, 0.6077713877710000378584709324059076607227\right)}}\right), \mathsf{fma}\left(\mathsf{fma}\left(\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 r371558 = x;
double r371559 = y;
double r371560 = z;
double r371561 = 3.13060547623;
double r371562 = r371560 * r371561;
double r371563 = 11.1667541262;
double r371564 = r371562 + r371563;
double r371565 = r371564 * r371560;
double r371566 = t;
double r371567 = r371565 + r371566;
double r371568 = r371567 * r371560;
double r371569 = a;
double r371570 = r371568 + r371569;
double r371571 = r371570 * r371560;
double r371572 = b;
double r371573 = r371571 + r371572;
double r371574 = r371559 * r371573;
double r371575 = 15.234687407;
double r371576 = r371560 + r371575;
double r371577 = r371576 * r371560;
double r371578 = 31.4690115749;
double r371579 = r371577 + r371578;
double r371580 = r371579 * r371560;
double r371581 = 11.9400905721;
double r371582 = r371580 + r371581;
double r371583 = r371582 * r371560;
double r371584 = 0.607771387771;
double r371585 = r371583 + r371584;
double r371586 = r371574 / r371585;
double r371587 = r371558 + r371586;
return r371587;
}
double f(double x, double y, double z, double t, double a, double b) {
double r371588 = z;
double r371589 = -1.722270487450869e+48;
bool r371590 = r371588 <= r371589;
double r371591 = 2.40528713233231e+35;
bool r371592 = r371588 <= r371591;
double r371593 = !r371592;
bool r371594 = r371590 || r371593;
double r371595 = y;
double r371596 = 3.13060547623;
double r371597 = t;
double r371598 = 2.0;
double r371599 = pow(r371588, r371598);
double r371600 = r371597 / r371599;
double r371601 = r371596 + r371600;
double r371602 = x;
double r371603 = fma(r371595, r371601, r371602);
double r371604 = 1.0;
double r371605 = 15.234687407;
double r371606 = r371588 + r371605;
double r371607 = 31.4690115749;
double r371608 = fma(r371606, r371588, r371607);
double r371609 = 11.9400905721;
double r371610 = fma(r371608, r371588, r371609);
double r371611 = 0.607771387771;
double r371612 = fma(r371610, r371588, r371611);
double r371613 = r371604 / r371612;
double r371614 = sqrt(r371613);
double r371615 = r371614 * r371614;
double r371616 = r371595 * r371615;
double r371617 = 11.1667541262;
double r371618 = fma(r371588, r371596, r371617);
double r371619 = fma(r371618, r371588, r371597);
double r371620 = a;
double r371621 = fma(r371619, r371588, r371620);
double r371622 = b;
double r371623 = fma(r371621, r371588, r371622);
double r371624 = fma(r371616, r371623, r371602);
double r371625 = r371594 ? r371603 : r371624;
return r371625;
}




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.6 |
|---|---|
| Target | 1.0 |
| Herbie | 1.2 |
if z < -1.722270487450869e+48 or 2.40528713233231e+35 < z Initial program 60.3
Simplified58.1
Taylor expanded around inf 8.7
Simplified1.4
if -1.722270487450869e+48 < z < 2.40528713233231e+35Initial program 1.8
Simplified0.9
rmApplied div-inv1.0
rmApplied add-sqr-sqrt1.1
Final simplification1.2
herbie shell --seed 2020001 +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))))