| Alternative 1 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 32704 |
\[r \cdot \frac{\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 (/ (* (sin b) r) (fma (sin a) (- (sin b)) (* (cos a) (cos b)))))
double code(double r, double a, double b) {
return r * (sin(b) / cos((a + b)));
}
double code(double r, double a, double b) {
return (sin(b) * r) / fma(sin(a), -sin(b), (cos(a) * cos(b)));
}
function code(r, a, b) return Float64(r * Float64(sin(b) / cos(Float64(a + b)))) end
function code(r, a, b) return Float64(Float64(sin(b) * r) / fma(sin(a), Float64(-sin(b)), Float64(cos(a) * cos(b)))) end
code[r_, a_, b_] := N[(r * N[(N[Sin[b], $MachinePrecision] / N[Cos[N[(a + b), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
code[r_, a_, b_] := N[(N[(N[Sin[b], $MachinePrecision] * r), $MachinePrecision] / N[(N[Sin[a], $MachinePrecision] * (-N[Sin[b], $MachinePrecision]) + N[(N[Cos[a], $MachinePrecision] * N[Cos[b], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
r \cdot \frac{\sin b}{\cos \left(a + b\right)}
\frac{\sin b \cdot r}{\mathsf{fma}\left(\sin a, -\sin b, \cos a \cdot \cos b\right)}
Initial program 76.5%
Simplified76.5%
[Start]76.5 | \[ r \cdot \frac{\sin b}{\cos \left(a + b\right)}
\] |
|---|---|
+-commutative [=>]76.5 | \[ r \cdot \frac{\sin b}{\cos \color{blue}{\left(b + a\right)}}
\] |
Applied egg-rr99.5%
[Start]76.5 | \[ r \cdot \frac{\sin b}{\cos \left(b + a\right)}
\] |
|---|---|
cos-sum [=>]99.5 | \[ r \cdot \frac{\sin b}{\color{blue}{\cos b \cdot \cos a - \sin b \cdot \sin a}}
\] |
fma-neg [=>]99.5 | \[ r \cdot \frac{\sin b}{\color{blue}{\mathsf{fma}\left(\cos b, \cos a, -\sin b \cdot \sin a\right)}}
\] |
Taylor expanded in r around 0 99.5%
Applied egg-rr99.5%
[Start]99.5 | \[ \frac{\sin b \cdot r}{\cos a \cdot \cos b - \sin a \cdot \sin b}
\] |
|---|---|
sub-neg [=>]99.5 | \[ \frac{\sin b \cdot r}{\color{blue}{\cos a \cdot \cos b + \left(-\sin a \cdot \sin b\right)}}
\] |
distribute-rgt-neg-in [=>]99.5 | \[ \frac{\sin b \cdot r}{\cos a \cdot \cos b + \color{blue}{\sin a \cdot \left(-\sin b\right)}}
\] |
Simplified99.5%
[Start]99.5 | \[ \frac{\sin b \cdot r}{\cos a \cdot \cos b + \sin a \cdot \left(-\sin b\right)}
\] |
|---|---|
+-commutative [<=]99.5 | \[ \frac{\sin b \cdot r}{\color{blue}{\sin a \cdot \left(-\sin b\right) + \cos a \cdot \cos b}}
\] |
fma-def [=>]99.5 | \[ \frac{\sin b \cdot r}{\color{blue}{\mathsf{fma}\left(\sin a, -\sin b, \cos a \cdot \cos b\right)}}
\] |
Final simplification99.5%
| Alternative 1 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 32704 |
| Alternative 2 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 32704 |
| Alternative 3 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 32704 |
| Alternative 4 | |
|---|---|
| Accuracy | 77.6% |
| Cost | 19648 |
| Alternative 5 | |
|---|---|
| Accuracy | 76.3% |
| Cost | 13384 |
| Alternative 6 | |
|---|---|
| Accuracy | 76.5% |
| Cost | 13248 |
| Alternative 7 | |
|---|---|
| Accuracy | 76.5% |
| Cost | 13248 |
| Alternative 8 | |
|---|---|
| Accuracy | 76.3% |
| Cost | 7113 |
| Alternative 9 | |
|---|---|
| Accuracy | 76.3% |
| Cost | 6985 |
| Alternative 10 | |
|---|---|
| Accuracy | 76.3% |
| Cost | 6985 |
| Alternative 11 | |
|---|---|
| Accuracy | 39.1% |
| Cost | 6592 |
| Alternative 12 | |
|---|---|
| Accuracy | 60.0% |
| Cost | 6592 |
| Alternative 13 | |
|---|---|
| Accuracy | 34.6% |
| Cost | 192 |
herbie shell --seed 2023137
(FPCore (r a b)
:name "rsin B (should all be same)"
:precision binary64
(* r (/ (sin b) (cos (+ a b)))))