x + \frac{\left(y - x\right) \cdot z}{t}\begin{array}{l}
\mathbf{if}\;x \leq -6.8672134430398595 \cdot 10^{-56}:\\
\;\;\;\;x + \left(y - x\right) \cdot \frac{z}{t}\\
\mathbf{else}:\\
\;\;\;\;x + z \cdot \frac{y - x}{t}\\
\end{array}(FPCore (x y z t) :precision binary64 (+ x (/ (* (- y x) z) t)))
(FPCore (x y z t) :precision binary64 (if (<= x -6.8672134430398595e-56) (+ x (* (- y x) (/ z t))) (+ x (* z (/ (- y x) t)))))
double code(double x, double y, double z, double t) {
return x + (((y - x) * z) / t);
}
double code(double x, double y, double z, double t) {
double tmp;
if (x <= -6.8672134430398595e-56) {
tmp = x + ((y - x) * (z / t));
} else {
tmp = x + (z * ((y - x) / t));
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 6.7 |
|---|---|
| Target | 2.1 |
| Herbie | 4.3 |
if x < -6.86721344303986e-56Initial program 8.4
rmApplied *-un-lft-identity_binary64_116728.4
Applied times-frac_binary64_116780.4
if -6.86721344303986e-56 < x Initial program 6.1
Taylor expanded around 0 6.1
Simplified5.8
Final simplification4.3
herbie shell --seed 2021043
(FPCore (x y z t)
:name "Numeric.Histogram:binBounds from Chart-1.5.3"
:precision binary64
:herbie-target
(if (< x -9.025511195533005e-135) (- x (* (/ z t) (- x y))) (if (< x 4.275032163700715e-250) (+ x (* (/ (- y x) t) z)) (+ x (/ (- y x) (/ t z)))))
(+ x (/ (* (- y x) z) t)))