\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)}\begin{array}{l}
\mathbf{if}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} \leq -1.0776202918311757 \cdot 10^{+307}:\\
\;\;\;\;\frac{-1}{\frac{y - b}{t - a}} - \frac{x}{z + -1}\\
\mathbf{elif}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} \leq -3.0865535911923863 \cdot 10^{-232}:\\
\;\;\;\;\frac{1}{\frac{y + z \cdot \left(b - y\right)}{x \cdot y + z \cdot \left(t - a\right)}}\\
\mathbf{elif}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} \leq 0:\\
\;\;\;\;\frac{t}{b - y} + \left(\left(\frac{\frac{x \cdot y}{z}}{b - y} + \frac{a}{z} \cdot \frac{y}{{\left(b - y\right)}^{2}}\right) - \left(\frac{y}{{\left(b - y\right)}^{2}} \cdot \frac{t}{z} + \frac{a}{b - y}\right)\right)\\
\mathbf{elif}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} \leq 1.3387691926349812 \cdot 10^{+279}:\\
\;\;\;\;\frac{\left(x \cdot y + z \cdot t\right) - z \cdot a}{y + z \cdot \left(b - y\right)}\\
\mathbf{elif}\;\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)} \leq \infty:\\
\;\;\;\;\frac{y}{\frac{y + z \cdot \left(b - y\right)}{x}} + \frac{z}{\frac{y + z \cdot \left(b - y\right)}{t - a}}\\
\mathbf{else}:\\
\;\;\;\;\frac{t}{b - y} + \left(\left(\frac{a}{z} \cdot \frac{y}{{\left(b - y\right)}^{2}} + \frac{y}{z} \cdot \frac{x}{b - y}\right) - \left(\frac{a}{b - y} + \frac{y}{z} \cdot \frac{t}{{\left(b - y\right)}^{2}}\right)\right)\\
\end{array}(FPCore (x y z t a b) :precision binary64 (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))))
(FPCore (x y z t a b)
:precision binary64
(if (<=
(/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y))))
-1.0776202918311757e+307)
(- (/ -1.0 (/ (- y b) (- t a))) (/ x (+ z -1.0)))
(if (<=
(/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y))))
-3.0865535911923863e-232)
(/ 1.0 (/ (+ y (* z (- b y))) (+ (* x y) (* z (- t a)))))
(if (<= (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))) 0.0)
(+
(/ t (- b y))
(-
(+ (/ (/ (* x y) z) (- b y)) (* (/ a z) (/ y (pow (- b y) 2.0))))
(+ (* (/ y (pow (- b y) 2.0)) (/ t z)) (/ a (- b y)))))
(if (<=
(/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y))))
1.3387691926349812e+279)
(/ (- (+ (* x y) (* z t)) (* z a)) (+ y (* z (- b y))))
(if (<= (/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))) INFINITY)
(+
(/ y (/ (+ y (* z (- b y))) x))
(/ z (/ (+ y (* z (- b y))) (- t a))))
(+
(/ t (- b y))
(-
(+ (* (/ a z) (/ y (pow (- b y) 2.0))) (* (/ y z) (/ x (- b y))))
(+ (/ a (- b y)) (* (/ y z) (/ t (pow (- b y) 2.0))))))))))))double code(double x, double y, double z, double t, double a, double b) {
return ((x * y) + (z * (t - a))) / (y + (z * (b - y)));
}
double code(double x, double y, double z, double t, double a, double b) {
double tmp;
if ((((x * y) + (z * (t - a))) / (y + (z * (b - y)))) <= -1.0776202918311757e+307) {
tmp = (-1.0 / ((y - b) / (t - a))) - (x / (z + -1.0));
} else if ((((x * y) + (z * (t - a))) / (y + (z * (b - y)))) <= -3.0865535911923863e-232) {
tmp = 1.0 / ((y + (z * (b - y))) / ((x * y) + (z * (t - a))));
} else if ((((x * y) + (z * (t - a))) / (y + (z * (b - y)))) <= 0.0) {
tmp = (t / (b - y)) + (((((x * y) / z) / (b - y)) + ((a / z) * (y / pow((b - y), 2.0)))) - (((y / pow((b - y), 2.0)) * (t / z)) + (a / (b - y))));
} else if ((((x * y) + (z * (t - a))) / (y + (z * (b - y)))) <= 1.3387691926349812e+279) {
tmp = (((x * y) + (z * t)) - (z * a)) / (y + (z * (b - y)));
} else if ((((x * y) + (z * (t - a))) / (y + (z * (b - y)))) <= ((double) INFINITY)) {
tmp = (y / ((y + (z * (b - y))) / x)) + (z / ((y + (z * (b - y))) / (t - a)));
} else {
tmp = (t / (b - y)) + ((((a / z) * (y / pow((b - y), 2.0))) + ((y / z) * (x / (b - y)))) - ((a / (b - y)) + ((y / z) * (t / pow((b - y), 2.0)))));
}
return tmp;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
Results
| Original | 23.3 |
|---|---|
| Target | 18.3 |
| Herbie | 1.4 |
if (/.f64 (+.f64 (*.f64 x y) (*.f64 z (-.f64 t a))) (+.f64 y (*.f64 z (-.f64 b y)))) < -1.0776202918311757e307Initial program 63.5
Taylor expanded around 0 63.5
Simplified34.8
rmApplied div-inv_binary64_1678434.9
Applied add-cube-cbrt_binary64_1682235.3
Applied times-frac_binary64_1679342.9
Simplified42.9
Taylor expanded around -inf 34.6
Simplified34.7
Taylor expanded around -inf 2.9
Simplified2.9
if -1.0776202918311757e307 < (/.f64 (+.f64 (*.f64 x y) (*.f64 z (-.f64 t a))) (+.f64 y (*.f64 z (-.f64 b y)))) < -3.08655359119238627e-232Initial program 0.3
rmApplied clear-num_binary64_167860.4
if -3.08655359119238627e-232 < (/.f64 (+.f64 (*.f64 x y) (*.f64 z (-.f64 t a))) (+.f64 y (*.f64 z (-.f64 b y)))) < 0.0Initial program 41.5
Taylor expanded around inf 20.7
Simplified5.1
if 0.0 < (/.f64 (+.f64 (*.f64 x y) (*.f64 z (-.f64 t a))) (+.f64 y (*.f64 z (-.f64 b y)))) < 1.3387691926349812e279Initial program 0.3
rmApplied sub-neg_binary64_167800.3
Applied distribute-rgt-in_binary64_167370.3
Applied associate-+r+_binary64_167190.3
if 1.3387691926349812e279 < (/.f64 (+.f64 (*.f64 x y) (*.f64 z (-.f64 t a))) (+.f64 y (*.f64 z (-.f64 b y)))) < +inf.0Initial program 57.6
Taylor expanded around 0 57.6
Simplified33.8
rmApplied associate-/l*_binary64_167324.7
if +inf.0 < (/.f64 (+.f64 (*.f64 x y) (*.f64 z (-.f64 t a))) (+.f64 y (*.f64 z (-.f64 b y)))) Initial program 64.0
Taylor expanded around inf 39.8
Simplified0.2
Final simplification1.4
herbie shell --seed 2021176
(FPCore (x y z t a b)
:name "Development.Shake.Progress:decay from shake-0.15.5"
:precision binary64
:herbie-target
(- (/ (+ (* z t) (* y x)) (+ y (* z (- b y)))) (/ a (+ (- b y) (/ y z))))
(/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))))