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 r680778 = 2.0;
double r680779 = x;
double r680780 = y;
double r680781 = r680779 * r680780;
double r680782 = z;
double r680783 = r680779 * r680782;
double r680784 = r680781 + r680783;
double r680785 = r680780 * r680782;
double r680786 = r680784 + r680785;
double r680787 = sqrt(r680786);
double r680788 = r680778 * r680787;
return r680788;
}
double f(double x, double y, double z) {
double r680789 = 2.0;
double r680790 = x;
double r680791 = y;
double r680792 = r680790 * r680791;
double r680793 = z;
double r680794 = r680790 * r680793;
double r680795 = r680792 + r680794;
double r680796 = r680791 * r680793;
double r680797 = r680795 + r680796;
double r680798 = sqrt(r680797);
double r680799 = r680789 * r680798;
return r680799;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 20.1 |
|---|---|
| Target | 19.0 |
| Herbie | 20.1 |
Initial program 20.1
Final simplification20.1
herbie shell --seed 2020083
(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)))))