x + \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;y \le -1.5745896431018994 \cdot 10^{66}:\\
\;\;\;\;x + y \cdot \frac{z - t}{a}\\
\mathbf{elif}\;y \le 1.8297702711364304 \cdot 10^{-148}:\\
\;\;\;\;x + \frac{1}{\frac{a}{y \cdot \left(z - t\right)}}\\
\mathbf{else}:\\
\;\;\;\;x + \frac{y}{\frac{a}{z - t}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r337520 = x;
double r337521 = y;
double r337522 = z;
double r337523 = t;
double r337524 = r337522 - r337523;
double r337525 = r337521 * r337524;
double r337526 = a;
double r337527 = r337525 / r337526;
double r337528 = r337520 + r337527;
return r337528;
}
double f(double x, double y, double z, double t, double a) {
double r337529 = y;
double r337530 = -1.5745896431018994e+66;
bool r337531 = r337529 <= r337530;
double r337532 = x;
double r337533 = z;
double r337534 = t;
double r337535 = r337533 - r337534;
double r337536 = a;
double r337537 = r337535 / r337536;
double r337538 = r337529 * r337537;
double r337539 = r337532 + r337538;
double r337540 = 1.8297702711364304e-148;
bool r337541 = r337529 <= r337540;
double r337542 = 1.0;
double r337543 = r337529 * r337535;
double r337544 = r337536 / r337543;
double r337545 = r337542 / r337544;
double r337546 = r337532 + r337545;
double r337547 = r337536 / r337535;
double r337548 = r337529 / r337547;
double r337549 = r337532 + r337548;
double r337550 = r337541 ? r337546 : r337549;
double r337551 = r337531 ? r337539 : r337550;
return r337551;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 6.5 |
|---|---|
| Target | 0.7 |
| Herbie | 1.3 |
if y < -1.5745896431018994e+66Initial program 19.0
rmApplied *-un-lft-identity19.0
Applied times-frac0.9
Simplified0.9
if -1.5745896431018994e+66 < y < 1.8297702711364304e-148Initial program 0.7
rmApplied clear-num0.8
if 1.8297702711364304e-148 < y Initial program 10.2
rmApplied associate-/l*2.2
Final simplification1.3
herbie shell --seed 2020083
(FPCore (x y z t a)
:name "Optimisation.CirclePacking:place from circle-packing-0.1.0.4, E"
:precision binary64
:herbie-target
(if (< y -1.0761266216389975e-10) (+ x (/ 1 (/ (/ a (- z t)) y))) (if (< y 2.894426862792089e-49) (+ x (/ (* y (- z t)) a)) (+ x (/ y (/ a (- z t))))))
(+ x (/ (* y (- z t)) a)))