x + \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;\left(z - t\right) \cdot y \le -1.1358477187951435 \cdot 10^{+146}:\\
\;\;\;\;x + \left(\frac{z}{\frac{a}{y}} - \frac{t}{\frac{a}{y}}\right)\\
\mathbf{elif}\;\left(z - t\right) \cdot y \le 4.602631262379337 \cdot 10^{+178}:\\
\;\;\;\;x + \frac{\left(z - t\right) \cdot y}{a}\\
\mathbf{else}:\\
\;\;\;\;x + \left(z - t\right) \cdot \frac{y}{a}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r15461788 = x;
double r15461789 = y;
double r15461790 = z;
double r15461791 = t;
double r15461792 = r15461790 - r15461791;
double r15461793 = r15461789 * r15461792;
double r15461794 = a;
double r15461795 = r15461793 / r15461794;
double r15461796 = r15461788 + r15461795;
return r15461796;
}
double f(double x, double y, double z, double t, double a) {
double r15461797 = z;
double r15461798 = t;
double r15461799 = r15461797 - r15461798;
double r15461800 = y;
double r15461801 = r15461799 * r15461800;
double r15461802 = -1.1358477187951435e+146;
bool r15461803 = r15461801 <= r15461802;
double r15461804 = x;
double r15461805 = a;
double r15461806 = r15461805 / r15461800;
double r15461807 = r15461797 / r15461806;
double r15461808 = r15461798 / r15461806;
double r15461809 = r15461807 - r15461808;
double r15461810 = r15461804 + r15461809;
double r15461811 = 4.602631262379337e+178;
bool r15461812 = r15461801 <= r15461811;
double r15461813 = r15461801 / r15461805;
double r15461814 = r15461804 + r15461813;
double r15461815 = r15461800 / r15461805;
double r15461816 = r15461799 * r15461815;
double r15461817 = r15461804 + r15461816;
double r15461818 = r15461812 ? r15461814 : r15461817;
double r15461819 = r15461803 ? r15461810 : r15461818;
return r15461819;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 5.5 |
|---|---|
| Target | 0.7 |
| Herbie | 0.6 |
if (* y (- z t)) < -1.1358477187951435e+146Initial program 19.1
Taylor expanded around 0 19.2
Simplified1.2
rmApplied div-sub1.2
if -1.1358477187951435e+146 < (* y (- z t)) < 4.602631262379337e+178Initial program 0.5
if 4.602631262379337e+178 < (* y (- z t)) Initial program 23.3
Taylor expanded around 0 23.3
Simplified0.9
rmApplied div-inv1.0
Simplified0.7
Final simplification0.6
herbie shell --seed 2019158
(FPCore (x y z t a)
:name "Optimisation.CirclePacking:place from circle-packing-0.1.0.4, E"
: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)))