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 r319924 = x;
double r319925 = y;
double r319926 = z;
double r319927 = t;
double r319928 = r319926 - r319927;
double r319929 = r319925 * r319928;
double r319930 = a;
double r319931 = r319929 / r319930;
double r319932 = r319924 + r319931;
return r319932;
}
double f(double x, double y, double z, double t, double a) {
double r319933 = y;
double r319934 = -2486.642887294508;
bool r319935 = r319933 <= r319934;
double r319936 = 7.809854763613243e-193;
bool r319937 = r319933 <= r319936;
double r319938 = !r319937;
bool r319939 = r319935 || r319938;
double r319940 = x;
double r319941 = a;
double r319942 = z;
double r319943 = t;
double r319944 = r319942 - r319943;
double r319945 = r319941 / r319944;
double r319946 = r319933 / r319945;
double r319947 = r319940 + r319946;
double r319948 = r319933 * r319944;
double r319949 = r319948 / r319941;
double r319950 = r319940 + r319949;
double r319951 = r319939 ? r319947 : r319950;
return r319951;
}




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)))