x + \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;a \le -12943396756.221923828125 \lor \neg \left(a \le 4.018884300263023536054951700128720971934 \cdot 10^{-127}\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 r395282 = x;
double r395283 = y;
double r395284 = z;
double r395285 = t;
double r395286 = r395284 - r395285;
double r395287 = r395283 * r395286;
double r395288 = a;
double r395289 = r395287 / r395288;
double r395290 = r395282 + r395289;
return r395290;
}
double f(double x, double y, double z, double t, double a) {
double r395291 = a;
double r395292 = -12943396756.221924;
bool r395293 = r395291 <= r395292;
double r395294 = 4.0188843002630235e-127;
bool r395295 = r395291 <= r395294;
double r395296 = !r395295;
bool r395297 = r395293 || r395296;
double r395298 = x;
double r395299 = y;
double r395300 = z;
double r395301 = t;
double r395302 = r395300 - r395301;
double r395303 = r395291 / r395302;
double r395304 = r395299 / r395303;
double r395305 = r395298 + r395304;
double r395306 = r395299 * r395302;
double r395307 = r395306 / r395291;
double r395308 = r395298 + r395307;
double r395309 = r395297 ? r395305 : r395308;
return r395309;
}




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.2 |
if a < -12943396756.221924 or 4.0188843002630235e-127 < a Initial program 8.9
rmApplied associate-/l*1.4
if -12943396756.221924 < a < 4.0188843002630235e-127Initial program 0.8
Final simplification1.2
herbie shell --seed 2019353
(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)))