x + y \cdot \frac{z - t}{a - t}\begin{array}{l}
\mathbf{if}\;t \le -1.0071455594193599 \cdot 10^{-271} \lor \neg \left(t \le 7.46702847266602817 \cdot 10^{-71}\right):\\
\;\;\;\;x + y \cdot \left(\frac{z}{a - t} - \frac{t}{a - t}\right)\\
\mathbf{else}:\\
\;\;\;\;x + \left(\left(z - t\right) \cdot y\right) \cdot \frac{1}{a - t}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r577916 = x;
double r577917 = y;
double r577918 = z;
double r577919 = t;
double r577920 = r577918 - r577919;
double r577921 = a;
double r577922 = r577921 - r577919;
double r577923 = r577920 / r577922;
double r577924 = r577917 * r577923;
double r577925 = r577916 + r577924;
return r577925;
}
double f(double x, double y, double z, double t, double a) {
double r577926 = t;
double r577927 = -1.0071455594193599e-271;
bool r577928 = r577926 <= r577927;
double r577929 = 7.467028472666028e-71;
bool r577930 = r577926 <= r577929;
double r577931 = !r577930;
bool r577932 = r577928 || r577931;
double r577933 = x;
double r577934 = y;
double r577935 = z;
double r577936 = a;
double r577937 = r577936 - r577926;
double r577938 = r577935 / r577937;
double r577939 = r577926 / r577937;
double r577940 = r577938 - r577939;
double r577941 = r577934 * r577940;
double r577942 = r577933 + r577941;
double r577943 = r577935 - r577926;
double r577944 = r577943 * r577934;
double r577945 = 1.0;
double r577946 = r577945 / r577937;
double r577947 = r577944 * r577946;
double r577948 = r577933 + r577947;
double r577949 = r577932 ? r577942 : r577948;
return r577949;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 1.4 |
|---|---|
| Target | 0.5 |
| Herbie | 1.5 |
if t < -1.0071455594193599e-271 or 7.467028472666028e-71 < t Initial program 0.9
rmApplied div-sub0.8
if -1.0071455594193599e-271 < t < 7.467028472666028e-71Initial program 3.5
rmApplied *-un-lft-identity3.5
Applied add-cube-cbrt3.9
Applied times-frac3.9
Applied associate-*r*2.9
Simplified2.9
rmApplied div-inv2.9
Applied associate-*r*4.2
Simplified3.9
Final simplification1.5
herbie shell --seed 2020056
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisLine from plot-0.2.3.4, B"
:precision binary64
:herbie-target
(if (< y -8.508084860551241e-17) (+ x (* y (/ (- z t) (- a t)))) (if (< y 2.894426862792089e-49) (+ x (* (* y (- z t)) (/ 1 (- a t)))) (+ x (* y (/ (- z t) (- a t))))))
(+ x (* y (/ (- z t) (- a t)))))