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 r315857 = x;
double r315858 = y;
double r315859 = z;
double r315860 = 3.13060547623;
double r315861 = r315859 * r315860;
double r315862 = 11.1667541262;
double r315863 = r315861 + r315862;
double r315864 = r315863 * r315859;
double r315865 = t;
double r315866 = r315864 + r315865;
double r315867 = r315866 * r315859;
double r315868 = a;
double r315869 = r315867 + r315868;
double r315870 = r315869 * r315859;
double r315871 = b;
double r315872 = r315870 + r315871;
double r315873 = r315858 * r315872;
double r315874 = 15.234687407;
double r315875 = r315859 + r315874;
double r315876 = r315875 * r315859;
double r315877 = 31.4690115749;
double r315878 = r315876 + r315877;
double r315879 = r315878 * r315859;
double r315880 = 11.9400905721;
double r315881 = r315879 + r315880;
double r315882 = r315881 * r315859;
double r315883 = 0.607771387771;
double r315884 = r315882 + r315883;
double r315885 = r315873 / r315884;
double r315886 = r315857 + r315885;
return r315886;
}
double f(double x, double y, double z, double t, double a, double b) {
double r315887 = z;
double r315888 = -1.722270487450869e+48;
bool r315889 = r315887 <= r315888;
double r315890 = 2.40528713233231e+35;
bool r315891 = r315887 <= r315890;
double r315892 = !r315891;
bool r315893 = r315889 || r315892;
double r315894 = y;
double r315895 = 3.13060547623;
double r315896 = t;
double r315897 = 2.0;
double r315898 = pow(r315887, r315897);
double r315899 = r315896 / r315898;
double r315900 = r315895 + r315899;
double r315901 = x;
double r315902 = fma(r315894, r315900, r315901);
double r315903 = 1.0;
double r315904 = 15.234687407;
double r315905 = r315887 + r315904;
double r315906 = 31.4690115749;
double r315907 = fma(r315905, r315887, r315906);
double r315908 = 11.9400905721;
double r315909 = fma(r315907, r315887, r315908);
double r315910 = 0.607771387771;
double r315911 = fma(r315909, r315887, r315910);
double r315912 = r315903 / r315911;
double r315913 = sqrt(r315912);
double r315914 = r315913 * r315913;
double r315915 = r315894 * r315914;
double r315916 = 11.1667541262;
double r315917 = fma(r315887, r315895, r315916);
double r315918 = fma(r315917, r315887, r315896);
double r315919 = a;
double r315920 = fma(r315918, r315887, r315919);
double r315921 = b;
double r315922 = fma(r315920, r315887, r315921);
double r315923 = fma(r315915, r315922, r315901);
double r315924 = r315893 ? r315902 : r315923;
return r315924;
}




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))))