\frac{x \cdot y + z \cdot \left(t - a\right)}{y + z \cdot \left(b - y\right)}\begin{array}{l}
\mathbf{if}\;z \le -5.61354917538780133180731765986612602828 \cdot 10^{193}:\\
\;\;\;\;\frac{t}{b} - \frac{a}{b}\\
\mathbf{elif}\;z \le 5.088199112679185338412991581117806833141 \cdot 10^{118}:\\
\;\;\;\;\frac{\mathsf{fma}\left(z, t - a, y \cdot x\right)}{\mathsf{fma}\left(b - y, z, y\right)}\\
\mathbf{else}:\\
\;\;\;\;\frac{t}{b} - \frac{a}{b}\\
\end{array}double f(double x, double y, double z, double t, double a, double b) {
double r38427439 = x;
double r38427440 = y;
double r38427441 = r38427439 * r38427440;
double r38427442 = z;
double r38427443 = t;
double r38427444 = a;
double r38427445 = r38427443 - r38427444;
double r38427446 = r38427442 * r38427445;
double r38427447 = r38427441 + r38427446;
double r38427448 = b;
double r38427449 = r38427448 - r38427440;
double r38427450 = r38427442 * r38427449;
double r38427451 = r38427440 + r38427450;
double r38427452 = r38427447 / r38427451;
return r38427452;
}
double f(double x, double y, double z, double t, double a, double b) {
double r38427453 = z;
double r38427454 = -5.613549175387801e+193;
bool r38427455 = r38427453 <= r38427454;
double r38427456 = t;
double r38427457 = b;
double r38427458 = r38427456 / r38427457;
double r38427459 = a;
double r38427460 = r38427459 / r38427457;
double r38427461 = r38427458 - r38427460;
double r38427462 = 5.088199112679185e+118;
bool r38427463 = r38427453 <= r38427462;
double r38427464 = r38427456 - r38427459;
double r38427465 = y;
double r38427466 = x;
double r38427467 = r38427465 * r38427466;
double r38427468 = fma(r38427453, r38427464, r38427467);
double r38427469 = r38427457 - r38427465;
double r38427470 = fma(r38427469, r38427453, r38427465);
double r38427471 = r38427468 / r38427470;
double r38427472 = r38427463 ? r38427471 : r38427461;
double r38427473 = r38427455 ? r38427461 : r38427472;
return r38427473;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a




Bits error versus b
| Original | 23.4 |
|---|---|
| Target | 18.1 |
| Herbie | 19.5 |
if z < -5.613549175387801e+193 or 5.088199112679185e+118 < z Initial program 49.1
Simplified49.1
rmApplied clear-num49.1
Taylor expanded around inf 33.1
if -5.613549175387801e+193 < z < 5.088199112679185e+118Initial program 15.1
Simplified15.1
Final simplification19.5
herbie shell --seed 2019168 +o rules:numerics
(FPCore (x y z t a b)
:name "Development.Shake.Progress:decay from shake-0.15.5"
:herbie-target
(- (/ (+ (* z t) (* y x)) (+ y (* z (- b y)))) (/ a (+ (- b y) (/ y z))))
(/ (+ (* x y) (* z (- t a))) (+ y (* z (- b y)))))