\frac{r \cdot \sin b}{\cos \left(a + b\right)}r \cdot \left(\sin b \cdot \frac{1}{\cos b \cdot \cos a - \sin a \cdot \sin b}\right)double f(double r, double a, double b) {
double r17005 = r;
double r17006 = b;
double r17007 = sin(r17006);
double r17008 = r17005 * r17007;
double r17009 = a;
double r17010 = r17009 + r17006;
double r17011 = cos(r17010);
double r17012 = r17008 / r17011;
return r17012;
}
double f(double r, double a, double b) {
double r17013 = r;
double r17014 = b;
double r17015 = sin(r17014);
double r17016 = 1.0;
double r17017 = cos(r17014);
double r17018 = a;
double r17019 = cos(r17018);
double r17020 = r17017 * r17019;
double r17021 = sin(r17018);
double r17022 = r17021 * r17015;
double r17023 = r17020 - r17022;
double r17024 = r17016 / r17023;
double r17025 = r17015 * r17024;
double r17026 = r17013 * r17025;
return r17026;
}



Bits error versus r



Bits error versus a



Bits error versus b
Results
Initial program 14.9
rmApplied cos-sum0.3
rmApplied *-un-lft-identity0.3
Applied times-frac0.3
Simplified0.3
Simplified0.3
rmApplied div-inv0.4
Final simplification0.4
herbie shell --seed 2020057
(FPCore (r a b)
:name "r*sin(b)/cos(a+b), A"
:precision binary64
(/ (* r (sin b)) (cos (+ a b))))