\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;a \le -1.838369765495349463260835321405014535092 \cdot 10^{-148}:\\
\;\;\;\;\left(x + y\right) - \frac{z - t}{\left(\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}\right) \cdot \sqrt[3]{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}}} \cdot \frac{y}{\sqrt[3]{\sqrt[3]{a - t}}}\\
\mathbf{elif}\;a \le 3.265578407157981999998792060881541473299 \cdot 10^{-103}:\\
\;\;\;\;x + \frac{z \cdot y}{t}\\
\mathbf{else}:\\
\;\;\;\;\left(x + y\right) - \left(\frac{\sqrt[3]{z - t}}{\sqrt[3]{a - t} \cdot \sqrt[3]{\sqrt[3]{a - t}}} \cdot \frac{y}{\sqrt[3]{\sqrt[3]{a - t}}}\right) \cdot \frac{\sqrt[3]{z - t} \cdot \sqrt[3]{z - t}}{\sqrt[3]{a - t} \cdot \sqrt[3]{\sqrt[3]{a - t}}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r32664532 = x;
double r32664533 = y;
double r32664534 = r32664532 + r32664533;
double r32664535 = z;
double r32664536 = t;
double r32664537 = r32664535 - r32664536;
double r32664538 = r32664537 * r32664533;
double r32664539 = a;
double r32664540 = r32664539 - r32664536;
double r32664541 = r32664538 / r32664540;
double r32664542 = r32664534 - r32664541;
return r32664542;
}
double f(double x, double y, double z, double t, double a) {
double r32664543 = a;
double r32664544 = -1.8383697654953495e-148;
bool r32664545 = r32664543 <= r32664544;
double r32664546 = x;
double r32664547 = y;
double r32664548 = r32664546 + r32664547;
double r32664549 = z;
double r32664550 = t;
double r32664551 = r32664549 - r32664550;
double r32664552 = r32664543 - r32664550;
double r32664553 = cbrt(r32664552);
double r32664554 = r32664553 * r32664553;
double r32664555 = cbrt(r32664554);
double r32664556 = r32664554 * r32664555;
double r32664557 = r32664551 / r32664556;
double r32664558 = cbrt(r32664553);
double r32664559 = r32664547 / r32664558;
double r32664560 = r32664557 * r32664559;
double r32664561 = r32664548 - r32664560;
double r32664562 = 3.265578407157982e-103;
bool r32664563 = r32664543 <= r32664562;
double r32664564 = r32664549 * r32664547;
double r32664565 = r32664564 / r32664550;
double r32664566 = r32664546 + r32664565;
double r32664567 = cbrt(r32664551);
double r32664568 = r32664553 * r32664558;
double r32664569 = r32664567 / r32664568;
double r32664570 = r32664569 * r32664559;
double r32664571 = r32664567 * r32664567;
double r32664572 = r32664571 / r32664568;
double r32664573 = r32664570 * r32664572;
double r32664574 = r32664548 - r32664573;
double r32664575 = r32664563 ? r32664566 : r32664574;
double r32664576 = r32664545 ? r32664561 : r32664575;
return r32664576;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 16.3 |
|---|---|
| Target | 8.7 |
| Herbie | 9.2 |
if a < -1.8383697654953495e-148Initial program 15.5
rmApplied add-cube-cbrt15.6
Applied times-frac9.0
rmApplied add-cube-cbrt9.1
Applied cbrt-prod9.1
Applied *-un-lft-identity9.1
Applied times-frac9.1
Applied associate-*r*8.9
Simplified8.9
if -1.8383697654953495e-148 < a < 3.265578407157982e-103Initial program 19.9
Taylor expanded around inf 10.7
if 3.265578407157982e-103 < a Initial program 14.4
rmApplied add-cube-cbrt14.6
Applied times-frac8.6
rmApplied add-cube-cbrt8.6
Applied *-un-lft-identity8.6
Applied times-frac8.6
Applied associate-*r*8.5
Simplified8.5
rmApplied add-cube-cbrt8.5
Applied times-frac8.5
Applied associate-*l*8.2
Final simplification9.2
herbie shell --seed 2019169
(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))))