\frac{x0}{1 - x1} - x0\begin{array}{l}
\mathbf{if}\;1 - x1 \leq 0.9814:\\
\;\;\;\;\frac{\frac{x0}{1 - x1} \cdot \frac{x0}{1 - x1} - x0 \cdot x0}{x0 + \frac{x0}{1 - x1}}\\
\mathbf{else}:\\
\;\;\;\;\left(x1 + x1 \cdot x1\right) \cdot \left(x0 + x1 \cdot \left(x1 \cdot x0\right)\right)\\
\end{array}(FPCore (x0 x1) :precision binary64 (- (/ x0 (- 1.0 x1)) x0))
(FPCore (x0 x1)
:precision binary64
(if (<= (- 1.0 x1) 0.9814)
(/
(- (* (/ x0 (- 1.0 x1)) (/ x0 (- 1.0 x1))) (* x0 x0))
(+ x0 (/ x0 (- 1.0 x1))))
(* (+ x1 (* x1 x1)) (+ x0 (* x1 (* x1 x0))))))double code(double x0, double x1) {
return (x0 / (1.0 - x1)) - x0;
}
double code(double x0, double x1) {
double tmp;
if ((1.0 - x1) <= 0.9814) {
tmp = (((x0 / (1.0 - x1)) * (x0 / (1.0 - x1))) - (x0 * x0)) / (x0 + (x0 / (1.0 - x1)));
} else {
tmp = (x1 + (x1 * x1)) * (x0 + (x1 * (x1 * x0)));
}
return tmp;
}




Bits error versus x0




Bits error versus x1
Results
| Original | 8.4 |
|---|---|
| Target | 0.5 |
| Herbie | 4.0 |
if (-.f64 1 x1) < 0.98140000000000005Initial program 5.5
rmApplied flip--_binary64_31224.0
if 0.98140000000000005 < (-.f64 1 x1) Initial program 11.3
Taylor expanded around 0 3.9
Simplified3.9
Final simplification4.0
herbie shell --seed 2021059
(FPCore (x0 x1)
:name "(- (/ x0 (- 1 x1)) x0)"
:precision binary64
:pre (or (and (== x0 1.855) (== x1 0.000209)) (and (== x0 2.985) (== x1 0.0186)))
:herbie-target
(/ (* x0 x1) (- 1.0 x1))
(- (/ x0 (- 1.0 x1)) x0))