\left(\left(\log \left(x + y\right) + \log z\right) - t\right) + \left(a - 0.5\right) \cdot \log t
\left(\left(\log \left(x + y\right) + \log z\right) - t\right) + \left(\left(a - 0.5\right) \cdot \left(2 \cdot \log \left(\sqrt[3]{\sqrt[3]{t}} \cdot \sqrt[3]{\sqrt[3]{t}}\right)\right) + \mathsf{fma}\left(\log \left(\sqrt[3]{\sqrt[3]{t}}\right), 2, \log \left({t}^{\frac{1}{3}}\right)\right) \cdot \left(a - 0.5\right)\right)double f(double x, double y, double z, double t, double a) {
double r286836 = x;
double r286837 = y;
double r286838 = r286836 + r286837;
double r286839 = log(r286838);
double r286840 = z;
double r286841 = log(r286840);
double r286842 = r286839 + r286841;
double r286843 = t;
double r286844 = r286842 - r286843;
double r286845 = a;
double r286846 = 0.5;
double r286847 = r286845 - r286846;
double r286848 = log(r286843);
double r286849 = r286847 * r286848;
double r286850 = r286844 + r286849;
return r286850;
}
double f(double x, double y, double z, double t, double a) {
double r286851 = x;
double r286852 = y;
double r286853 = r286851 + r286852;
double r286854 = log(r286853);
double r286855 = z;
double r286856 = log(r286855);
double r286857 = r286854 + r286856;
double r286858 = t;
double r286859 = r286857 - r286858;
double r286860 = a;
double r286861 = 0.5;
double r286862 = r286860 - r286861;
double r286863 = 2.0;
double r286864 = cbrt(r286858);
double r286865 = cbrt(r286864);
double r286866 = r286865 * r286865;
double r286867 = log(r286866);
double r286868 = r286863 * r286867;
double r286869 = r286862 * r286868;
double r286870 = log(r286865);
double r286871 = 0.3333333333333333;
double r286872 = pow(r286858, r286871);
double r286873 = log(r286872);
double r286874 = fma(r286870, r286863, r286873);
double r286875 = r286874 * r286862;
double r286876 = r286869 + r286875;
double r286877 = r286859 + r286876;
return r286877;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 0.3 |
|---|---|
| Target | 0.3 |
| Herbie | 0.3 |
Initial program 0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.3
Applied distribute-lft-in0.3
Simplified0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.3
Applied distribute-lft-in0.3
Applied distribute-lft-in0.3
Applied associate-+l+0.3
Simplified0.3
Final simplification0.3
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x y z t a)
:name "Numeric.SpecFunctions:logGammaL from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(+ (log (+ x y)) (+ (- (log z) t) (* (- a 0.5) (log t))))
(+ (- (+ (log (+ x y)) (log z)) t) (* (- a 0.5) (log t))))