\left(\left(x \cdot \log y - y\right) - z\right) + \log t
\mathsf{fma}\left(y, -1, y\right) + \mathsf{fma}\left(x, \log y, \left(\left(\log \left(\sqrt[3]{t}\right) - z\right) - y\right) + \log \left(\sqrt[3]{t} \cdot \sqrt[3]{t}\right)\right)double f(double x, double y, double z, double t) {
double r5124892 = x;
double r5124893 = y;
double r5124894 = log(r5124893);
double r5124895 = r5124892 * r5124894;
double r5124896 = r5124895 - r5124893;
double r5124897 = z;
double r5124898 = r5124896 - r5124897;
double r5124899 = t;
double r5124900 = log(r5124899);
double r5124901 = r5124898 + r5124900;
return r5124901;
}
double f(double x, double y, double z, double t) {
double r5124902 = y;
double r5124903 = -1.0;
double r5124904 = fma(r5124902, r5124903, r5124902);
double r5124905 = x;
double r5124906 = log(r5124902);
double r5124907 = t;
double r5124908 = cbrt(r5124907);
double r5124909 = log(r5124908);
double r5124910 = z;
double r5124911 = r5124909 - r5124910;
double r5124912 = r5124911 - r5124902;
double r5124913 = r5124908 * r5124908;
double r5124914 = log(r5124913);
double r5124915 = r5124912 + r5124914;
double r5124916 = fma(r5124905, r5124906, r5124915);
double r5124917 = r5124904 + r5124916;
return r5124917;
}



Bits error versus x



Bits error versus y



Bits error versus z



Bits error versus t
Initial program 0.1
Simplified0.1
rmApplied add-cube-cbrt0.5
Applied add-sqr-sqrt32.3
Applied prod-diff32.3
Simplified0.1
Simplified0.1
rmApplied add-cube-cbrt0.1
Applied log-prod0.1
Applied associate--l+0.1
Applied associate--l+0.1
Final simplification0.1
herbie shell --seed 2019163 +o rules:numerics
(FPCore (x y z t)
:name "Numeric.SpecFunctions:incompleteGamma from math-functions-0.1.5.2, A"
(+ (- (- (* x (log y)) y) z) (log t)))