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 r737136 = 2.0;
double r737137 = x;
double r737138 = y;
double r737139 = r737137 * r737138;
double r737140 = z;
double r737141 = r737137 * r737140;
double r737142 = r737139 + r737141;
double r737143 = r737138 * r737140;
double r737144 = r737142 + r737143;
double r737145 = sqrt(r737144);
double r737146 = r737136 * r737145;
return r737146;
}
double f(double x, double y, double z) {
double r737147 = 2.0;
double r737148 = x;
double r737149 = y;
double r737150 = r737148 * r737149;
double r737151 = z;
double r737152 = r737148 * r737151;
double r737153 = r737150 + r737152;
double r737154 = r737149 * r737151;
double r737155 = r737153 + r737154;
double r737156 = sqrt(r737155);
double r737157 = r737147 * r737156;
return r737157;
}




Bits error versus x




Bits error versus y




Bits error versus z
Results
| Original | 19.9 |
|---|---|
| Target | 19.1 |
| Herbie | 19.9 |
Initial program 19.9
Final simplification19.9
herbie shell --seed 2019353 +o rules:numerics
(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)))))