\left(\left(x - \left(y + 0.5\right) \cdot \log y\right) + y\right) - z
\left(x + \mathsf{fma}\left(-\left(y + 0.5\right), \log y, y\right)\right) - zdouble f(double x, double y, double z) {
double r540701 = x;
double r540702 = y;
double r540703 = 0.5;
double r540704 = r540702 + r540703;
double r540705 = log(r540702);
double r540706 = r540704 * r540705;
double r540707 = r540701 - r540706;
double r540708 = r540707 + r540702;
double r540709 = z;
double r540710 = r540708 - r540709;
return r540710;
}
double f(double x, double y, double z) {
double r540711 = x;
double r540712 = y;
double r540713 = 0.5;
double r540714 = r540712 + r540713;
double r540715 = -r540714;
double r540716 = log(r540712);
double r540717 = fma(r540715, r540716, r540712);
double r540718 = r540711 + r540717;
double r540719 = z;
double r540720 = r540718 - r540719;
return r540720;
}




Bits error versus x




Bits error versus y




Bits error versus z
| Original | 0.1 |
|---|---|
| Target | 0.1 |
| Herbie | 0.1 |
Initial program 0.1
rmApplied sub-neg0.1
Applied associate-+l+0.1
Simplified0.1
Final simplification0.1
herbie shell --seed 2019362 +o rules:numerics
(FPCore (x y z)
:name "Numeric.SpecFunctions:stirlingError from math-functions-0.1.5.2"
:precision binary64
:herbie-target
(- (- (+ y x) z) (* (+ y 0.5) (log y)))
(- (+ (- x (* (+ y 0.5) (log y))) y) z))