x + \frac{\left(y - z\right) \cdot \left(t - x\right)}{a - z}\begin{array}{l}
\mathbf{if}\;a \le -6.647463183269898 \cdot 10^{-65}:\\
\;\;\;\;x + \frac{y - z}{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}} \cdot \frac{t - x}{\sqrt[3]{a - z}}\\
\mathbf{elif}\;a \le 500051093016.9032:\\
\;\;\;\;t + y \cdot \left(\frac{x}{z} - \frac{t}{z}\right)\\
\mathbf{else}:\\
\;\;\;\;x + \left(\frac{y - z}{\sqrt[3]{a - z} \cdot \sqrt[3]{a - z}} \cdot \left(\sqrt[3]{\frac{t - x}{\sqrt[3]{a - z}}} \cdot \sqrt[3]{\frac{t - x}{\sqrt[3]{a - z}}}\right)\right) \cdot \left(\sqrt[3]{\frac{1}{\sqrt[3]{\sqrt[3]{a - z}} \cdot \sqrt[3]{\sqrt[3]{a - z}}}} \cdot \sqrt[3]{\frac{t - x}{\sqrt[3]{\sqrt[3]{a - z}}}}\right)\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r474897 = x;
double r474898 = y;
double r474899 = z;
double r474900 = r474898 - r474899;
double r474901 = t;
double r474902 = r474901 - r474897;
double r474903 = r474900 * r474902;
double r474904 = a;
double r474905 = r474904 - r474899;
double r474906 = r474903 / r474905;
double r474907 = r474897 + r474906;
return r474907;
}
double f(double x, double y, double z, double t, double a) {
double r474908 = a;
double r474909 = -6.647463183269898e-65;
bool r474910 = r474908 <= r474909;
double r474911 = x;
double r474912 = y;
double r474913 = z;
double r474914 = r474912 - r474913;
double r474915 = r474908 - r474913;
double r474916 = cbrt(r474915);
double r474917 = r474916 * r474916;
double r474918 = r474914 / r474917;
double r474919 = t;
double r474920 = r474919 - r474911;
double r474921 = r474920 / r474916;
double r474922 = r474918 * r474921;
double r474923 = r474911 + r474922;
double r474924 = 500051093016.9032;
bool r474925 = r474908 <= r474924;
double r474926 = r474911 / r474913;
double r474927 = r474919 / r474913;
double r474928 = r474926 - r474927;
double r474929 = r474912 * r474928;
double r474930 = r474919 + r474929;
double r474931 = cbrt(r474921);
double r474932 = r474931 * r474931;
double r474933 = r474918 * r474932;
double r474934 = 1.0;
double r474935 = cbrt(r474916);
double r474936 = r474935 * r474935;
double r474937 = r474934 / r474936;
double r474938 = cbrt(r474937);
double r474939 = r474920 / r474935;
double r474940 = cbrt(r474939);
double r474941 = r474938 * r474940;
double r474942 = r474933 * r474941;
double r474943 = r474911 + r474942;
double r474944 = r474925 ? r474930 : r474943;
double r474945 = r474910 ? r474923 : r474944;
return r474945;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 24.7 |
|---|---|
| Target | 12.1 |
| Herbie | 12.4 |
if a < -6.647463183269898e-65Initial program 22.7
rmApplied add-cube-cbrt23.0
Applied times-frac8.6
if -6.647463183269898e-65 < a < 500051093016.9032Initial program 27.9
rmApplied add-cube-cbrt28.5
Applied times-frac20.5
rmApplied add-cube-cbrt20.7
Applied add-cube-cbrt20.8
Applied times-frac20.8
Applied associate-*r*19.5
Taylor expanded around inf 21.7
Simplified18.5
if 500051093016.9032 < a Initial program 22.1
rmApplied add-cube-cbrt22.4
Applied times-frac6.8
rmApplied add-cube-cbrt7.0
Applied associate-*r*7.0
rmApplied add-cube-cbrt7.0
Applied *-un-lft-identity7.0
Applied times-frac7.0
Applied cbrt-prod7.0
Final simplification12.4
herbie shell --seed 2019199
(FPCore (x y z t a)
:name "Graphics.Rendering.Chart.Axis.Types:invLinMap from Chart-1.5.3"
:herbie-target
(if (< z -1.2536131056095036e+188) (- t (* (/ y z) (- t x))) (if (< z 4.446702369113811e+64) (+ x (/ (- y z) (/ (- a z) (- t x)))) (- t (* (/ y z) (- t x)))))
(+ x (/ (* (- y z) (- t x)) (- a z))))