\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;a \le -5.501967405141766076521871674752624329876 \cdot 10^{-144}:\\
\;\;\;\;\left(x + y\right) - \left(\frac{z - t}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}} \cdot \frac{\sqrt[3]{y} \cdot \sqrt[3]{y}}{\sqrt[3]{\sqrt[3]{a - t}} \cdot \sqrt[3]{\sqrt[3]{a - t}}}\right) \cdot \frac{\sqrt[3]{y}}{\sqrt[3]{\sqrt[3]{a - t}}}\\
\mathbf{elif}\;a \le 6.087929422498986455511468865172036217713 \cdot 10^{-197}:\\
\;\;\;\;\frac{z \cdot y}{t} + x\\
\mathbf{else}:\\
\;\;\;\;\left(x + y\right) - \frac{z - t}{\frac{a - t}{y}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r439485 = x;
double r439486 = y;
double r439487 = r439485 + r439486;
double r439488 = z;
double r439489 = t;
double r439490 = r439488 - r439489;
double r439491 = r439490 * r439486;
double r439492 = a;
double r439493 = r439492 - r439489;
double r439494 = r439491 / r439493;
double r439495 = r439487 - r439494;
return r439495;
}
double f(double x, double y, double z, double t, double a) {
double r439496 = a;
double r439497 = -5.501967405141766e-144;
bool r439498 = r439496 <= r439497;
double r439499 = x;
double r439500 = y;
double r439501 = r439499 + r439500;
double r439502 = z;
double r439503 = t;
double r439504 = r439502 - r439503;
double r439505 = r439496 - r439503;
double r439506 = cbrt(r439505);
double r439507 = r439506 * r439506;
double r439508 = r439504 / r439507;
double r439509 = cbrt(r439500);
double r439510 = r439509 * r439509;
double r439511 = cbrt(r439506);
double r439512 = r439511 * r439511;
double r439513 = r439510 / r439512;
double r439514 = r439508 * r439513;
double r439515 = r439509 / r439511;
double r439516 = r439514 * r439515;
double r439517 = r439501 - r439516;
double r439518 = 6.087929422498986e-197;
bool r439519 = r439496 <= r439518;
double r439520 = r439502 * r439500;
double r439521 = r439520 / r439503;
double r439522 = r439521 + r439499;
double r439523 = r439505 / r439500;
double r439524 = r439504 / r439523;
double r439525 = r439501 - r439524;
double r439526 = r439519 ? r439522 : r439525;
double r439527 = r439498 ? r439517 : r439526;
return r439527;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 16.4 |
|---|---|
| Target | 8.6 |
| Herbie | 9.4 |
if a < -5.501967405141766e-144Initial program 15.6
rmApplied add-cube-cbrt15.7
Applied times-frac9.0
rmApplied add-cube-cbrt9.0
Applied add-cube-cbrt9.1
Applied times-frac9.1
Applied associate-*r*8.7
if -5.501967405141766e-144 < a < 6.087929422498986e-197Initial program 20.4
Taylor expanded around inf 9.1
if 6.087929422498986e-197 < a Initial program 15.3
rmApplied associate-/l*10.1
Final simplification9.4
herbie shell --seed 1978988140
(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))))