\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;t \le -1.35463550198866496 \cdot 10^{129} \lor \neg \left(t \le 1.3792081327255185 \cdot 10^{60}\right):\\
\;\;\;\;\frac{z \cdot y}{t} + x\\
\mathbf{else}:\\
\;\;\;\;\left(x + y\right) - \frac{\sqrt[3]{y} \cdot \sqrt[3]{y}}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}} \cdot \frac{z - t}{\frac{\sqrt[3]{a - t}}{\sqrt[3]{y}}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r564106 = x;
double r564107 = y;
double r564108 = r564106 + r564107;
double r564109 = z;
double r564110 = t;
double r564111 = r564109 - r564110;
double r564112 = r564111 * r564107;
double r564113 = a;
double r564114 = r564113 - r564110;
double r564115 = r564112 / r564114;
double r564116 = r564108 - r564115;
return r564116;
}
double f(double x, double y, double z, double t, double a) {
double r564117 = t;
double r564118 = -1.354635501988665e+129;
bool r564119 = r564117 <= r564118;
double r564120 = 1.3792081327255185e+60;
bool r564121 = r564117 <= r564120;
double r564122 = !r564121;
bool r564123 = r564119 || r564122;
double r564124 = z;
double r564125 = y;
double r564126 = r564124 * r564125;
double r564127 = r564126 / r564117;
double r564128 = x;
double r564129 = r564127 + r564128;
double r564130 = r564128 + r564125;
double r564131 = cbrt(r564125);
double r564132 = r564131 * r564131;
double r564133 = a;
double r564134 = r564133 - r564117;
double r564135 = cbrt(r564134);
double r564136 = r564135 * r564135;
double r564137 = r564132 / r564136;
double r564138 = r564124 - r564117;
double r564139 = r564135 / r564131;
double r564140 = r564138 / r564139;
double r564141 = r564137 * r564140;
double r564142 = r564130 - r564141;
double r564143 = r564123 ? r564129 : r564142;
return r564143;
}




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.6 |
| Herbie | 10.1 |
if t < -1.354635501988665e+129 or 1.3792081327255185e+60 < t Initial program 30.0
Taylor expanded around inf 17.9
if -1.354635501988665e+129 < t < 1.3792081327255185e+60Initial program 8.6
rmApplied associate-/l*6.8
rmApplied add-cube-cbrt7.0
Applied add-cube-cbrt7.0
Applied times-frac7.0
Applied *-un-lft-identity7.0
Applied times-frac5.4
Simplified5.4
Final simplification10.1
herbie shell --seed 2020081
(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))))