x + \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;a \le -1.7970758753613627 \cdot 10^{+105}:\\
\;\;\;\;x + y \cdot \frac{z - t}{a}\\
\mathbf{elif}\;a \le 1.2591825253525602 \cdot 10^{-146}:\\
\;\;\;\;\frac{1}{\frac{a}{\left(z - t\right) \cdot y}} + x\\
\mathbf{else}:\\
\;\;\;\;x + \frac{y}{\sqrt[3]{a} \cdot \sqrt[3]{a}} \cdot \frac{z - t}{\sqrt[3]{a}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r16348900 = x;
double r16348901 = y;
double r16348902 = z;
double r16348903 = t;
double r16348904 = r16348902 - r16348903;
double r16348905 = r16348901 * r16348904;
double r16348906 = a;
double r16348907 = r16348905 / r16348906;
double r16348908 = r16348900 + r16348907;
return r16348908;
}
double f(double x, double y, double z, double t, double a) {
double r16348909 = a;
double r16348910 = -1.7970758753613627e+105;
bool r16348911 = r16348909 <= r16348910;
double r16348912 = x;
double r16348913 = y;
double r16348914 = z;
double r16348915 = t;
double r16348916 = r16348914 - r16348915;
double r16348917 = r16348916 / r16348909;
double r16348918 = r16348913 * r16348917;
double r16348919 = r16348912 + r16348918;
double r16348920 = 1.2591825253525602e-146;
bool r16348921 = r16348909 <= r16348920;
double r16348922 = 1.0;
double r16348923 = r16348916 * r16348913;
double r16348924 = r16348909 / r16348923;
double r16348925 = r16348922 / r16348924;
double r16348926 = r16348925 + r16348912;
double r16348927 = cbrt(r16348909);
double r16348928 = r16348927 * r16348927;
double r16348929 = r16348913 / r16348928;
double r16348930 = r16348916 / r16348927;
double r16348931 = r16348929 * r16348930;
double r16348932 = r16348912 + r16348931;
double r16348933 = r16348921 ? r16348926 : r16348932;
double r16348934 = r16348911 ? r16348919 : r16348933;
return r16348934;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 6.1 |
|---|---|
| Target | 0.6 |
| Herbie | 1.8 |
if a < -1.7970758753613627e+105Initial program 11.2
rmApplied *-un-lft-identity11.2
Applied times-frac0.6
Simplified0.6
if -1.7970758753613627e+105 < a < 1.2591825253525602e-146Initial program 2.0
rmApplied clear-num2.1
if 1.2591825253525602e-146 < a Initial program 7.0
rmApplied add-cube-cbrt7.5
Applied times-frac2.1
Final simplification1.8
herbie shell --seed 2019165
(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)))