x + \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;y \le -2486.642887294508 \lor \neg \left(y \le 7.8098547636132432 \cdot 10^{-193}\right):\\
\;\;\;\;x + \frac{y}{\frac{a}{z - t}}\\
\mathbf{else}:\\
\;\;\;\;x + \frac{y \cdot \left(z - t\right)}{a}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r263720 = x;
double r263721 = y;
double r263722 = z;
double r263723 = t;
double r263724 = r263722 - r263723;
double r263725 = r263721 * r263724;
double r263726 = a;
double r263727 = r263725 / r263726;
double r263728 = r263720 + r263727;
return r263728;
}
double f(double x, double y, double z, double t, double a) {
double r263729 = y;
double r263730 = -2486.642887294508;
bool r263731 = r263729 <= r263730;
double r263732 = 7.809854763613243e-193;
bool r263733 = r263729 <= r263732;
double r263734 = !r263733;
bool r263735 = r263731 || r263734;
double r263736 = x;
double r263737 = a;
double r263738 = z;
double r263739 = t;
double r263740 = r263738 - r263739;
double r263741 = r263737 / r263740;
double r263742 = r263729 / r263741;
double r263743 = r263736 + r263742;
double r263744 = r263729 * r263740;
double r263745 = r263744 / r263737;
double r263746 = r263736 + r263745;
double r263747 = r263735 ? r263743 : r263746;
return r263747;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 6.0 |
|---|---|
| Target | 0.6 |
| Herbie | 1.6 |
if y < -2486.642887294508 or 7.809854763613243e-193 < y Initial program 10.3
rmApplied associate-/l*2.4
if -2486.642887294508 < y < 7.809854763613243e-193Initial program 0.5
Final simplification1.6
herbie shell --seed 2020062
(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)))