\frac{r \cdot \sin b}{\cos \left(a + b\right)}r \cdot \frac{\sin b}{\mathsf{fma}\left(\sin b, -\sin a, \cos a \cdot \cos b\right)}double f(double r, double a, double b) {
double r16574 = r;
double r16575 = b;
double r16576 = sin(r16575);
double r16577 = r16574 * r16576;
double r16578 = a;
double r16579 = r16578 + r16575;
double r16580 = cos(r16579);
double r16581 = r16577 / r16580;
return r16581;
}
double f(double r, double a, double b) {
double r16582 = r;
double r16583 = b;
double r16584 = sin(r16583);
double r16585 = a;
double r16586 = sin(r16585);
double r16587 = -r16586;
double r16588 = cos(r16585);
double r16589 = cos(r16583);
double r16590 = r16588 * r16589;
double r16591 = fma(r16584, r16587, r16590);
double r16592 = r16584 / r16591;
double r16593 = r16582 * r16592;
return r16593;
}



Bits error versus r



Bits error versus a



Bits error versus b
Initial program 15.3
rmApplied cos-sum0.3
rmApplied fma-neg0.3
Simplified0.3
rmApplied *-un-lft-identity0.3
Applied times-frac0.3
Simplified0.3
Taylor expanded around inf 0.3
Simplified0.3
Final simplification0.3
herbie shell --seed 2020042 +o rules:numerics
(FPCore (r a b)
:name "r*sin(b)/cos(a+b), A"
:precision binary64
(/ (* r (sin b)) (cos (+ a b))))