\sqrt{\left|\frac{a \cdot a - b \cdot b}{a \cdot a}\right|}\sqrt{\left|\frac{a + b}{a} \cdot \mathsf{expm1}\left(\mathsf{log1p}\left(\frac{a - b}{a}\right)\right)\right|}double code(double a, double b) {
return sqrt(fabs((((a * a) - (b * b)) / (a * a))));
}
double code(double a, double b) {
return sqrt(fabs((((a + b) / a) * expm1(log1p(((a - b) / a))))));
}



Bits error versus a



Bits error versus b
Results
Initial program 14.9
rmApplied difference-of-squares14.9
Applied times-frac0.0
rmApplied expm1-log1p-u0.0
Final simplification0.0
herbie shell --seed 2020079 +o rules:numerics
(FPCore (a b)
:name "Eccentricity of an ellipse"
:precision binary64
:pre (<= 0.0 b a 1)
(sqrt (fabs (/ (- (* a a) (* b b)) (* a a)))))