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(x1 + \left(\left(\left(\left(3 \cdot x1\right) \cdot x1\right) \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + x2 \cdot 2\right) - x1}{1 + x1 \cdot x1} + \left(\left(-x1 \cdot x1\right) \cdot 6 + \left(\left(x1 \cdot x1\right) \cdot \left(\frac{\left(\left(3 \cdot x1\right) \cdot x1 + x2 \cdot 2\right) - x1}{1 + x1 \cdot x1} \cdot 4\right) + \left(\left(x1 \cdot 2\right) \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 + x2 \cdot 2\right) - x1}{1 + x1 \cdot x1}\right) \cdot \mathsf{fma}\left(\left(\left(3 \cdot x1\right) \cdot x1 + x2 \cdot 2\right) - x1, \frac{1}{1 + x1 \cdot x1}, -3\right)\right)\right) \cdot \left(1 + x1 \cdot x1\right)\right) + x1 \cdot \left(x1 \cdot x1\right)\right)\right) + 3 \cdot \frac{\left(\left(3 \cdot x1\right) \cdot x1 - x2 \cdot 2\right) - x1}{1 + x1 \cdot x1}\right)double f(double x1, double x2) {
double r2448684 = x1;
double r2448685 = 2.0;
double r2448686 = r2448685 * r2448684;
double r2448687 = 3.0;
double r2448688 = r2448687 * r2448684;
double r2448689 = r2448688 * r2448684;
double r2448690 = x2;
double r2448691 = r2448685 * r2448690;
double r2448692 = r2448689 + r2448691;
double r2448693 = r2448692 - r2448684;
double r2448694 = r2448684 * r2448684;
double r2448695 = 1.0;
double r2448696 = r2448694 + r2448695;
double r2448697 = r2448693 / r2448696;
double r2448698 = r2448686 * r2448697;
double r2448699 = r2448697 - r2448687;
double r2448700 = r2448698 * r2448699;
double r2448701 = 4.0;
double r2448702 = r2448701 * r2448697;
double r2448703 = 6.0;
double r2448704 = r2448702 - r2448703;
double r2448705 = r2448694 * r2448704;
double r2448706 = r2448700 + r2448705;
double r2448707 = r2448706 * r2448696;
double r2448708 = r2448689 * r2448697;
double r2448709 = r2448707 + r2448708;
double r2448710 = r2448694 * r2448684;
double r2448711 = r2448709 + r2448710;
double r2448712 = r2448711 + r2448684;
double r2448713 = r2448689 - r2448691;
double r2448714 = r2448713 - r2448684;
double r2448715 = r2448714 / r2448696;
double r2448716 = r2448687 * r2448715;
double r2448717 = r2448712 + r2448716;
double r2448718 = r2448684 + r2448717;
return r2448718;
}
double f(double x1, double x2) {
double r2448719 = x1;
double r2448720 = 3.0;
double r2448721 = r2448720 * r2448719;
double r2448722 = r2448721 * r2448719;
double r2448723 = x2;
double r2448724 = 2.0;
double r2448725 = r2448723 * r2448724;
double r2448726 = r2448722 + r2448725;
double r2448727 = r2448726 - r2448719;
double r2448728 = 1.0;
double r2448729 = r2448719 * r2448719;
double r2448730 = r2448728 + r2448729;
double r2448731 = r2448727 / r2448730;
double r2448732 = r2448722 * r2448731;
double r2448733 = -r2448729;
double r2448734 = 6.0;
double r2448735 = r2448733 * r2448734;
double r2448736 = 4.0;
double r2448737 = r2448731 * r2448736;
double r2448738 = r2448729 * r2448737;
double r2448739 = r2448719 * r2448724;
double r2448740 = r2448739 * r2448731;
double r2448741 = 1.0;
double r2448742 = r2448741 / r2448730;
double r2448743 = -r2448720;
double r2448744 = fma(r2448727, r2448742, r2448743);
double r2448745 = r2448740 * r2448744;
double r2448746 = r2448738 + r2448745;
double r2448747 = r2448735 + r2448746;
double r2448748 = r2448747 * r2448730;
double r2448749 = r2448732 + r2448748;
double r2448750 = r2448719 * r2448729;
double r2448751 = r2448749 + r2448750;
double r2448752 = r2448719 + r2448751;
double r2448753 = r2448722 - r2448725;
double r2448754 = r2448753 - r2448719;
double r2448755 = r2448754 / r2448730;
double r2448756 = r2448720 * r2448755;
double r2448757 = r2448752 + r2448756;
double r2448758 = r2448719 + r2448757;
return r2448758;
}



Bits error versus x1



Bits error versus x2
Initial program 0.5
rmApplied sub-neg0.5
Applied distribute-rgt-in0.5
Applied associate-+r+0.5
rmApplied div-inv0.5
Applied fma-neg0.5
Final simplification0.5
herbie shell --seed 2019171 +o rules:numerics
(FPCore (x1 x2)
:name "Rosa's FloatVsDoubleBenchmark"
(+ x1 (+ (+ (+ (+ (* (+ (* (* (* 2.0 x1) (/ (- (+ (* (* 3.0 x1) x1) (* 2.0 x2)) x1) (+ (* x1 x1) 1.0))) (- (/ (- (+ (* (* 3.0 x1) x1) (* 2.0 x2)) x1) (+ (* x1 x1) 1.0)) 3.0)) (* (* x1 x1) (- (* 4.0 (/ (- (+ (* (* 3.0 x1) x1) (* 2.0 x2)) x1) (+ (* x1 x1) 1.0))) 6.0))) (+ (* x1 x1) 1.0)) (* (* (* 3.0 x1) x1) (/ (- (+ (* (* 3.0 x1) x1) (* 2.0 x2)) x1) (+ (* x1 x1) 1.0)))) (* (* x1 x1) x1)) x1) (* 3.0 (/ (- (- (* (* 3.0 x1) x1) (* 2.0 x2)) x1) (+ (* x1 x1) 1.0))))))