\frac{x \cdot y - \left(z \cdot 9\right) \cdot t}{a \cdot 2}\begin{array}{l}
\mathbf{if}\;x \cdot y - \left(z \cdot 9\right) \cdot t \le -4.03283629370113762 \cdot 10^{287}:\\
\;\;\;\;0.5 \cdot \frac{x \cdot y}{a} - \left(t \cdot 4.5\right) \cdot \frac{z}{a}\\
\mathbf{elif}\;x \cdot y - \left(z \cdot 9\right) \cdot t \le 6.15442072676607707 \cdot 10^{270}:\\
\;\;\;\;\frac{x \cdot y - 9 \cdot \left(t \cdot z\right)}{a \cdot 2}\\
\mathbf{else}:\\
\;\;\;\;0.5 \cdot \frac{x}{\frac{a}{y}} - 4.5 \cdot \frac{t \cdot z}{a}\\
\end{array}double f(double x, double y, double z, double t, double a) {
double r710852 = x;
double r710853 = y;
double r710854 = r710852 * r710853;
double r710855 = z;
double r710856 = 9.0;
double r710857 = r710855 * r710856;
double r710858 = t;
double r710859 = r710857 * r710858;
double r710860 = r710854 - r710859;
double r710861 = a;
double r710862 = 2.0;
double r710863 = r710861 * r710862;
double r710864 = r710860 / r710863;
return r710864;
}
double f(double x, double y, double z, double t, double a) {
double r710865 = x;
double r710866 = y;
double r710867 = r710865 * r710866;
double r710868 = z;
double r710869 = 9.0;
double r710870 = r710868 * r710869;
double r710871 = t;
double r710872 = r710870 * r710871;
double r710873 = r710867 - r710872;
double r710874 = -4.0328362937011376e+287;
bool r710875 = r710873 <= r710874;
double r710876 = 0.5;
double r710877 = a;
double r710878 = r710867 / r710877;
double r710879 = r710876 * r710878;
double r710880 = 4.5;
double r710881 = r710871 * r710880;
double r710882 = r710868 / r710877;
double r710883 = r710881 * r710882;
double r710884 = r710879 - r710883;
double r710885 = 6.154420726766077e+270;
bool r710886 = r710873 <= r710885;
double r710887 = r710871 * r710868;
double r710888 = r710869 * r710887;
double r710889 = r710867 - r710888;
double r710890 = 2.0;
double r710891 = r710877 * r710890;
double r710892 = r710889 / r710891;
double r710893 = r710877 / r710866;
double r710894 = r710865 / r710893;
double r710895 = r710876 * r710894;
double r710896 = r710887 / r710877;
double r710897 = r710880 * r710896;
double r710898 = r710895 - r710897;
double r710899 = r710886 ? r710892 : r710898;
double r710900 = r710875 ? r710884 : r710899;
return r710900;
}




Bits error versus x




Bits error versus y




Bits error versus z




Bits error versus t




Bits error versus a
Results
| Original | 8.0 |
|---|---|
| Target | 5.8 |
| Herbie | 4.6 |
if (- (* x y) (* (* z 9.0) t)) < -4.0328362937011376e+287Initial program 54.9
Taylor expanded around 0 54.2
rmApplied *-un-lft-identity54.2
Applied times-frac29.4
Applied associate-*r*29.5
Simplified29.5
if -4.0328362937011376e+287 < (- (* x y) (* (* z 9.0) t)) < 6.154420726766077e+270Initial program 0.8
Taylor expanded around inf 0.8
if 6.154420726766077e+270 < (- (* x y) (* (* z 9.0) t)) Initial program 48.6
Taylor expanded around 0 48.0
rmApplied associate-/l*26.2
Final simplification4.6
herbie shell --seed 2020024
(FPCore (x y z t a)
:name "Diagrams.Solve.Polynomial:cubForm from diagrams-solve-0.1, I"
:precision binary64
:herbie-target
(if (< a -2.090464557976709e+86) (- (* 0.5 (/ (* y x) a)) (* 4.5 (/ t (/ a z)))) (if (< a 2.144030707833976e+99) (/ (- (* x y) (* z (* 9 t))) (* a 2)) (- (* (/ y a) (* x 0.5)) (* (/ t a) (* z 4.5)))))
(/ (- (* x y) (* (* z 9) t)) (* a 2)))