x + \frac{y \cdot \left(z - t\right)}{z - a}\begin{array}{l}
\mathbf{if}\;\frac{y \cdot \left(z - t\right)}{z - a} \le -5.2646213116575603 \cdot 10^{290}:\\
\;\;\;\;y \cdot \left(\left(z - t\right) \cdot \frac{1}{z - a}\right) + x\\
\mathbf{elif}\;\frac{y \cdot \left(z - t\right)}{z - a} \le 1.1606107956763068 \cdot 10^{295}:\\
\;\;\;\;x + \frac{y \cdot \left(z - t\right)}{z - a}\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{1}{\frac{z - a}{y}}, z - t, x\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r559440 = x;
double r559441 = y;
double r559442 = z;
double r559443 = t;
double r559444 = r559442 - r559443;
double r559445 = r559441 * r559444;
double r559446 = a;
double r559447 = r559442 - r559446;
double r559448 = r559445 / r559447;
double r559449 = r559440 + r559448;
return r559449;
}
double f(double x, double y, double z, double t, double a) {
double r559450 = y;
double r559451 = z;
double r559452 = t;
double r559453 = r559451 - r559452;
double r559454 = r559450 * r559453;
double r559455 = a;
double r559456 = r559451 - r559455;
double r559457 = r559454 / r559456;
double r559458 = -5.26462131165756e+290;
bool r559459 = r559457 <= r559458;
double r559460 = 1.0;
double r559461 = r559460 / r559456;
double r559462 = r559453 * r559461;
double r559463 = r559450 * r559462;
double r559464 = x;
double r559465 = r559463 + r559464;
double r559466 = 1.1606107956763068e+295;
bool r559467 = r559457 <= r559466;
double r559468 = r559464 + r559457;
double r559469 = r559456 / r559450;
double r559470 = r559460 / r559469;
double r559471 = fma(r559470, r559453, r559464);
double r559472 = r559467 ? r559468 : r559471;
double r559473 = r559459 ? r559465 : r559472;
return r559473;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 10.5 |
|---|---|
| Target | 1.3 |
| Herbie | 0.3 |
if (/ (* y (- z t)) (- z a)) < -5.26462131165756e+290Initial program 61.2
Simplified1.0
rmApplied fma-udef1.0
rmApplied div-inv1.2
Applied associate-*l*0.7
Simplified0.6
rmApplied div-inv0.7
if -5.26462131165756e+290 < (/ (* y (- z t)) (- z a)) < 1.1606107956763068e+295Initial program 0.2
Simplified3.3
rmApplied fma-udef3.3
rmApplied pow13.3
Applied pow13.3
Applied pow-prod-down3.3
Simplified0.2
if 1.1606107956763068e+295 < (/ (* y (- z t)) (- z a)) Initial program 62.1
Simplified0.6
rmApplied clear-num0.7
Final simplification0.3
herbie shell --seed 2020045 +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))))