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 r72893 = x1;
double r72894 = 2.0;
double r72895 = r72894 * r72893;
double r72896 = 3.0;
double r72897 = r72896 * r72893;
double r72898 = r72897 * r72893;
double r72899 = x2;
double r72900 = r72894 * r72899;
double r72901 = r72898 + r72900;
double r72902 = r72901 - r72893;
double r72903 = r72893 * r72893;
double r72904 = 1.0;
double r72905 = r72903 + r72904;
double r72906 = r72902 / r72905;
double r72907 = r72895 * r72906;
double r72908 = r72906 - r72896;
double r72909 = r72907 * r72908;
double r72910 = 4.0;
double r72911 = r72910 * r72906;
double r72912 = 6.0;
double r72913 = r72911 - r72912;
double r72914 = r72903 * r72913;
double r72915 = r72909 + r72914;
double r72916 = r72915 * r72905;
double r72917 = r72898 * r72906;
double r72918 = r72916 + r72917;
double r72919 = r72903 * r72893;
double r72920 = r72918 + r72919;
double r72921 = r72920 + r72893;
double r72922 = r72898 - r72900;
double r72923 = r72922 - r72893;
double r72924 = r72923 / r72905;
double r72925 = r72896 * r72924;
double r72926 = r72921 + r72925;
double r72927 = r72893 + r72926;
return r72927;
}
double f(double x1, double x2) {
double r72928 = x1;
double r72929 = 2.0;
double r72930 = r72929 * r72928;
double r72931 = 3.0;
double r72932 = r72931 * r72928;
double r72933 = r72932 * r72928;
double r72934 = x2;
double r72935 = r72929 * r72934;
double r72936 = r72933 + r72935;
double r72937 = r72936 - r72928;
double r72938 = r72928 * r72928;
double r72939 = 1.0;
double r72940 = r72938 + r72939;
double r72941 = r72937 / r72940;
double r72942 = r72930 * r72941;
double r72943 = r72941 - r72931;
double r72944 = r72942 * r72943;
double r72945 = 4.0;
double r72946 = r72945 * r72941;
double r72947 = 6.0;
double r72948 = r72946 - r72947;
double r72949 = r72938 * r72948;
double r72950 = r72944 + r72949;
double r72951 = cbrt(r72950);
double r72952 = r72951 * r72951;
double r72953 = cbrt(r72943);
double r72954 = r72953 * r72953;
double r72955 = r72954 * r72953;
double r72956 = r72942 * r72955;
double r72957 = r72956 + r72949;
double r72958 = cbrt(r72957);
double r72959 = r72952 * r72958;
double r72960 = r72959 * r72940;
double r72961 = r72933 * r72941;
double r72962 = r72960 + r72961;
double r72963 = r72938 * r72928;
double r72964 = r72962 + r72963;
double r72965 = r72964 + r72928;
double r72966 = r72933 - r72935;
double r72967 = r72966 - r72928;
double r72968 = r72967 / r72940;
double r72969 = r72931 * r72968;
double r72970 = r72965 + r72969;
double r72971 = r72928 + r72970;
return r72971;
}



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))))))