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 -3.7165119779502947 \cdot 10^{24} \lor \neg \left(z \le 3.87772220842748429 \cdot 10^{27}\right):\\
\;\;\;\;x + y \cdot \left(\left(\frac{t}{{z}^{2}} + 3.13060547622999996\right) - 36.527041698806414 \cdot \frac{1}{z}\right)\\
\mathbf{else}:\\
\;\;\;\;x + y \cdot \frac{\frac{\left(\left(\left(z \cdot 3.13060547622999996 + 11.166754126200001\right) \cdot z + t\right) \cdot z + a\right) \cdot z + b}{\sqrt[3]{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004} \cdot \sqrt[3]{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004}}}{\sqrt[3]{\left(\left(\left(z + 15.234687406999999\right) \cdot z + 31.469011574900001\right) \cdot z + 11.940090572100001\right) \cdot z + 0.60777138777100004}}\\
\end{array}double f(double x, double y, double z, double t, double a, double b) {
double r387064 = x;
double r387065 = y;
double r387066 = z;
double r387067 = 3.13060547623;
double r387068 = r387066 * r387067;
double r387069 = 11.1667541262;
double r387070 = r387068 + r387069;
double r387071 = r387070 * r387066;
double r387072 = t;
double r387073 = r387071 + r387072;
double r387074 = r387073 * r387066;
double r387075 = a;
double r387076 = r387074 + r387075;
double r387077 = r387076 * r387066;
double r387078 = b;
double r387079 = r387077 + r387078;
double r387080 = r387065 * r387079;
double r387081 = 15.234687407;
double r387082 = r387066 + r387081;
double r387083 = r387082 * r387066;
double r387084 = 31.4690115749;
double r387085 = r387083 + r387084;
double r387086 = r387085 * r387066;
double r387087 = 11.9400905721;
double r387088 = r387086 + r387087;
double r387089 = r387088 * r387066;
double r387090 = 0.607771387771;
double r387091 = r387089 + r387090;
double r387092 = r387080 / r387091;
double r387093 = r387064 + r387092;
return r387093;
}
double f(double x, double y, double z, double t, double a, double b) {
double r387094 = z;
double r387095 = -3.7165119779502947e+24;
bool r387096 = r387094 <= r387095;
double r387097 = 3.8777222084274843e+27;
bool r387098 = r387094 <= r387097;
double r387099 = !r387098;
bool r387100 = r387096 || r387099;
double r387101 = x;
double r387102 = y;
double r387103 = t;
double r387104 = 2.0;
double r387105 = pow(r387094, r387104);
double r387106 = r387103 / r387105;
double r387107 = 3.13060547623;
double r387108 = r387106 + r387107;
double r387109 = 36.527041698806414;
double r387110 = 1.0;
double r387111 = r387110 / r387094;
double r387112 = r387109 * r387111;
double r387113 = r387108 - r387112;
double r387114 = r387102 * r387113;
double r387115 = r387101 + r387114;
double r387116 = r387094 * r387107;
double r387117 = 11.1667541262;
double r387118 = r387116 + r387117;
double r387119 = r387118 * r387094;
double r387120 = r387119 + r387103;
double r387121 = r387120 * r387094;
double r387122 = a;
double r387123 = r387121 + r387122;
double r387124 = r387123 * r387094;
double r387125 = b;
double r387126 = r387124 + r387125;
double r387127 = 15.234687407;
double r387128 = r387094 + r387127;
double r387129 = r387128 * r387094;
double r387130 = 31.4690115749;
double r387131 = r387129 + r387130;
double r387132 = r387131 * r387094;
double r387133 = 11.9400905721;
double r387134 = r387132 + r387133;
double r387135 = r387134 * r387094;
double r387136 = 0.607771387771;
double r387137 = r387135 + r387136;
double r387138 = cbrt(r387137);
double r387139 = r387138 * r387138;
double r387140 = r387126 / r387139;
double r387141 = r387140 / r387138;
double r387142 = r387102 * r387141;
double r387143 = r387101 + r387142;
double r387144 = r387100 ? r387115 : r387143;
return r387144;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
Results
| Original | 29.8 |
|---|---|
| Target | 1.1 |
| Herbie | 1.2 |
if z < -3.7165119779502947e+24 or 3.8777222084274843e+27 < z Initial program 58.5
rmApplied *-un-lft-identity58.5
Applied times-frac55.5
Simplified55.5
Taylor expanded around inf 1.8
if -3.7165119779502947e+24 < z < 3.8777222084274843e+27Initial program 0.9
rmApplied *-un-lft-identity0.9
Applied times-frac0.4
Simplified0.4
rmApplied add-cube-cbrt0.4
Applied associate-/r*0.5
Final simplification1.2
herbie shell --seed 2020035
(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))))