x + \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;z \le -1.8095903151115152 \cdot 10^{-138}:\\
\;\;\;\;x + \left(z - t\right) \cdot \frac{y}{a}\\
\mathbf{elif}\;z \le 6.9390753974297484 \cdot 10^{-149}:\\
\;\;\;\;x + \frac{y}{\frac{a}{z - t}}\\
\mathbf{else}:\\
\;\;\;\;x + \frac{z - t}{\frac{a}{y}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r336680 = x;
double r336681 = y;
double r336682 = z;
double r336683 = t;
double r336684 = r336682 - r336683;
double r336685 = r336681 * r336684;
double r336686 = a;
double r336687 = r336685 / r336686;
double r336688 = r336680 + r336687;
return r336688;
}
double f(double x, double y, double z, double t, double a) {
double r336689 = z;
double r336690 = -1.8095903151115152e-138;
bool r336691 = r336689 <= r336690;
double r336692 = x;
double r336693 = t;
double r336694 = r336689 - r336693;
double r336695 = y;
double r336696 = a;
double r336697 = r336695 / r336696;
double r336698 = r336694 * r336697;
double r336699 = r336692 + r336698;
double r336700 = 6.939075397429748e-149;
bool r336701 = r336689 <= r336700;
double r336702 = r336696 / r336694;
double r336703 = r336695 / r336702;
double r336704 = r336692 + r336703;
double r336705 = r336696 / r336695;
double r336706 = r336694 / r336705;
double r336707 = r336692 + r336706;
double r336708 = r336701 ? r336704 : r336707;
double r336709 = r336691 ? r336699 : r336708;
return r336709;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 6.2 |
|---|---|
| Target | 0.7 |
| Herbie | 2.5 |
if z < -1.8095903151115152e-138Initial program 7.4
rmApplied associate-/l*6.1
rmApplied *-un-lft-identity6.1
Applied *-un-lft-identity6.1
Applied times-frac6.1
Applied *-un-lft-identity6.1
Applied times-frac6.1
Simplified6.1
Simplified2.1
if -1.8095903151115152e-138 < z < 6.939075397429748e-149Initial program 4.3
rmApplied associate-/l*3.3
if 6.939075397429748e-149 < z Initial program 6.5
Taylor expanded around 0 6.5
Simplified2.2
Final simplification2.5
herbie shell --seed 2020047
(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)))