\frac{e \cdot \sin v}{1 + e \cdot \cos v}\frac{\sin v}{\frac{\mathsf{fma}\left(\cos v, e, 1\right)}{e}}double code(double e, double v) {
return ((double) (((double) (e * ((double) sin(v)))) / ((double) (1.0 + ((double) (e * ((double) cos(v))))))));
}
double code(double e, double v) {
return ((double) (((double) sin(v)) / ((double) (((double) fma(((double) cos(v)), e, 1.0)) / e))));
}



Bits error versus e



Bits error versus v
Results
Initial program 0.1
Simplified0.2
Final simplification0.2
herbie shell --seed 2020121 +o rules:numerics
(FPCore (e v)
:name "Trigonometry A"
:precision binary64
:pre (<= 0.0 e 1)
(/ (* e (sin v)) (+ 1 (* e (cos v)))))