\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;a \le -1.323154873685477 \cdot 10^{-128}:\\
\;\;\;\;\left(x + y\right) - \left(z - t\right) \cdot \frac{y}{a - t}\\
\mathbf{elif}\;a \le 1.6655050159899754 \cdot 10^{-189}:\\
\;\;\;\;\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 \sqrt[3]{\frac{z - t}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}}}\right) \cdot \left(\sqrt[3]{\frac{z - t}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}}} \cdot \frac{y}{\sqrt[3]{a - t}}\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r772752 = x;
double r772753 = y;
double r772754 = r772752 + r772753;
double r772755 = z;
double r772756 = t;
double r772757 = r772755 - r772756;
double r772758 = r772757 * r772753;
double r772759 = a;
double r772760 = r772759 - r772756;
double r772761 = r772758 / r772760;
double r772762 = r772754 - r772761;
return r772762;
}
double f(double x, double y, double z, double t, double a) {
double r772763 = a;
double r772764 = -1.323154873685477e-128;
bool r772765 = r772763 <= r772764;
double r772766 = x;
double r772767 = y;
double r772768 = r772766 + r772767;
double r772769 = z;
double r772770 = t;
double r772771 = r772769 - r772770;
double r772772 = r772763 - r772770;
double r772773 = r772767 / r772772;
double r772774 = r772771 * r772773;
double r772775 = r772768 - r772774;
double r772776 = 1.6655050159899754e-189;
bool r772777 = r772763 <= r772776;
double r772778 = r772769 * r772767;
double r772779 = r772778 / r772770;
double r772780 = r772779 + r772766;
double r772781 = cbrt(r772772);
double r772782 = r772781 * r772781;
double r772783 = r772771 / r772782;
double r772784 = cbrt(r772783);
double r772785 = r772784 * r772784;
double r772786 = r772767 / r772781;
double r772787 = r772784 * r772786;
double r772788 = r772785 * r772787;
double r772789 = r772768 - r772788;
double r772790 = r772777 ? r772780 : r772789;
double r772791 = r772765 ? r772775 : r772790;
return r772791;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 16.6 |
|---|---|
| Target | 8.2 |
| Herbie | 9.2 |
if a < -1.323154873685477e-128Initial program 15.3
rmApplied *-un-lft-identity15.3
Applied times-frac9.5
Simplified9.5
if -1.323154873685477e-128 < a < 1.6655050159899754e-189Initial program 21.0
Taylor expanded around inf 8.5
if 1.6655050159899754e-189 < a Initial program 15.4
rmApplied add-cube-cbrt15.6
Applied times-frac9.3
rmApplied add-cube-cbrt9.4
Applied associate-*l*9.3
Final simplification9.2
herbie shell --seed 2020046
(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-07) (- (+ y x) (* (* (- z t) (/ 1 (- 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 (- a t))) y))))
(- (+ x y) (/ (* (- z t) y) (- a t))))