\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;\left(y + x\right) - \frac{\left(z - t\right) \cdot y}{a - t} \le -1.9079071000270957 \cdot 10^{-242}:\\
\;\;\;\;\left(y + x\right) - \frac{z - t}{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}} \cdot \frac{y}{\sqrt[3]{a - t}}\\
\mathbf{elif}\;\left(y + x\right) - \frac{\left(z - t\right) \cdot y}{a - t} \le 9.635345176449361 \cdot 10^{-222}:\\
\;\;\;\;\frac{z \cdot y}{t} + x\\
\mathbf{else}:\\
\;\;\;\;\left(y + x\right) - \left(\frac{y}{\sqrt[3]{a - t}} \cdot \frac{\sqrt[3]{z - t}}{\sqrt[3]{a - t}}\right) \cdot \frac{\sqrt[3]{z - t} \cdot \sqrt[3]{z - t}}{\sqrt[3]{a - t}}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r30939029 = x;
double r30939030 = y;
double r30939031 = r30939029 + r30939030;
double r30939032 = z;
double r30939033 = t;
double r30939034 = r30939032 - r30939033;
double r30939035 = r30939034 * r30939030;
double r30939036 = a;
double r30939037 = r30939036 - r30939033;
double r30939038 = r30939035 / r30939037;
double r30939039 = r30939031 - r30939038;
return r30939039;
}
double f(double x, double y, double z, double t, double a) {
double r30939040 = y;
double r30939041 = x;
double r30939042 = r30939040 + r30939041;
double r30939043 = z;
double r30939044 = t;
double r30939045 = r30939043 - r30939044;
double r30939046 = r30939045 * r30939040;
double r30939047 = a;
double r30939048 = r30939047 - r30939044;
double r30939049 = r30939046 / r30939048;
double r30939050 = r30939042 - r30939049;
double r30939051 = -1.9079071000270957e-242;
bool r30939052 = r30939050 <= r30939051;
double r30939053 = cbrt(r30939048);
double r30939054 = r30939053 * r30939053;
double r30939055 = r30939045 / r30939054;
double r30939056 = r30939040 / r30939053;
double r30939057 = r30939055 * r30939056;
double r30939058 = r30939042 - r30939057;
double r30939059 = 9.635345176449361e-222;
bool r30939060 = r30939050 <= r30939059;
double r30939061 = r30939043 * r30939040;
double r30939062 = r30939061 / r30939044;
double r30939063 = r30939062 + r30939041;
double r30939064 = cbrt(r30939045);
double r30939065 = r30939064 / r30939053;
double r30939066 = r30939056 * r30939065;
double r30939067 = r30939064 * r30939064;
double r30939068 = r30939067 / r30939053;
double r30939069 = r30939066 * r30939068;
double r30939070 = r30939042 - r30939069;
double r30939071 = r30939060 ? r30939063 : r30939070;
double r30939072 = r30939052 ? r30939058 : r30939071;
return r30939072;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 16.0 |
|---|---|
| Target | 8.1 |
| Herbie | 7.8 |
if (- (+ x y) (/ (* (- z t) y) (- a t))) < -1.9079071000270957e-242Initial program 12.3
rmApplied add-cube-cbrt12.5
Applied times-frac7.1
if -1.9079071000270957e-242 < (- (+ x y) (/ (* (- z t) y) (- a t))) < 9.635345176449361e-222Initial program 53.7
Taylor expanded around inf 19.3
if 9.635345176449361e-222 < (- (+ x y) (/ (* (- z t) y) (- a t))) Initial program 12.4
rmApplied add-cube-cbrt12.6
Applied times-frac7.0
rmApplied add-cube-cbrt7.0
Applied times-frac7.0
Applied associate-*l*6.3
Final simplification7.8
herbie shell --seed 2019163
(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 (- 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))))