\frac{x - y}{z - y} \cdot t\begin{array}{l}
\mathbf{if}\;y \leq 5.704566056545378 \cdot 10^{-299} \lor \neg \left(y \leq 2.795632804998043 \cdot 10^{-116}\right):\\
\;\;\;\;\frac{x - y}{z - y} \cdot t\\
\mathbf{else}:\\
\;\;\;\;\left(\sqrt[3]{x - y} \cdot \sqrt[3]{x - y}\right) \cdot \left(t \cdot \frac{\sqrt[3]{x - y}}{z - y}\right)\\
\end{array}(FPCore (x y z t) :precision binary64 (* (/ (- x y) (- z y)) t))
(FPCore (x y z t) :precision binary64 (if (or (<= y 5.704566056545378e-299) (not (<= y 2.795632804998043e-116))) (* (/ (- x y) (- z y)) t) (* (* (cbrt (- x y)) (cbrt (- x y))) (* t (/ (cbrt (- x y)) (- z y))))))
double code(double x, double y, double z, double t) {
return ((x - y) / (z - y)) * t;
}
double code(double x, double y, double z, double t) {
double tmp;
if ((y <= 5.704566056545378e-299) || !(y <= 2.795632804998043e-116)) {
tmp = ((x - y) / (z - y)) * t;
} else {
tmp = (cbrt(x - y) * cbrt(x - y)) * (t * (cbrt(x - y) / (z - y)));
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t
Results
| Original | 2.2 |
|---|---|
| Target | 2.2 |
| Herbie | 2.1 |
if y < 5.7045660565453784e-299 or 2.79563280499804283e-116 < y Initial program 1.6
if 5.7045660565453784e-299 < y < 2.79563280499804283e-116Initial program 6.2
rmApplied *-un-lft-identity_binary64_116726.2
Applied add-cube-cbrt_binary64_117077.0
Applied times-frac_binary64_116787.0
Applied associate-*l*_binary64_116134.8
Simplified4.8
Final simplification2.1
herbie shell --seed 2020342
(FPCore (x y z t)
:name "Numeric.Signal.Multichannel:$cput from hsignal-0.2.7.1"
:precision binary64
:herbie-target
(/ t (/ (- z y) (- x y)))
(* (/ (- x y) (- z y)) t))