\left(x \cdot x + \left(x \cdot 2\right) \cdot y\right) + y \cdot y
\mathsf{fma}\left(\sqrt{x \cdot x}, \sqrt{x \cdot x}, \left(x \cdot 2\right) \cdot y\right) + y \cdot ydouble code(double x, double y) {
return ((double) (((double) (((double) (x * x)) + ((double) (((double) (x * 2.0)) * y)))) + ((double) (y * y))));
}
double code(double x, double y) {
return ((double) (((double) fma(((double) sqrt(((double) (x * x)))), ((double) sqrt(((double) (x * x)))), ((double) (((double) (x * 2.0)) * y)))) + ((double) (y * y))));
}




Bits error versus x




Bits error versus y
Results
| Original | 0.0 |
|---|---|
| Target | 0.0 |
| Herbie | 0.0 |
Initial program 0.0
rmApplied add-sqr-sqrt0.0
Applied fma-def0.0
Final simplification0.0
herbie shell --seed 2020114 +o rules:numerics
(FPCore (x y)
:name "Examples.Basics.ProofTests:f4 from sbv-4.4"
:precision binary64
:herbie-target
(+ (* x x) (+ (* y y) (* (* x y) 2)))
(+ (+ (* x x) (* (* x 2) y)) (* y y)))