\log \left(1 + x\right)
\begin{array}{l}
\mathbf{if}\;1 + x \le 1:\\
\;\;\;\;x \cdot \left(1 + \frac{\frac{-1}{2}}{\frac{1 \cdot 1}{x}}\right) + \log 1\\
\mathbf{else}:\\
\;\;\;\;\log \left(1 + x\right)\\
\end{array}double f(double x) {
double r41536 = 1.0;
double r41537 = x;
double r41538 = r41536 + r41537;
double r41539 = log(r41538);
return r41539;
}
double f(double x) {
double r41540 = 1.0;
double r41541 = x;
double r41542 = r41540 + r41541;
bool r41543 = r41542 <= r41540;
double r41544 = -0.5;
double r41545 = r41540 * r41540;
double r41546 = r41545 / r41541;
double r41547 = r41544 / r41546;
double r41548 = r41540 + r41547;
double r41549 = r41541 * r41548;
double r41550 = log(r41540);
double r41551 = r41549 + r41550;
double r41552 = log(r41542);
double r41553 = r41543 ? r41551 : r41552;
return r41553;
}




Bits error versus x
Results
| Original | 39.1 |
|---|---|
| Target | 0.2 |
| Herbie | 0.6 |
if (+ 1.0 x) < 1.0Initial program 59.6
Taylor expanded around 0 0.3
Simplified0.3
if 1.0 < (+ 1.0 x) Initial program 1.3
Final simplification0.6
herbie shell --seed 2019326
(FPCore (x)
:name "ln(1 + x)"
:precision binary64
:herbie-target
(if (== (+ 1 x) 1) x (/ (* x (log (+ 1 x))) (- (+ 1 x) 1)))
(log (+ 1 x)))