x - \frac{y \cdot \left(z - t\right)}{a}\begin{array}{l}
\mathbf{if}\;y \le -1.5745896431018994 \cdot 10^{66}:\\
\;\;\;\;x - y \cdot \frac{z - t}{a}\\
\mathbf{elif}\;y \le 1.8297702711364304 \cdot 10^{-148}:\\
\;\;\;\;x - \frac{1}{\frac{a}{y \cdot \left(z - t\right)}}\\
\mathbf{else}:\\
\;\;\;\;x - \frac{y}{\frac{a}{z - t}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r317650 = x;
double r317651 = y;
double r317652 = z;
double r317653 = t;
double r317654 = r317652 - r317653;
double r317655 = r317651 * r317654;
double r317656 = a;
double r317657 = r317655 / r317656;
double r317658 = r317650 - r317657;
return r317658;
}
double f(double x, double y, double z, double t, double a) {
double r317659 = y;
double r317660 = -1.5745896431018994e+66;
bool r317661 = r317659 <= r317660;
double r317662 = x;
double r317663 = z;
double r317664 = t;
double r317665 = r317663 - r317664;
double r317666 = a;
double r317667 = r317665 / r317666;
double r317668 = r317659 * r317667;
double r317669 = r317662 - r317668;
double r317670 = 1.8297702711364304e-148;
bool r317671 = r317659 <= r317670;
double r317672 = 1.0;
double r317673 = r317659 * r317665;
double r317674 = r317666 / r317673;
double r317675 = r317672 / r317674;
double r317676 = r317662 - r317675;
double r317677 = r317666 / r317665;
double r317678 = r317659 / r317677;
double r317679 = r317662 - r317678;
double r317680 = r317671 ? r317676 : r317679;
double r317681 = r317661 ? r317669 : r317680;
return r317681;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 6.5 |
|---|---|
| Target | 0.7 |
| Herbie | 1.3 |
if y < -1.5745896431018994e+66Initial program 19.0
rmApplied *-un-lft-identity19.0
Applied times-frac0.9
Simplified0.9
if -1.5745896431018994e+66 < y < 1.8297702711364304e-148Initial program 0.7
rmApplied clear-num0.8
if 1.8297702711364304e-148 < y Initial program 10.2
rmApplied associate-/l*2.2
Final simplification1.3
herbie shell --seed 2020083
(FPCore (x y z t a)
:name "Optimisation.CirclePacking:place from circle-packing-0.1.0.4, F"
: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)))