\frac{r \cdot \sin b}{\cos \left(a + b\right)}\frac{r}{\mathsf{fma}\left(\frac{\cos a}{\sin b}, \cos b, \frac{-\sin a}{1}\right)}double code(double r, double a, double b) {
return ((r * sin(b)) / cos((a + b)));
}
double code(double r, double a, double b) {
return (r / fma((cos(a) / sin(b)), cos(b), (-sin(a) / 1.0)));
}



Bits error versus r



Bits error versus a



Bits error versus b
Results
Initial program 14.9
rmApplied cos-sum0.3
rmApplied *-commutative0.3
Applied fma-neg0.3
rmApplied associate-/l*0.4
Simplified0.4
Final simplification0.4
herbie shell --seed 2020078 +o rules:numerics
(FPCore (r a b)
:name "r*sin(b)/cos(a+b), A"
:precision binary64
(/ (* r (sin b)) (cos (+ a b))))