\left(\left(\log \left(x + y\right) + \log z\right) - t\right) + \left(a - 0.5\right) \cdot \log t
\mathsf{fma}\left(a - 0.5, \log t, \left(\mathsf{fma}\left(2, \log \left(\sqrt[3]{z}\right), \log \left(x + y\right)\right) + \log \left(\sqrt[3]{z}\right)\right) - t\right)double f(double x, double y, double z, double t, double a) {
double r368062 = x;
double r368063 = y;
double r368064 = r368062 + r368063;
double r368065 = log(r368064);
double r368066 = z;
double r368067 = log(r368066);
double r368068 = r368065 + r368067;
double r368069 = t;
double r368070 = r368068 - r368069;
double r368071 = a;
double r368072 = 0.5;
double r368073 = r368071 - r368072;
double r368074 = log(r368069);
double r368075 = r368073 * r368074;
double r368076 = r368070 + r368075;
return r368076;
}
double f(double x, double y, double z, double t, double a) {
double r368077 = a;
double r368078 = 0.5;
double r368079 = r368077 - r368078;
double r368080 = t;
double r368081 = log(r368080);
double r368082 = 2.0;
double r368083 = z;
double r368084 = cbrt(r368083);
double r368085 = log(r368084);
double r368086 = x;
double r368087 = y;
double r368088 = r368086 + r368087;
double r368089 = log(r368088);
double r368090 = fma(r368082, r368085, r368089);
double r368091 = r368090 + r368085;
double r368092 = r368091 - r368080;
double r368093 = fma(r368079, r368081, r368092);
return r368093;
}




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
Simplified0.3
rmApplied add-cube-cbrt0.3
Applied log-prod0.3
Applied associate-+r+0.3
Simplified0.3
Final simplification0.3
herbie shell --seed 2019326 +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))))