\left(x + y\right) - \frac{\left(z - t\right) \cdot y}{a - t}\begin{array}{l}
\mathbf{if}\;t \le -4.8073561715930757 \cdot 10^{132} \lor \neg \left(t \le 3.72314564871241098 \cdot 10^{89}\right):\\
\;\;\;\;\mathsf{fma}\left(\frac{z}{t}, y, x\right)\\
\mathbf{else}:\\
\;\;\;\;\mathsf{fma}\left(\frac{1}{\frac{\sqrt[3]{a - t} \cdot \sqrt[3]{a - t}}{\sqrt[3]{y} \cdot \sqrt[3]{y}}}, \frac{t - z}{\frac{\sqrt[3]{a - t}}{\sqrt[3]{y}}}, x + y\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r706841 = x;
double r706842 = y;
double r706843 = r706841 + r706842;
double r706844 = z;
double r706845 = t;
double r706846 = r706844 - r706845;
double r706847 = r706846 * r706842;
double r706848 = a;
double r706849 = r706848 - r706845;
double r706850 = r706847 / r706849;
double r706851 = r706843 - r706850;
return r706851;
}
double f(double x, double y, double z, double t, double a) {
double r706852 = t;
double r706853 = -4.807356171593076e+132;
bool r706854 = r706852 <= r706853;
double r706855 = 3.723145648712411e+89;
bool r706856 = r706852 <= r706855;
double r706857 = !r706856;
bool r706858 = r706854 || r706857;
double r706859 = z;
double r706860 = r706859 / r706852;
double r706861 = y;
double r706862 = x;
double r706863 = fma(r706860, r706861, r706862);
double r706864 = 1.0;
double r706865 = a;
double r706866 = r706865 - r706852;
double r706867 = cbrt(r706866);
double r706868 = r706867 * r706867;
double r706869 = cbrt(r706861);
double r706870 = r706869 * r706869;
double r706871 = r706868 / r706870;
double r706872 = r706864 / r706871;
double r706873 = r706852 - r706859;
double r706874 = r706867 / r706869;
double r706875 = r706873 / r706874;
double r706876 = r706862 + r706861;
double r706877 = fma(r706872, r706875, r706876);
double r706878 = r706858 ? r706863 : r706877;
return r706878;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
| Original | 16.6 |
|---|---|
| Target | 8.9 |
| Herbie | 7.5 |
if t < -4.807356171593076e+132 or 3.723145648712411e+89 < t Initial program 31.3
Simplified22.8
rmApplied clear-num22.9
rmApplied fma-udef23.0
Simplified23.0
Taylor expanded around inf 18.1
Simplified12.2
if -4.807356171593076e+132 < t < 3.723145648712411e+89Initial program 8.9
Simplified6.3
rmApplied clear-num6.4
rmApplied fma-udef6.4
Simplified6.2
rmApplied add-cube-cbrt6.4
Applied add-cube-cbrt6.4
Applied times-frac6.4
Applied *-un-lft-identity6.4
Applied times-frac5.1
Applied fma-def5.1
Final simplification7.5
herbie shell --seed 2020020 +o rules:numerics
(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))))