r \cdot \frac{\sin b}{\cos \left(a + b\right)}\frac{r \cdot \sin b}{\mathsf{fma}\left(\left(\cos a\right), \left(\cos b\right), \left(\sin b \cdot \left(-\sin a\right)\right)\right)}double f(double r, double a, double b) {
double r812036 = r;
double r812037 = b;
double r812038 = sin(r812037);
double r812039 = a;
double r812040 = r812039 + r812037;
double r812041 = cos(r812040);
double r812042 = r812038 / r812041;
double r812043 = r812036 * r812042;
return r812043;
}
double f(double r, double a, double b) {
double r812044 = r;
double r812045 = b;
double r812046 = sin(r812045);
double r812047 = r812044 * r812046;
double r812048 = a;
double r812049 = cos(r812048);
double r812050 = cos(r812045);
double r812051 = sin(r812048);
double r812052 = -r812051;
double r812053 = r812046 * r812052;
double r812054 = fma(r812049, r812050, r812053);
double r812055 = r812047 / r812054;
return r812055;
}



Bits error versus r



Bits error versus a



Bits error versus b
Initial program 15.1
rmApplied cos-sum0.3
rmApplied add-log-exp0.4
Taylor expanded around inf 0.4
rmApplied fma-neg0.3
Final simplification0.3
herbie shell --seed 2019129 +o rules:numerics
(FPCore (r a b)
:name "r*sin(b)/cos(a+b), B"
(* r (/ (sin b) (cos (+ a b)))))