| Alternative 1 | |
|---|---|
| Error | 99.5% |
| Cost | 39040.00 |
\[r \cdot \frac{\sin b}{\mathsf{fma}\left(\cos b, \cos a, \sin b \cdot \left(-\sin a\right)\right)}
\]
(FPCore (r a b) :precision binary64 (* r (/ (sin b) (cos (+ a b)))))
(FPCore (r a b)
:precision binary64
(*
r
(/
(sin b)
(fma
(cos b)
(cos a)
(fma (- (sin b)) (sin a) (fma (- (sin a)) (sin 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) / fma(cos(b), cos(a), fma(-sin(b), sin(a), fma(-sin(a), sin(b), (sin(b) * sin(a))))));
}
function code(r, a, b) return Float64(r * Float64(sin(b) / cos(Float64(a + b)))) end
function code(r, a, b) return Float64(r * Float64(sin(b) / fma(cos(b), cos(a), fma(Float64(-sin(b)), sin(a), fma(Float64(-sin(a)), sin(b), Float64(sin(b) * sin(a))))))) 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[(r * N[(N[Sin[b], $MachinePrecision] / N[(N[Cos[b], $MachinePrecision] * N[Cos[a], $MachinePrecision] + N[((-N[Sin[b], $MachinePrecision]) * N[Sin[a], $MachinePrecision] + N[((-N[Sin[a], $MachinePrecision]) * N[Sin[b], $MachinePrecision] + N[(N[Sin[b], $MachinePrecision] * N[Sin[a], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
r \cdot \frac{\sin b}{\cos \left(a + b\right)}
r \cdot \frac{\sin b}{\mathsf{fma}\left(\cos b, \cos a, \mathsf{fma}\left(-\sin b, \sin a, \mathsf{fma}\left(-\sin a, \sin b, \sin b \cdot \sin a\right)\right)\right)}
Initial program 76.9
Simplified76.9
[Start]76.9 | \[ r \cdot \frac{\sin b}{\cos \left(a + b\right)}
\] |
|---|---|
+-commutative [=>]76.9 | \[ r \cdot \frac{\sin b}{\cos \color{blue}{\left(b + a\right)}}
\] |
Applied egg-rr99.5
Simplified99.5
[Start]99.5 | \[ r \cdot \frac{\sin b}{\cos b \cdot \cos a + \left(\left(-\sin b\right) \cdot \sin a + \mathsf{fma}\left(-\sin a, \sin b, \sin b \cdot \sin a\right)\right)}
\] |
|---|---|
fma-def [=>]99.5 | \[ r \cdot \frac{\sin b}{\color{blue}{\mathsf{fma}\left(\cos b, \cos a, \left(-\sin b\right) \cdot \sin a + \mathsf{fma}\left(-\sin a, \sin b, \sin b \cdot \sin a\right)\right)}}
\] |
fma-def [=>]99.5 | \[ r \cdot \frac{\sin b}{\mathsf{fma}\left(\cos b, \cos a, \color{blue}{\mathsf{fma}\left(-\sin b, \sin a, \mathsf{fma}\left(-\sin a, \sin b, \sin b \cdot \sin a\right)\right)}\right)}
\] |
*-commutative [=>]99.5 | \[ r \cdot \frac{\sin b}{\mathsf{fma}\left(\cos b, \cos a, \mathsf{fma}\left(-\sin b, \sin a, \mathsf{fma}\left(-\sin a, \sin b, \color{blue}{\sin a \cdot \sin b}\right)\right)\right)}
\] |
Final simplification99.5
| Alternative 1 | |
|---|---|
| Error | 99.5% |
| Cost | 39040.00 |
| Alternative 2 | |
|---|---|
| Error | 99.5% |
| Cost | 32704.00 |
| Alternative 3 | |
|---|---|
| Error | 76.6% |
| Cost | 13385.00 |
| Alternative 4 | |
|---|---|
| Error | 76.6% |
| Cost | 13385.00 |
| Alternative 5 | |
|---|---|
| Error | 76.9% |
| Cost | 13248.00 |
| Alternative 6 | |
|---|---|
| Error | 54.9% |
| Cost | 13120.00 |
| Alternative 7 | |
|---|---|
| Error | 51.5% |
| Cost | 7232.00 |
| Alternative 8 | |
|---|---|
| Error | 50.7% |
| Cost | 6848.00 |
| Alternative 9 | |
|---|---|
| Error | 50.7% |
| Cost | 6720.00 |
| Alternative 10 | |
|---|---|
| Error | 50.7% |
| Cost | 6720.00 |
| Alternative 11 | |
|---|---|
| Error | 34.4% |
| Cost | 192.00 |
herbie shell --seed 2023093
(FPCore (r a b)
:name "rsin B (should all be same)"
:precision binary64
(* r (/ (sin b) (cos (+ a b)))))