x + \frac{y \cdot \left(\left(\left(\left(z \cdot 3.13060547622999996 + 11.166754126200001\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b\right)}{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004}\begin{array}{l}
\mathbf{if}\;z \le -2.078108004357145 \cdot 10^{59} \lor \neg \left(z \le 9.5295344732185015 \cdot 10^{30}\right):\\
\;\;\;\;\mathsf{fma}\left(y, 3.13060547622999996 + \frac{t}{{z}^{2}}, x\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(y \cdot \frac{1}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z + 15.234687406999999, z, 31.469011574900001\right), z, 11.940090572100001\right), z, 0.60777138777100004\right)}, \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(z, 3.13060547622999996, 11.166754126200001\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 r403084 = x;
double r403085 = y;
double r403086 = z;
double r403087 = 3.13060547623;
double r403088 = r403086 * r403087;
double r403089 = 11.1667541262;
double r403090 = r403088 + r403089;
double r403091 = r403090 * r403086;
double r403092 = t;
double r403093 = r403091 + r403092;
double r403094 = r403093 * r403086;
double r403095 = a;
double r403096 = r403094 + r403095;
double r403097 = r403096 * r403086;
double r403098 = b;
double r403099 = r403097 + r403098;
double r403100 = r403085 * r403099;
double r403101 = 15.234687407;
double r403102 = r403086 + r403101;
double r403103 = r403102 * r403086;
double r403104 = 31.4690115749;
double r403105 = r403103 + r403104;
double r403106 = r403105 * r403086;
double r403107 = 11.9400905721;
double r403108 = r403106 + r403107;
double r403109 = r403108 * r403086;
double r403110 = 0.607771387771;
double r403111 = r403109 + r403110;
double r403112 = r403100 / r403111;
double r403113 = r403084 + r403112;
return r403113;
}
double f(double x, double y, double z, double t, double a, double b) {
double r403114 = z;
double r403115 = -2.078108004357145e+59;
bool r403116 = r403114 <= r403115;
double r403117 = 9.529534473218501e+30;
bool r403118 = r403114 <= r403117;
double r403119 = !r403118;
bool r403120 = r403116 || r403119;
double r403121 = y;
double r403122 = 3.13060547623;
double r403123 = t;
double r403124 = 2.0;
double r403125 = pow(r403114, r403124);
double r403126 = r403123 / r403125;
double r403127 = r403122 + r403126;
double r403128 = x;
double r403129 = fma(r403121, r403127, r403128);
double r403130 = 1.0;
double r403131 = 15.234687407;
double r403132 = r403114 + r403131;
double r403133 = 31.4690115749;
double r403134 = fma(r403132, r403114, r403133);
double r403135 = 11.9400905721;
double r403136 = fma(r403134, r403114, r403135);
double r403137 = 0.607771387771;
double r403138 = fma(r403136, r403114, r403137);
double r403139 = r403130 / r403138;
double r403140 = r403121 * r403139;
double r403141 = 11.1667541262;
double r403142 = fma(r403114, r403122, r403141);
double r403143 = fma(r403142, r403114, r403123);
double r403144 = a;
double r403145 = fma(r403143, r403114, r403144);
double r403146 = b;
double r403147 = fma(r403145, r403114, r403146);
double r403148 = fma(r403140, r403147, r403128);
double r403149 = r403120 ? r403129 : r403148;
return r403149;
}




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.0 |
|---|---|
| Target | 1.1 |
| Herbie | 1.2 |
if z < -2.078108004357145e+59 or 9.529534473218501e+30 < z Initial program 60.3
Simplified58.8
Taylor expanded around inf 9.0
Simplified1.2
if -2.078108004357145e+59 < z < 9.529534473218501e+30Initial program 2.2
Simplified1.0
rmApplied div-inv1.1
Final simplification1.2
herbie shell --seed 2020062 +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))))