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 r755085 = 2.0;
double r755086 = x;
double r755087 = y;
double r755088 = r755086 * r755087;
double r755089 = z;
double r755090 = r755086 * r755089;
double r755091 = r755088 + r755090;
double r755092 = r755087 * r755089;
double r755093 = r755091 + r755092;
double r755094 = sqrt(r755093);
double r755095 = r755085 * r755094;
return r755095;
}
double f(double x, double y, double z) {
double r755096 = 2.0;
double r755097 = x;
double r755098 = y;
double r755099 = r755097 * r755098;
double r755100 = z;
double r755101 = r755097 * r755100;
double r755102 = r755099 + r755101;
double r755103 = r755098 * r755100;
double r755104 = r755102 + r755103;
double r755105 = sqrt(r755104);
double r755106 = r755096 * r755105;
return r755106;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 19.5 |
|---|---|
| Target | 19.0 |
| Herbie | 19.5 |
Initial program 19.5
Final simplification19.5
herbie shell --seed 2020025
(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)))))