x + \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;y \cdot \left(z - t\right) \le -1.8638720380733864 \cdot 10^{137} \lor \neg \left(y \cdot \left(z - t\right) \le 1.10810879622775848 \cdot 10^{56}\right):\\
\;\;\;\;x + \frac{z - t}{\frac{a}{y}}\\
\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 r196223 = x;
double r196224 = y;
double r196225 = z;
double r196226 = t;
double r196227 = r196225 - r196226;
double r196228 = r196224 * r196227;
double r196229 = a;
double r196230 = r196228 / r196229;
double r196231 = r196223 + r196230;
return r196231;
}
double f(double x, double y, double z, double t, double a) {
double r196232 = y;
double r196233 = z;
double r196234 = t;
double r196235 = r196233 - r196234;
double r196236 = r196232 * r196235;
double r196237 = -1.8638720380733864e+137;
bool r196238 = r196236 <= r196237;
double r196239 = 1.1081087962277585e+56;
bool r196240 = r196236 <= r196239;
double r196241 = !r196240;
bool r196242 = r196238 || r196241;
double r196243 = x;
double r196244 = a;
double r196245 = r196244 / r196232;
double r196246 = r196235 / r196245;
double r196247 = r196243 + r196246;
double r196248 = r196236 / r196244;
double r196249 = r196243 + r196248;
double r196250 = r196242 ? r196247 : r196249;
return r196250;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 6.3 |
|---|---|
| Target | 0.7 |
| Herbie | 1.0 |
if (* y (- z t)) < -1.8638720380733864e+137 or 1.1081087962277585e+56 < (* y (- z t)) Initial program 16.1
rmApplied associate-/l*3.2
rmApplied associate-/r/1.9
rmApplied pow11.9
Applied pow11.9
Applied pow-prod-down1.9
Simplified1.9
if -1.8638720380733864e+137 < (* y (- z t)) < 1.1081087962277585e+56Initial program 0.5
Final simplification1.0
herbie shell --seed 2020046
(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)))