x + \frac{y \cdot \left(z - t\right)}{z - a}\begin{array}{l}
\mathbf{if}\;\frac{y \cdot \left(z - t\right)}{z - a} = -\infty:\\
\;\;\;\;\frac{z - t}{z - a} \cdot y + x\\
\mathbf{elif}\;\frac{y \cdot \left(z - t\right)}{z - a} \le 3.941060132304761944440726014815691553449 \cdot 10^{276}:\\
\;\;\;\;x + \frac{y \cdot \left(z - t\right)}{z - a}\\
\mathbf{else}:\\
\;\;\;\;\frac{1}{\frac{\frac{z - a}{y}}{z - t}} + x\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r558230 = x;
double r558231 = y;
double r558232 = z;
double r558233 = t;
double r558234 = r558232 - r558233;
double r558235 = r558231 * r558234;
double r558236 = a;
double r558237 = r558232 - r558236;
double r558238 = r558235 / r558237;
double r558239 = r558230 + r558238;
return r558239;
}
double f(double x, double y, double z, double t, double a) {
double r558240 = y;
double r558241 = z;
double r558242 = t;
double r558243 = r558241 - r558242;
double r558244 = r558240 * r558243;
double r558245 = a;
double r558246 = r558241 - r558245;
double r558247 = r558244 / r558246;
double r558248 = -inf.0;
bool r558249 = r558247 <= r558248;
double r558250 = r558243 / r558246;
double r558251 = r558250 * r558240;
double r558252 = x;
double r558253 = r558251 + r558252;
double r558254 = 3.941060132304762e+276;
bool r558255 = r558247 <= r558254;
double r558256 = r558252 + r558247;
double r558257 = 1.0;
double r558258 = r558246 / r558240;
double r558259 = r558258 / r558243;
double r558260 = r558257 / r558259;
double r558261 = r558260 + r558252;
double r558262 = r558255 ? r558256 : r558261;
double r558263 = r558249 ? r558253 : r558262;
return r558263;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 11.0 |
|---|---|
| Target | 1.3 |
| Herbie | 0.4 |
if (/ (* y (- z t)) (- z a)) < -inf.0Initial program 64.0
Simplified0.2
rmApplied clear-num0.2
rmApplied fma-udef0.2
Simplified0.1
rmApplied associate-/r/0.1
if -inf.0 < (/ (* y (- z t)) (- z a)) < 3.941060132304762e+276Initial program 0.2
if 3.941060132304762e+276 < (/ (* y (- z t)) (- z a)) Initial program 59.1
Simplified1.9
rmApplied clear-num2.0
rmApplied fma-udef2.0
Simplified1.8
rmApplied clear-num1.9
Final simplification0.4
herbie shell --seed 2020001 +o rules:numerics
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisTicks from plot-0.2.3.4, A"
:precision binary64
:herbie-target
(+ x (/ y (/ (- z a) (- z t))))
(+ x (/ (* y (- z t)) (- z a))))