x1 + \left(\left(\left(\left(\left(\left(\left(2 \cdot x1\right) \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1}\right) \cdot \left(\frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 3\right) + \left(x1 \cdot x1\right) \cdot \left(4 \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 6\right)\right) \cdot \left(x1 \cdot x1 + 1\right) + \left(\left(3 \cdot x1\right) \cdot x1\right) \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1}\right) + \left(x1 \cdot x1\right) \cdot x1\right) + x1\right) + 3 \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 - 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1}\right)x1 + \left(\left(\left(\left(\left(\left(\sqrt[3]{\left(\left(2 \cdot x1\right) \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1}\right) \cdot \left(\frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 3\right) + \left(x1 \cdot x1\right) \cdot \left(4 \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 6\right)} \cdot \sqrt[3]{\left(\left(2 \cdot x1\right) \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1}\right) \cdot \left(\frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 3\right) + \left(x1 \cdot x1\right) \cdot \left(4 \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 6\right)}\right) \cdot \sqrt[3]{\left(\left(2 \cdot x1\right) \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1}\right) \cdot \left(\left(\sqrt[3]{\frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 3} \cdot \sqrt[3]{\frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 3}\right) \cdot \sqrt[3]{\frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 3}\right) + \left(x1 \cdot x1\right) \cdot \left(4 \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1} - 6\right)}\right) \cdot \left(x1 \cdot x1 + 1\right) + \left(\left(3 \cdot x1\right) \cdot x1\right) \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1}\right) + \left(x1 \cdot x1\right) \cdot x1\right) + x1\right) + 3 \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 - 2 \cdot x2\right) - x1}{x1 \cdot x1 + 1}\right)double f(double x1, double x2) {
double r72854 = x1;
double r72855 = 2.0;
double r72856 = r72855 * r72854;
double r72857 = 3.0;
double r72858 = r72857 * r72854;
double r72859 = r72858 * r72854;
double r72860 = x2;
double r72861 = r72855 * r72860;
double r72862 = r72859 + r72861;
double r72863 = r72862 - r72854;
double r72864 = r72854 * r72854;
double r72865 = 1.0;
double r72866 = r72864 + r72865;
double r72867 = r72863 / r72866;
double r72868 = r72856 * r72867;
double r72869 = r72867 - r72857;
double r72870 = r72868 * r72869;
double r72871 = 4.0;
double r72872 = r72871 * r72867;
double r72873 = 6.0;
double r72874 = r72872 - r72873;
double r72875 = r72864 * r72874;
double r72876 = r72870 + r72875;
double r72877 = r72876 * r72866;
double r72878 = r72859 * r72867;
double r72879 = r72877 + r72878;
double r72880 = r72864 * r72854;
double r72881 = r72879 + r72880;
double r72882 = r72881 + r72854;
double r72883 = r72859 - r72861;
double r72884 = r72883 - r72854;
double r72885 = r72884 / r72866;
double r72886 = r72857 * r72885;
double r72887 = r72882 + r72886;
double r72888 = r72854 + r72887;
return r72888;
}
double f(double x1, double x2) {
double r72889 = x1;
double r72890 = 2.0;
double r72891 = r72890 * r72889;
double r72892 = 3.0;
double r72893 = r72892 * r72889;
double r72894 = r72893 * r72889;
double r72895 = x2;
double r72896 = r72890 * r72895;
double r72897 = r72894 + r72896;
double r72898 = r72897 - r72889;
double r72899 = r72889 * r72889;
double r72900 = 1.0;
double r72901 = r72899 + r72900;
double r72902 = r72898 / r72901;
double r72903 = r72891 * r72902;
double r72904 = r72902 - r72892;
double r72905 = r72903 * r72904;
double r72906 = 4.0;
double r72907 = r72906 * r72902;
double r72908 = 6.0;
double r72909 = r72907 - r72908;
double r72910 = r72899 * r72909;
double r72911 = r72905 + r72910;
double r72912 = cbrt(r72911);
double r72913 = r72912 * r72912;
double r72914 = cbrt(r72904);
double r72915 = r72914 * r72914;
double r72916 = r72915 * r72914;
double r72917 = r72903 * r72916;
double r72918 = r72917 + r72910;
double r72919 = cbrt(r72918);
double r72920 = r72913 * r72919;
double r72921 = r72920 * r72901;
double r72922 = r72894 * r72902;
double r72923 = r72921 + r72922;
double r72924 = r72899 * r72889;
double r72925 = r72923 + r72924;
double r72926 = r72925 + r72889;
double r72927 = r72894 - r72896;
double r72928 = r72927 - r72889;
double r72929 = r72928 / r72901;
double r72930 = r72892 * r72929;
double r72931 = r72926 + r72930;
double r72932 = r72889 + r72931;
return r72932;
}



Bits error versus x1



Bits error versus x2
Results
Initial program 0.5
rmApplied add-cube-cbrt0.8
rmApplied add-cube-cbrt0.8
Final simplification0.8
herbie shell --seed 2019322
(FPCore (x1 x2)
:name "Rosa's FloatVsDoubleBenchmark"
:precision binary64
(+ x1 (+ (+ (+ (+ (* (+ (* (* (* 2 x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) (- (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)) 3)) (* (* x1 x1) (- (* 4 (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))) 6))) (+ (* x1 x1) 1)) (* (* (* 3 x1) x1) (/ (- (+ (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1)))) (* (* x1 x1) x1)) x1) (* 3 (/ (- (- (* (* 3 x1) x1) (* 2 x2)) x1) (+ (* x1 x1) 1))))))