x + \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;y \cdot \left(z - t\right) \le -4.9168923767645714 \cdot 10^{80}:\\
\;\;\;\;x + y \cdot \frac{z - t}{a}\\
\mathbf{elif}\;y \cdot \left(z - t\right) \le 2.08730857278766648 \cdot 10^{115}:\\
\;\;\;\;x + \frac{y \cdot \left(z - t\right)}{a}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{y}{a}, z - t, x\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r293123 = x;
double r293124 = y;
double r293125 = z;
double r293126 = t;
double r293127 = r293125 - r293126;
double r293128 = r293124 * r293127;
double r293129 = a;
double r293130 = r293128 / r293129;
double r293131 = r293123 + r293130;
return r293131;
}
double f(double x, double y, double z, double t, double a) {
double r293132 = y;
double r293133 = z;
double r293134 = t;
double r293135 = r293133 - r293134;
double r293136 = r293132 * r293135;
double r293137 = -4.916892376764571e+80;
bool r293138 = r293136 <= r293137;
double r293139 = x;
double r293140 = a;
double r293141 = r293135 / r293140;
double r293142 = r293132 * r293141;
double r293143 = r293139 + r293142;
double r293144 = 2.0873085727876665e+115;
bool r293145 = r293136 <= r293144;
double r293146 = r293136 / r293140;
double r293147 = r293139 + r293146;
double r293148 = r293132 / r293140;
double r293149 = fma(r293148, r293135, r293139);
double r293150 = r293145 ? r293147 : r293149;
double r293151 = r293138 ? r293143 : r293150;
return r293151;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 6.3 |
|---|---|
| Target | 0.7 |
| Herbie | 1.4 |
if (* y (- z t)) < -4.916892376764571e+80Initial program 14.6
rmApplied *-un-lft-identity14.6
Applied times-frac3.8
Simplified3.8
if -4.916892376764571e+80 < (* y (- z t)) < 2.0873085727876665e+115Initial program 0.5
if 2.0873085727876665e+115 < (* y (- z t)) Initial program 18.1
Simplified2.2
Final simplification1.4
herbie shell --seed 2020046 +o rules:numerics
(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)))