\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;t \le -6.071803987356108646236154501276931761132 \cdot 10^{127} \lor \neg \left(t \le 8.095220835801230557633946104079438724776 \cdot 10^{223}\right):\\
\;\;\;\;\frac{z \cdot y}{t} + x\\
\mathbf{else}:\\
\;\;\;\;\left(x + y\right) - \left(\sqrt[3]{\frac{z - t}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}} \cdot \frac{y}{\sqrt[3]{a - t}}} \cdot \sqrt[3]{\frac{z - t}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}} \cdot \frac{y}{\sqrt[3]{a - t}}}\right) \cdot \left(\sqrt[3]{\frac{z - t}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}}} \cdot \left(\sqrt[3]{\sqrt[3]{\frac{y}{\sqrt[3]{a - t}}} \cdot \sqrt[3]{\frac{y}{\sqrt[3]{a - t}}}} \cdot \sqrt[3]{\sqrt[3]{\frac{y}{\sqrt[3]{a - t}}}}\right)\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r506475 = x;
double r506476 = y;
double r506477 = r506475 + r506476;
double r506478 = z;
double r506479 = t;
double r506480 = r506478 - r506479;
double r506481 = r506480 * r506476;
double r506482 = a;
double r506483 = r506482 - r506479;
double r506484 = r506481 / r506483;
double r506485 = r506477 - r506484;
return r506485;
}
double f(double x, double y, double z, double t, double a) {
double r506486 = t;
double r506487 = -6.071803987356109e+127;
bool r506488 = r506486 <= r506487;
double r506489 = 8.095220835801231e+223;
bool r506490 = r506486 <= r506489;
double r506491 = !r506490;
bool r506492 = r506488 || r506491;
double r506493 = z;
double r506494 = y;
double r506495 = r506493 * r506494;
double r506496 = r506495 / r506486;
double r506497 = x;
double r506498 = r506496 + r506497;
double r506499 = r506497 + r506494;
double r506500 = r506493 - r506486;
double r506501 = a;
double r506502 = r506501 - r506486;
double r506503 = cbrt(r506502);
double r506504 = r506503 * r506503;
double r506505 = r506500 / r506504;
double r506506 = r506494 / r506503;
double r506507 = r506505 * r506506;
double r506508 = cbrt(r506507);
double r506509 = r506508 * r506508;
double r506510 = cbrt(r506505);
double r506511 = cbrt(r506506);
double r506512 = r506511 * r506511;
double r506513 = cbrt(r506512);
double r506514 = cbrt(r506511);
double r506515 = r506513 * r506514;
double r506516 = r506510 * r506515;
double r506517 = r506509 * r506516;
double r506518 = r506499 - r506517;
double r506519 = r506492 ? r506498 : r506518;
return r506519;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 16.7 |
|---|---|
| Target | 8.4 |
| Herbie | 10.4 |
if t < -6.071803987356109e+127 or 8.095220835801231e+223 < t Initial program 33.7
Taylor expanded around inf 17.7
if -6.071803987356109e+127 < t < 8.095220835801231e+223Initial program 11.4
rmApplied add-cube-cbrt11.6
Applied times-frac8.0
rmApplied add-cube-cbrt8.1
rmApplied cbrt-prod8.1
rmApplied add-cube-cbrt8.1
Applied cbrt-prod8.1
Final simplification10.4
herbie shell --seed 2019298
(FPCore (x y z t a)
:name "Graphics.Rendering.Plot.Render.Plot.Axis:renderAxisTick from plot-0.2.3.4, B"
:precision binary64
:herbie-target
(if (< (- (+ x y) (/ (* (- z t) y) (- a t))) -1.3664970889390727e-7) (- (+ y x) (* (* (- z t) (/ 1 (- a t))) y)) (if (< (- (+ x y) (/ (* (- z t) y) (- a t))) 1.47542934445772333e-239) (/ (- (* y (- a z)) (* x t)) (- a t)) (- (+ y x) (* (* (- z t) (/ 1 (- a t))) y))))
(- (+ x y) (/ (* (- z t) y) (- a t))))