\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;a \le -1.31413808910975569189734655926999448624 \cdot 10^{-225} \lor \neg \left(a \le 5.913406836150693827223293523747761324681 \cdot 10^{-231}\right):\\
\;\;\;\;\left(x + y\right) - \frac{\frac{z - t}{\frac{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}}{\sqrt[3]{y} \cdot \sqrt[3]{y}}}}{\frac{\sqrt[3]{a - t}}{\sqrt[3]{y}}}\\
\mathbf{else}:\\
\;\;\;\;\frac{z \cdot y}{t} + x\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r394355 = x;
double r394356 = y;
double r394357 = r394355 + r394356;
double r394358 = z;
double r394359 = t;
double r394360 = r394358 - r394359;
double r394361 = r394360 * r394356;
double r394362 = a;
double r394363 = r394362 - r394359;
double r394364 = r394361 / r394363;
double r394365 = r394357 - r394364;
return r394365;
}
double f(double x, double y, double z, double t, double a) {
double r394366 = a;
double r394367 = -1.3141380891097557e-225;
bool r394368 = r394366 <= r394367;
double r394369 = 5.913406836150694e-231;
bool r394370 = r394366 <= r394369;
double r394371 = !r394370;
bool r394372 = r394368 || r394371;
double r394373 = x;
double r394374 = y;
double r394375 = r394373 + r394374;
double r394376 = z;
double r394377 = t;
double r394378 = r394376 - r394377;
double r394379 = r394366 - r394377;
double r394380 = cbrt(r394379);
double r394381 = r394380 * r394380;
double r394382 = cbrt(r394374);
double r394383 = r394382 * r394382;
double r394384 = r394381 / r394383;
double r394385 = r394378 / r394384;
double r394386 = r394380 / r394382;
double r394387 = r394385 / r394386;
double r394388 = r394375 - r394387;
double r394389 = r394376 * r394374;
double r394390 = r394389 / r394377;
double r394391 = r394390 + r394373;
double r394392 = r394372 ? r394388 : r394391;
return r394392;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 16.2 |
|---|---|
| Target | 8.3 |
| Herbie | 9.1 |
if a < -1.3141380891097557e-225 or 5.913406836150694e-231 < a Initial program 15.5
rmApplied associate-/l*10.4
rmApplied add-cube-cbrt10.6
Applied add-cube-cbrt10.6
Applied times-frac10.6
Applied associate-/r*9.5
if -1.3141380891097557e-225 < a < 5.913406836150694e-231Initial program 21.3
Taylor expanded around inf 6.5
Final simplification9.1
herbie shell --seed 2019325
(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))))