\log \left(\frac{1 - \varepsilon}{1 + \varepsilon}\right)\mathsf{log1p}\left(-\varepsilon\right) - \mathsf{log1p}\left(\varepsilon\right)double f(double eps) {
double r1774061 = 1.0;
double r1774062 = eps;
double r1774063 = r1774061 - r1774062;
double r1774064 = r1774061 + r1774062;
double r1774065 = r1774063 / r1774064;
double r1774066 = log(r1774065);
return r1774066;
}
double f(double eps) {
double r1774067 = eps;
double r1774068 = -r1774067;
double r1774069 = log1p(r1774068);
double r1774070 = log1p(r1774067);
double r1774071 = r1774069 - r1774070;
return r1774071;
}




Bits error versus eps
Results
| Original | 58.4 |
|---|---|
| Target | 0.3 |
| Herbie | 0.0 |
Initial program 58.4
rmApplied log-div58.4
Simplified50.4
rmApplied sub-neg50.4
Applied log1p-def0.0
Final simplification0.0
herbie shell --seed 2019151 +o rules:numerics
(FPCore (eps)
:name "logq (problem 3.4.3)"
:herbie-target
(* -2 (+ (+ eps (/ (pow eps 3) 3)) (/ (pow eps 5) 5)))
(log (/ (- 1 eps) (+ 1 eps))))