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(\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 r86087 = x1;
double r86088 = 2.0;
double r86089 = r86088 * r86087;
double r86090 = 3.0;
double r86091 = r86090 * r86087;
double r86092 = r86091 * r86087;
double r86093 = x2;
double r86094 = r86088 * r86093;
double r86095 = r86092 + r86094;
double r86096 = r86095 - r86087;
double r86097 = r86087 * r86087;
double r86098 = 1.0;
double r86099 = r86097 + r86098;
double r86100 = r86096 / r86099;
double r86101 = r86089 * r86100;
double r86102 = r86100 - r86090;
double r86103 = r86101 * r86102;
double r86104 = 4.0;
double r86105 = r86104 * r86100;
double r86106 = 6.0;
double r86107 = r86105 - r86106;
double r86108 = r86097 * r86107;
double r86109 = r86103 + r86108;
double r86110 = r86109 * r86099;
double r86111 = r86092 * r86100;
double r86112 = r86110 + r86111;
double r86113 = r86097 * r86087;
double r86114 = r86112 + r86113;
double r86115 = r86114 + r86087;
double r86116 = r86092 - r86094;
double r86117 = r86116 - r86087;
double r86118 = r86117 / r86099;
double r86119 = r86090 * r86118;
double r86120 = r86115 + r86119;
double r86121 = r86087 + r86120;
return r86121;
}
double f(double x1, double x2) {
double r86122 = x1;
double r86123 = 2.0;
double r86124 = r86123 * r86122;
double r86125 = 3.0;
double r86126 = r86125 * r86122;
double r86127 = r86126 * r86122;
double r86128 = x2;
double r86129 = r86123 * r86128;
double r86130 = r86127 + r86129;
double r86131 = r86130 - r86122;
double r86132 = r86122 * r86122;
double r86133 = 1.0;
double r86134 = r86132 + r86133;
double r86135 = r86131 / r86134;
double r86136 = r86124 * r86135;
double r86137 = r86135 - r86125;
double r86138 = cbrt(r86137);
double r86139 = r86138 * r86138;
double r86140 = r86139 * r86138;
double r86141 = r86136 * r86140;
double r86142 = 4.0;
double r86143 = r86142 * r86135;
double r86144 = 6.0;
double r86145 = r86143 - r86144;
double r86146 = r86132 * r86145;
double r86147 = r86141 + r86146;
double r86148 = r86147 * r86134;
double r86149 = r86127 * r86135;
double r86150 = r86148 + r86149;
double r86151 = r86132 * r86122;
double r86152 = r86150 + r86151;
double r86153 = r86152 + r86122;
double r86154 = r86127 - r86129;
double r86155 = r86154 - r86122;
double r86156 = r86155 / r86134;
double r86157 = r86125 * r86156;
double r86158 = r86153 + r86157;
double r86159 = r86122 + r86158;
return r86159;
}



Bits error versus x1



Bits error versus x2
Results
Initial program 0.5
rmApplied add-cube-cbrt0.7
Final simplification0.7
herbie shell --seed 2020047
(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))))))