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)\mathsf{fma}\left(\frac{3}{\mathsf{fma}\left(x1, x1, 1\right)}, \mathsf{fma}\left(3, x1 \cdot x1, -\mathsf{fma}\left(x2, 2, x1\right)\right), \left(x1 + \frac{\mathsf{fma}\left(3, x1 \cdot x1, 2 \cdot x2 - x1\right) \cdot \left(\left(3 \cdot x1\right) \cdot x1\right)}{\mathsf{fma}\left(x1, x1, 1\right)}\right) + \mathsf{fma}\left(\mathsf{fma}\left(\mathsf{fma}\left(\frac{1}{\sqrt{x1 \cdot x1 + 1}}, \frac{\left(\left(3 \cdot x1\right) \cdot x1 + 2 \cdot x2\right) - x1}{\sqrt{x1 \cdot x1 + 1}}, -3\right) \cdot 2, \frac{x1 \cdot \mathsf{fma}\left(3, x1 \cdot x1, 2 \cdot x2 - x1\right)}{\mathsf{fma}\left(x1, x1, 1\right)}, \frac{\left({x1}^{2} \cdot 4\right) \cdot \mathsf{fma}\left(3, x1 \cdot x1, 2 \cdot x2 - x1\right)}{\mathsf{fma}\left(x1, x1, 1\right)} + \left(x1 \cdot x1\right) \cdot \left(-6\right)\right), \mathsf{fma}\left(x1, x1, 1\right), \mathsf{fma}\left(x1, x1 \cdot x1, x1\right)\right)\right)double f(double x1, double x2) {
double r39015 = x1;
double r39016 = 2.0;
double r39017 = r39016 * r39015;
double r39018 = 3.0;
double r39019 = r39018 * r39015;
double r39020 = r39019 * r39015;
double r39021 = x2;
double r39022 = r39016 * r39021;
double r39023 = r39020 + r39022;
double r39024 = r39023 - r39015;
double r39025 = r39015 * r39015;
double r39026 = 1.0;
double r39027 = r39025 + r39026;
double r39028 = r39024 / r39027;
double r39029 = r39017 * r39028;
double r39030 = r39028 - r39018;
double r39031 = r39029 * r39030;
double r39032 = 4.0;
double r39033 = r39032 * r39028;
double r39034 = 6.0;
double r39035 = r39033 - r39034;
double r39036 = r39025 * r39035;
double r39037 = r39031 + r39036;
double r39038 = r39037 * r39027;
double r39039 = r39020 * r39028;
double r39040 = r39038 + r39039;
double r39041 = r39025 * r39015;
double r39042 = r39040 + r39041;
double r39043 = r39042 + r39015;
double r39044 = r39020 - r39022;
double r39045 = r39044 - r39015;
double r39046 = r39045 / r39027;
double r39047 = r39018 * r39046;
double r39048 = r39043 + r39047;
double r39049 = r39015 + r39048;
return r39049;
}
double f(double x1, double x2) {
double r39050 = 3.0;
double r39051 = x1;
double r39052 = 1.0;
double r39053 = fma(r39051, r39051, r39052);
double r39054 = r39050 / r39053;
double r39055 = r39051 * r39051;
double r39056 = x2;
double r39057 = 2.0;
double r39058 = fma(r39056, r39057, r39051);
double r39059 = -r39058;
double r39060 = fma(r39050, r39055, r39059);
double r39061 = r39057 * r39056;
double r39062 = r39061 - r39051;
double r39063 = fma(r39050, r39055, r39062);
double r39064 = r39050 * r39051;
double r39065 = r39064 * r39051;
double r39066 = r39063 * r39065;
double r39067 = r39066 / r39053;
double r39068 = r39051 + r39067;
double r39069 = 1.0;
double r39070 = r39055 + r39052;
double r39071 = sqrt(r39070);
double r39072 = r39069 / r39071;
double r39073 = r39065 + r39061;
double r39074 = r39073 - r39051;
double r39075 = r39074 / r39071;
double r39076 = -r39050;
double r39077 = fma(r39072, r39075, r39076);
double r39078 = r39077 * r39057;
double r39079 = r39051 * r39063;
double r39080 = r39079 / r39053;
double r39081 = 2.0;
double r39082 = pow(r39051, r39081);
double r39083 = 4.0;
double r39084 = r39082 * r39083;
double r39085 = r39084 * r39063;
double r39086 = r39085 / r39053;
double r39087 = 6.0;
double r39088 = -r39087;
double r39089 = r39055 * r39088;
double r39090 = r39086 + r39089;
double r39091 = fma(r39078, r39080, r39090);
double r39092 = fma(r39051, r39055, r39051);
double r39093 = fma(r39091, r39053, r39092);
double r39094 = r39068 + r39093;
double r39095 = fma(r39054, r39060, r39094);
return r39095;
}



Bits error versus x1



Bits error versus x2
Initial program 0.5
Simplified0.3
rmApplied sub-neg0.3
Applied distribute-lft-in0.3
Simplified0.3
rmApplied add-sqr-sqrt0.3
Applied *-un-lft-identity0.3
Applied times-frac0.3
Applied fma-neg0.3
Final simplification0.3
herbie shell --seed 2019353 +o rules:numerics
(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))))))