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)\left(x1 \cdot x1 + 1\right) \cdot \left(x1 + \left(\left(x1 \cdot x1\right) \cdot \left(\frac{x2 \cdot 2 - \left(x1 - x1 \cdot \left(x1 \cdot 3\right)\right)}{x1 \cdot x1 + 1} \cdot 4 - 6\right) + \frac{x2 \cdot 2 - \left(x1 - x1 \cdot \left(x1 \cdot 3\right)\right)}{x1 \cdot x1 + 1} \cdot \left(\left(x1 \cdot \left(\frac{x2 \cdot 2 - \left(x1 - x1 \cdot \left(x1 \cdot 3\right)\right)}{x1 \cdot x1 + 1} - 3\right)\right) \cdot 2\right)\right)\right) + \left(\left(\frac{\sqrt[3]{x2 \cdot 2 - \left(x1 - x1 \cdot \left(x1 \cdot 3\right)\right)}}{\sqrt[3]{\sqrt{x1 \cdot x1 + 1}}} \cdot \left(\frac{\sqrt[3]{x2 \cdot 2 - \left(x1 - x1 \cdot \left(x1 \cdot 3\right)\right)}}{\sqrt[3]{\sqrt{x1 \cdot x1 + 1}} \cdot \sqrt[3]{\sqrt{x1 \cdot x1 + 1}}} \cdot \left(x1 \cdot \left(x1 \cdot 3\right)\right)\right)\right) \cdot \frac{\sqrt[3]{x2 \cdot 2 - \left(x1 - x1 \cdot \left(x1 \cdot 3\right)\right)}}{\sqrt{x1 \cdot x1 + 1}} + \left(3 \cdot \frac{\left(x1 \cdot \left(x1 \cdot 3\right) - x1\right) - x2 \cdot 2}{x1 \cdot x1 + 1} + x1\right)\right)double f(double x1, double x2) {
double r25120533 = x1;
double r25120534 = 2.0;
double r25120535 = r25120534 * r25120533;
double r25120536 = 3.0;
double r25120537 = r25120536 * r25120533;
double r25120538 = r25120537 * r25120533;
double r25120539 = x2;
double r25120540 = r25120534 * r25120539;
double r25120541 = r25120538 + r25120540;
double r25120542 = r25120541 - r25120533;
double r25120543 = r25120533 * r25120533;
double r25120544 = 1.0;
double r25120545 = r25120543 + r25120544;
double r25120546 = r25120542 / r25120545;
double r25120547 = r25120535 * r25120546;
double r25120548 = r25120546 - r25120536;
double r25120549 = r25120547 * r25120548;
double r25120550 = 4.0;
double r25120551 = r25120550 * r25120546;
double r25120552 = 6.0;
double r25120553 = r25120551 - r25120552;
double r25120554 = r25120543 * r25120553;
double r25120555 = r25120549 + r25120554;
double r25120556 = r25120555 * r25120545;
double r25120557 = r25120538 * r25120546;
double r25120558 = r25120556 + r25120557;
double r25120559 = r25120543 * r25120533;
double r25120560 = r25120558 + r25120559;
double r25120561 = r25120560 + r25120533;
double r25120562 = r25120538 - r25120540;
double r25120563 = r25120562 - r25120533;
double r25120564 = r25120563 / r25120545;
double r25120565 = r25120536 * r25120564;
double r25120566 = r25120561 + r25120565;
double r25120567 = r25120533 + r25120566;
return r25120567;
}
double f(double x1, double x2) {
double r25120568 = x1;
double r25120569 = r25120568 * r25120568;
double r25120570 = 1.0;
double r25120571 = r25120569 + r25120570;
double r25120572 = x2;
double r25120573 = 2.0;
double r25120574 = r25120572 * r25120573;
double r25120575 = 3.0;
double r25120576 = r25120568 * r25120575;
double r25120577 = r25120568 * r25120576;
double r25120578 = r25120568 - r25120577;
double r25120579 = r25120574 - r25120578;
double r25120580 = r25120579 / r25120571;
double r25120581 = 4.0;
double r25120582 = r25120580 * r25120581;
double r25120583 = 6.0;
double r25120584 = r25120582 - r25120583;
double r25120585 = r25120569 * r25120584;
double r25120586 = r25120580 - r25120575;
double r25120587 = r25120568 * r25120586;
double r25120588 = r25120587 * r25120573;
double r25120589 = r25120580 * r25120588;
double r25120590 = r25120585 + r25120589;
double r25120591 = r25120568 + r25120590;
double r25120592 = r25120571 * r25120591;
double r25120593 = cbrt(r25120579);
double r25120594 = sqrt(r25120571);
double r25120595 = cbrt(r25120594);
double r25120596 = r25120593 / r25120595;
double r25120597 = r25120595 * r25120595;
double r25120598 = r25120593 / r25120597;
double r25120599 = r25120598 * r25120577;
double r25120600 = r25120596 * r25120599;
double r25120601 = r25120593 / r25120594;
double r25120602 = r25120600 * r25120601;
double r25120603 = r25120577 - r25120568;
double r25120604 = r25120603 - r25120574;
double r25120605 = r25120604 / r25120571;
double r25120606 = r25120575 * r25120605;
double r25120607 = r25120606 + r25120568;
double r25120608 = r25120602 + r25120607;
double r25120609 = r25120592 + r25120608;
return r25120609;
}



Bits error versus x1



Bits error versus x2
Results
Initial program 0.5
Simplified0.5
rmApplied add-sqr-sqrt0.5
Applied add-cube-cbrt0.5
Applied times-frac0.5
Applied associate-*r*0.5
rmApplied add-cube-cbrt0.5
Applied times-frac0.5
Applied associate-*r*0.5
Final simplification0.5
herbie shell --seed 2019107
(FPCore (x1 x2)
:name "Rosa's FloatVsDoubleBenchmark"
(+ 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))))))