\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;t \le -1.37314585255632761189109605897833700965 \cdot 10^{50}:\\
\;\;\;\;x + \frac{z \cdot y}{t}\\
\mathbf{elif}\;t \le 2.918652525119014591089469715053014371125 \cdot 10^{129}:\\
\;\;\;\;\left(x + y\right) - \frac{z - t}{\frac{\sqrt[3]{a - t}}{\sqrt[3]{\frac{y}{\sqrt[3]{\sqrt[3]{a - t}}}} \cdot \sqrt[3]{\frac{1}{\sqrt[3]{\sqrt[3]{a - t}} \cdot \sqrt[3]{\sqrt[3]{a - t}}}}} \cdot \frac{\sqrt[3]{a - t}}{\sqrt[3]{\frac{y}{\sqrt[3]{a - t}}}}} \cdot \sqrt[3]{\frac{y}{\sqrt[3]{a - t}}}\\
\mathbf{else}:\\
\;\;\;\;x + \frac{z \cdot y}{t}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r30986596 = x;
double r30986597 = y;
double r30986598 = r30986596 + r30986597;
double r30986599 = z;
double r30986600 = t;
double r30986601 = r30986599 - r30986600;
double r30986602 = r30986601 * r30986597;
double r30986603 = a;
double r30986604 = r30986603 - r30986600;
double r30986605 = r30986602 / r30986604;
double r30986606 = r30986598 - r30986605;
return r30986606;
}
double f(double x, double y, double z, double t, double a) {
double r30986607 = t;
double r30986608 = -1.3731458525563276e+50;
bool r30986609 = r30986607 <= r30986608;
double r30986610 = x;
double r30986611 = z;
double r30986612 = y;
double r30986613 = r30986611 * r30986612;
double r30986614 = r30986613 / r30986607;
double r30986615 = r30986610 + r30986614;
double r30986616 = 2.9186525251190146e+129;
bool r30986617 = r30986607 <= r30986616;
double r30986618 = r30986610 + r30986612;
double r30986619 = r30986611 - r30986607;
double r30986620 = a;
double r30986621 = r30986620 - r30986607;
double r30986622 = cbrt(r30986621);
double r30986623 = cbrt(r30986622);
double r30986624 = r30986612 / r30986623;
double r30986625 = cbrt(r30986624);
double r30986626 = 1.0;
double r30986627 = r30986623 * r30986623;
double r30986628 = r30986626 / r30986627;
double r30986629 = cbrt(r30986628);
double r30986630 = r30986625 * r30986629;
double r30986631 = r30986622 / r30986630;
double r30986632 = r30986612 / r30986622;
double r30986633 = cbrt(r30986632);
double r30986634 = r30986622 / r30986633;
double r30986635 = r30986631 * r30986634;
double r30986636 = r30986619 / r30986635;
double r30986637 = r30986636 * r30986633;
double r30986638 = r30986618 - r30986637;
double r30986639 = r30986617 ? r30986638 : r30986615;
double r30986640 = r30986609 ? r30986615 : r30986639;
return r30986640;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 16.4 |
|---|---|
| Target | 8.3 |
| Herbie | 10.3 |
if t < -1.3731458525563276e+50 or 2.9186525251190146e+129 < t Initial program 29.4
Taylor expanded around inf 18.1
if -1.3731458525563276e+50 < t < 2.9186525251190146e+129Initial program 8.4
rmApplied add-cube-cbrt8.6
Applied times-frac6.0
rmApplied add-cube-cbrt6.0
Applied associate-*r*6.0
Simplified5.5
rmApplied add-cube-cbrt5.4
Applied *-un-lft-identity5.4
Applied times-frac5.4
Applied cbrt-prod5.4
Final simplification10.3
herbie shell --seed 2019168
(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.0 (- 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.0 (- a t))) y))))
(- (+ x y) (/ (* (- z t) y) (- a t))))