r \cdot \frac{\sin b}{\cos \left(a + b\right)}\frac{r \cdot \sin b}{\cos a \cdot \cos b - \sin b \cdot \sin a}(FPCore (r a b) :precision binary64 (* r (/ (sin b) (cos (+ a b)))))
(FPCore (r a b) :precision binary64 (/ (* r (sin b)) (- (* (cos a) (cos b)) (* (sin b) (sin a)))))
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 * sin(b)) / ((cos(a) * cos(b)) - (sin(b) * sin(a)));
}












Bits error versus r












Bits error versus a












Bits error versus b
Results
| Alternative 1 | |
|---|---|
| Error | 0.3 |
| Cost | 32704 |
| Alternative 2 | |
|---|---|
| Error | 0.4 |
| Cost | 26176 |
| Alternative 3 | |
|---|---|
| Error | 0.4 |
| Cost | 26176 |
| Alternative 4 | |
|---|---|
| Error | 15.2 |
| Cost | 13248 |
| Alternative 5 | |
|---|---|
| Error | 15.4 |
| Cost | 13448 |
| Alternative 6 | |
|---|---|
| Error | 15.3 |
| Cost | 13448 |
| Alternative 7 | |
|---|---|
| Error | 31.4 |
| Cost | 6720 |
| Alternative 8 | |
|---|---|
| Error | 54.1 |
| Cost | 64 |
| Alternative 9 | |
|---|---|
| Error | 61.7 |
| Cost | 64 |

Initial program 15.2
rmApplied cos-sum_binary64_5530.3
rmApplied associate-*r/_binary64_3610.3
Simplified0.3
Final simplification0.3
herbie shell --seed 2021044
(FPCore (r a b)
:name "rsin B"
:precision binary64
(* r (/ (sin b) (cos (+ a b)))))