\frac{x \cdot \left(y - z\right)}{y}
\begin{array}{l}
t_0 := \frac{x \cdot \left(y - z\right)}{y}\\
\mathbf{if}\;t_0 \leq -\infty:\\
\;\;\;\;\frac{y - z}{\frac{y}{x}}\\
\mathbf{elif}\;t_0 \leq -1.3640159599362197 \cdot 10^{+114}:\\
\;\;\;\;x - \frac{x \cdot z}{y}\\
\mathbf{elif}\;t_0 \leq 3.93483722634 \cdot 10^{+95}:\\
\;\;\;\;x \cdot \left(1 - \frac{z}{y}\right)\\
\mathbf{else}:\\
\;\;\;\;\frac{x}{\sqrt[3]{y} \cdot \sqrt[3]{y}} \cdot \frac{y - z}{\sqrt[3]{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)))
(if (<= t_0 (- INFINITY))
(/ (- y z) (/ y x))
(if (<= t_0 -1.3640159599362197e+114)
(- x (/ (* x z) y))
(if (<= t_0 3.93483722634e+95)
(* x (- 1.0 (/ z y)))
(* (/ x (* (cbrt y) (cbrt y))) (/ (- y z) (cbrt 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 tmp;
if (t_0 <= -((double) INFINITY)) {
tmp = (y - z) / (y / x);
} else if (t_0 <= -1.3640159599362197e+114) {
tmp = x - ((x * z) / y);
} else if (t_0 <= 3.93483722634e+95) {
tmp = x * (1.0 - (z / y));
} else {
tmp = (x / (cbrt(y) * cbrt(y))) * ((y - z) / cbrt(y));
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 12.3 |
|---|---|
| Target | 3.4 |
| Herbie | 2.0 |
if (/.f64 (*.f64 x (-.f64 y z)) y) < -inf.0Initial program 64.0
rmApplied clear-num_binary6464.0
Simplified64.0
rmApplied associate-/r/_binary6464.0
Applied associate-*r*_binary640.2
Simplified0.1
rmApplied associate-*l/_binary6464.0
Applied associate-/l*_binary640.2
if -inf.0 < (/.f64 (*.f64 x (-.f64 y z)) y) < -1.36401595993621966e114Initial program 0.2
rmApplied clear-num_binary640.3
Simplified0.3
rmApplied associate-/r/_binary640.3
Applied associate-*r*_binary6412.6
Simplified12.6
rmApplied pow1_binary6412.6
Applied pow1_binary6412.6
Applied pow-prod-down_binary6412.6
Simplified0.2
if -1.36401595993621966e114 < (/.f64 (*.f64 x (-.f64 y z)) y) < 3.9348372263399999e95Initial program 4.9
rmApplied clear-num_binary645.0
Simplified5.0
rmApplied associate-/r/_binary645.0
Applied associate-*r*_binary641.1
Simplified1.0
Taylor expanded around 0 0.9
if 3.9348372263399999e95 < (/.f64 (*.f64 x (-.f64 y z)) y) Initial program 22.6
rmApplied add-cube-cbrt_binary6423.4
Applied times-frac_binary646.7
Final simplification2.0
herbie shell --seed 2021211
(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))