2 \cdot \sqrt{\left(x \cdot y + x \cdot z\right) + y \cdot z}2 \cdot \sqrt{\left(x \cdot y + x \cdot z\right) + y \cdot z}double f(double x, double y, double z) {
double r771716 = 2.0;
double r771717 = x;
double r771718 = y;
double r771719 = r771717 * r771718;
double r771720 = z;
double r771721 = r771717 * r771720;
double r771722 = r771719 + r771721;
double r771723 = r771718 * r771720;
double r771724 = r771722 + r771723;
double r771725 = sqrt(r771724);
double r771726 = r771716 * r771725;
return r771726;
}
double f(double x, double y, double z) {
double r771727 = 2.0;
double r771728 = x;
double r771729 = y;
double r771730 = r771728 * r771729;
double r771731 = z;
double r771732 = r771728 * r771731;
double r771733 = r771730 + r771732;
double r771734 = r771729 * r771731;
double r771735 = r771733 + r771734;
double r771736 = sqrt(r771735);
double r771737 = r771727 * r771736;
return r771737;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 20.0 |
|---|---|
| Target | 19.3 |
| Herbie | 20.0 |
Initial program 20.0
Final simplification20.0
herbie shell --seed 2020065
(FPCore (x y z)
:name "Diagrams.TwoD.Apollonian:descartes from diagrams-contrib-1.3.0.5"
:precision binary64
:herbie-target
(if (< z 7.636950090573675e+176) (* 2 (sqrt (+ (* (+ x y) z) (* x y)))) (* (* (+ (* 0.25 (* (* (pow y -0.75) (* (pow z -0.75) x)) (+ y z))) (* (pow z 0.25) (pow y 0.25))) (+ (* 0.25 (* (* (pow y -0.75) (* (pow z -0.75) x)) (+ y z))) (* (pow z 0.25) (pow y 0.25)))) 2))
(* 2 (sqrt (+ (+ (* x y) (* x z)) (* y z)))))