\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;t \le -4.76278196464351678 \cdot 10^{56} \lor \neg \left(t \le 3.70931520882170438 \cdot 10^{143}\right):\\
\;\;\;\;\mathsf{fma}\left(\frac{z}{t}, y, x\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\sqrt[3]{t - z} \cdot \sqrt[3]{t - z}, \left(\frac{\sqrt[3]{t - z}}{\sqrt[3]{a - t}} \cdot y\right) \cdot \frac{1}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}}, x + y\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r445389 = x;
double r445390 = y;
double r445391 = r445389 + r445390;
double r445392 = z;
double r445393 = t;
double r445394 = r445392 - r445393;
double r445395 = r445394 * r445390;
double r445396 = a;
double r445397 = r445396 - r445393;
double r445398 = r445395 / r445397;
double r445399 = r445391 - r445398;
return r445399;
}
double f(double x, double y, double z, double t, double a) {
double r445400 = t;
double r445401 = -4.762781964643517e+56;
bool r445402 = r445400 <= r445401;
double r445403 = 3.7093152088217044e+143;
bool r445404 = r445400 <= r445403;
double r445405 = !r445404;
bool r445406 = r445402 || r445405;
double r445407 = z;
double r445408 = r445407 / r445400;
double r445409 = y;
double r445410 = x;
double r445411 = fma(r445408, r445409, r445410);
double r445412 = r445400 - r445407;
double r445413 = cbrt(r445412);
double r445414 = r445413 * r445413;
double r445415 = a;
double r445416 = r445415 - r445400;
double r445417 = cbrt(r445416);
double r445418 = r445413 / r445417;
double r445419 = r445418 * r445409;
double r445420 = 1.0;
double r445421 = r445417 * r445417;
double r445422 = r445420 / r445421;
double r445423 = r445419 * r445422;
double r445424 = r445410 + r445409;
double r445425 = fma(r445414, r445423, r445424);
double r445426 = r445406 ? r445411 : r445425;
return r445426;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 16.3 |
|---|---|
| Target | 8.1 |
| Herbie | 8.7 |
if t < -4.762781964643517e+56 or 3.7093152088217044e+143 < t Initial program 29.5
Simplified19.3
Taylor expanded around inf 17.6
Simplified12.5
if -4.762781964643517e+56 < t < 3.7093152088217044e+143Initial program 8.7
Simplified6.9
rmApplied fma-udef6.9
rmApplied *-un-lft-identity6.9
Applied add-cube-cbrt7.1
Applied times-frac7.1
Applied associate-*l*6.5
rmApplied add-cube-cbrt6.6
Applied *-un-lft-identity6.6
Applied cbrt-prod6.6
Applied times-frac6.6
Applied associate-*l*6.5
rmApplied fma-def6.5
Final simplification8.7
herbie shell --seed 2019198 +o rules:numerics
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisTick from plot-0.2.3.4, B"
:herbie-target
(if (< (- (+ x y) (/ (* (- z t) y) (- a t))) -1.3664970889390727e-07) (- (+ y x) (* (* (- z t) (/ 1.0 (- a t))) y)) (if (< (- (+ x y) (/ (* (- z t) y) (- a t))) 1.4754293444577233e-239) (/ (- (* y (- a z)) (* x t)) (- a t)) (- (+ y x) (* (* (- z t) (/ 1.0 (- a t))) y))))
(- (+ x y) (/ (* (- z t) y) (- a t))))