\frac{x \cdot \left(y - z\right)}{y}
\begin{array}{l}
t_0 := \frac{x \cdot \left(y - z\right)}{y}\\
t_1 := x - \frac{x \cdot z}{y}\\
\mathbf{if}\;t_0 \leq -2.1152773731587005 \cdot 10^{+119}:\\
\;\;\;\;t_1\\
\mathbf{elif}\;t_0 \leq 6.209461191697141 \cdot 10^{-263}:\\
\;\;\;\;\frac{x}{\frac{y}{y - z}}\\
\mathbf{elif}\;t_0 \leq 4.38171916267836 \cdot 10^{+273}:\\
\;\;\;\;t_1\\
\mathbf{else}:\\
\;\;\;\;x \cdot \frac{y - z}{y}\\
\end{array}
(FPCore (x y z) :precision binary64 (/ (* x (- y z)) y))
(FPCore (x y z)
:precision binary64
(let* ((t_0 (/ (* x (- y z)) y)) (t_1 (- x (/ (* x z) y))))
(if (<= t_0 -2.1152773731587005e+119)
t_1
(if (<= t_0 6.209461191697141e-263)
(/ x (/ y (- y z)))
(if (<= t_0 4.38171916267836e+273) t_1 (* x (/ (- y z) y)))))))double code(double x, double y, double z) {
return (x * (y - z)) / y;
}
double code(double x, double y, double z) {
double t_0 = (x * (y - z)) / y;
double t_1 = x - ((x * z) / y);
double tmp;
if (t_0 <= -2.1152773731587005e+119) {
tmp = t_1;
} else if (t_0 <= 6.209461191697141e-263) {
tmp = x / (y / (y - z));
} else if (t_0 <= 4.38171916267836e+273) {
tmp = t_1;
} else {
tmp = x * ((y - z) / y);
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 12.4 |
|---|---|
| Target | 3.1 |
| Herbie | 2.2 |
if (/.f64 (*.f64 x (-.f64 y z)) y) < -2.11527737315870047e119 or 6.2094611916971407e-263 < (/.f64 (*.f64 x (-.f64 y z)) y) < 4.38171916267835984e273Initial program 9.5
Taylor expanded in y around 0 2.9
if -2.11527737315870047e119 < (/.f64 (*.f64 x (-.f64 y z)) y) < 6.2094611916971407e-263Initial program 6.8
Applied associate-/l*_binary641.0
if 4.38171916267835984e273 < (/.f64 (*.f64 x (-.f64 y z)) y) Initial program 52.7
Applied *-un-lft-identity_binary6452.7
Applied times-frac_binary642.5
Simplified2.5
Final simplification2.2
herbie shell --seed 2022096
(FPCore (x y z)
:name "Diagrams.Backend.Cairo.Internal:setTexture from diagrams-cairo-1.3.0.3"
:precision binary64
:herbie-target
(if (< z -2.060202331921739e+104) (- x (/ (* z x) y)) (if (< z 1.6939766013828526e+213) (/ x (/ y (- y z))) (* (- y z) (/ x y))))
(/ (* x (- y z)) y))