\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 r686833 = x;
double r686834 = y;
double r686835 = r686833 + r686834;
double r686836 = z;
double r686837 = t;
double r686838 = r686836 - r686837;
double r686839 = r686838 * r686834;
double r686840 = a;
double r686841 = r686840 - r686837;
double r686842 = r686839 / r686841;
double r686843 = r686835 - r686842;
return r686843;
}
double f(double x, double y, double z, double t, double a) {
double r686844 = a;
double r686845 = -1.323154873685477e-128;
bool r686846 = r686844 <= r686845;
double r686847 = x;
double r686848 = y;
double r686849 = r686847 + r686848;
double r686850 = z;
double r686851 = t;
double r686852 = r686850 - r686851;
double r686853 = r686844 - r686851;
double r686854 = r686848 / r686853;
double r686855 = r686852 * r686854;
double r686856 = r686849 - r686855;
double r686857 = 1.6655050159899754e-189;
bool r686858 = r686844 <= r686857;
double r686859 = r686850 * r686848;
double r686860 = r686859 / r686851;
double r686861 = r686860 + r686847;
double r686862 = cbrt(r686853);
double r686863 = r686862 * r686862;
double r686864 = r686852 / r686863;
double r686865 = cbrt(r686864);
double r686866 = r686865 * r686865;
double r686867 = r686848 / r686862;
double r686868 = r686865 * r686867;
double r686869 = r686866 * r686868;
double r686870 = r686849 - r686869;
double r686871 = r686858 ? r686861 : r686870;
double r686872 = r686846 ? r686856 : r686871;
return r686872;
}




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))))