\frac{\left(x - 2\right) \cdot \left(\left(\left(\left(x \cdot 4.16438922227999963610045597306452691555 + 78.69949241540000173245061887428164482117\right) \cdot x + 137.5194164160000127594685181975364685059\right) \cdot x + y\right) \cdot x + z\right)}{\left(\left(\left(x + 43.3400022514000013984514225739985704422\right) \cdot x + 263.5050747210000281484099105000495910645\right) \cdot x + 313.3992158940000081202015280723571777344\right) \cdot x + 47.06687660600000100430406746454536914825}\begin{array}{l}
\mathbf{if}\;x \le -288151121519641987601399808 \lor \neg \left(x \le 14456844266184348924014231552\right):\\
\;\;\;\;\mathsf{fma}\left(4.16438922227999963610045597306452691555, x, \frac{y}{{x}^{2}}\right) - 110.1139242984810948655649553984403610229\\
\mathbf{else}:\\
\;\;\;\;\frac{\left({x}^{3} - {2}^{3}\right) \cdot \frac{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(x, 4.16438922227999963610045597306452691555, 78.69949241540000173245061887428164482117\right), x, 137.5194164160000127594685181975364685059\right), x, y\right), x, z\right)}{\mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(x + 43.3400022514000013984514225739985704422, x, 263.5050747210000281484099105000495910645\right), x, 313.3992158940000081202015280723571777344\right), x, 47.06687660600000100430406746454536914825\right)}}{x \cdot x + \left(2 \cdot 2 + x \cdot 2\right)}\\
\end{array}double f(double x, double y, double z) {
double r232917 = x;
double r232918 = 2.0;
double r232919 = r232917 - r232918;
double r232920 = 4.16438922228;
double r232921 = r232917 * r232920;
double r232922 = 78.6994924154;
double r232923 = r232921 + r232922;
double r232924 = r232923 * r232917;
double r232925 = 137.519416416;
double r232926 = r232924 + r232925;
double r232927 = r232926 * r232917;
double r232928 = y;
double r232929 = r232927 + r232928;
double r232930 = r232929 * r232917;
double r232931 = z;
double r232932 = r232930 + r232931;
double r232933 = r232919 * r232932;
double r232934 = 43.3400022514;
double r232935 = r232917 + r232934;
double r232936 = r232935 * r232917;
double r232937 = 263.505074721;
double r232938 = r232936 + r232937;
double r232939 = r232938 * r232917;
double r232940 = 313.399215894;
double r232941 = r232939 + r232940;
double r232942 = r232941 * r232917;
double r232943 = 47.066876606;
double r232944 = r232942 + r232943;
double r232945 = r232933 / r232944;
return r232945;
}
double f(double x, double y, double z) {
double r232946 = x;
double r232947 = -2.88151121519642e+26;
bool r232948 = r232946 <= r232947;
double r232949 = 1.445684426618435e+28;
bool r232950 = r232946 <= r232949;
double r232951 = !r232950;
bool r232952 = r232948 || r232951;
double r232953 = 4.16438922228;
double r232954 = y;
double r232955 = 2.0;
double r232956 = pow(r232946, r232955);
double r232957 = r232954 / r232956;
double r232958 = fma(r232953, r232946, r232957);
double r232959 = 110.1139242984811;
double r232960 = r232958 - r232959;
double r232961 = 3.0;
double r232962 = pow(r232946, r232961);
double r232963 = 2.0;
double r232964 = pow(r232963, r232961);
double r232965 = r232962 - r232964;
double r232966 = 78.6994924154;
double r232967 = fma(r232946, r232953, r232966);
double r232968 = 137.519416416;
double r232969 = fma(r232967, r232946, r232968);
double r232970 = fma(r232969, r232946, r232954);
double r232971 = z;
double r232972 = fma(r232970, r232946, r232971);
double r232973 = 43.3400022514;
double r232974 = r232946 + r232973;
double r232975 = 263.505074721;
double r232976 = fma(r232974, r232946, r232975);
double r232977 = 313.399215894;
double r232978 = fma(r232976, r232946, r232977);
double r232979 = 47.066876606;
double r232980 = fma(r232978, r232946, r232979);
double r232981 = r232972 / r232980;
double r232982 = r232965 * r232981;
double r232983 = r232946 * r232946;
double r232984 = r232963 * r232963;
double r232985 = r232946 * r232963;
double r232986 = r232984 + r232985;
double r232987 = r232983 + r232986;
double r232988 = r232982 / r232987;
double r232989 = r232952 ? r232960 : r232988;
return r232989;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 26.1 |
|---|---|
| Target | 0.6 |
| Herbie | 0.9 |
if x < -2.88151121519642e+26 or 1.445684426618435e+28 < x Initial program 57.8
Simplified53.6
Taylor expanded around inf 1.5
Simplified1.5
if -2.88151121519642e+26 < x < 1.445684426618435e+28Initial program 0.7
Simplified0.5
rmApplied div-inv0.5
Simplified0.3
rmApplied flip3--0.3
Applied associate-*l/0.3
Final simplification0.9
herbie shell --seed 2019303 +o rules:numerics
(FPCore (x y z)
:name "Numeric.SpecFunctions:logGamma from math-functions-0.1.5.2, C"
:precision binary64
:herbie-target
(if (< x -3.3261287258700048e62) (- (+ (/ y (* x x)) (* 4.16438922227999964 x)) 110.11392429848109) (if (< x 9.4299917145546727e55) (* (/ (- x 2) 1) (/ (+ (* (+ (* (+ (* (+ (* x 4.16438922227999964) 78.6994924154000017) x) 137.51941641600001) x) y) x) z) (+ (* (+ (+ (* 263.50507472100003 x) (+ (* 43.3400022514000014 (* x x)) (* x (* x x)))) 313.399215894) x) 47.066876606000001))) (- (+ (/ y (* x x)) (* 4.16438922227999964 x)) 110.11392429848109)))
(/ (* (- x 2) (+ (* (+ (* (+ (* (+ (* x 4.16438922227999964) 78.6994924154000017) x) 137.51941641600001) x) y) x) z)) (+ (* (+ (* (+ (* (+ x 43.3400022514000014) x) 263.50507472100003) x) 313.399215894) x) 47.066876606000001)))