| Alternative 1 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 39040 |
\[\frac{r \cdot \sin b}{\mathsf{fma}\left(\sin b, -\sin a, \cos a \cdot \cos b\right)}
\]

(FPCore (r a b) :precision binary64 (/ (* r (sin b)) (cos (+ a b))))
(FPCore (r a b) :precision binary64 (/ (* r (sin b)) (fma (sin b) (- (sin a)) (* (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 (r * sin(b)) / fma(sin(b), -sin(a), (cos(a) * cos(b)));
}
function code(r, a, b) return Float64(Float64(r * sin(b)) / cos(Float64(a + b))) end
function code(r, a, b) return Float64(Float64(r * sin(b)) / fma(sin(b), Float64(-sin(a)), Float64(cos(a) * cos(b)))) end
code[r_, a_, b_] := N[(N[(r * N[Sin[b], $MachinePrecision]), $MachinePrecision] / N[Cos[N[(a + b), $MachinePrecision]], $MachinePrecision]), $MachinePrecision]
code[r_, a_, b_] := N[(N[(r * N[Sin[b], $MachinePrecision]), $MachinePrecision] / N[(N[Sin[b], $MachinePrecision] * (-N[Sin[a], $MachinePrecision]) + N[(N[Cos[a], $MachinePrecision] * N[Cos[b], $MachinePrecision]), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\frac{r \cdot \sin b}{\cos \left(a + b\right)}
\frac{r \cdot \sin b}{\mathsf{fma}\left(\sin b, -\sin a, \cos a \cdot \cos b\right)}
Herbie found 13 alternatives:
| Alternative | Accuracy | Speedup |
|---|
Initial program 80.2%
Simplified80.2%
[Start]80.2% | \[ \frac{r \cdot \sin b}{\cos \left(a + b\right)}
\] |
|---|---|
+-commutative [=>]80.2% | \[ \frac{r \cdot \sin b}{\cos \color{blue}{\left(b + a\right)}}
\] |
Applied egg-rr99.5%
[Start]80.2% | \[ \frac{r \cdot \sin b}{\cos \left(b + a\right)}
\] |
|---|---|
cos-sum [=>]99.5% | \[ \frac{r \cdot \sin b}{\color{blue}{\cos b \cdot \cos a - \sin b \cdot \sin a}}
\] |
Applied egg-rr99.5%
[Start]99.5% | \[ \frac{r \cdot \sin b}{\cos b \cdot \cos a - \sin b \cdot \sin a}
\] |
|---|---|
log1p-expm1-u [=>]99.5% | \[ \frac{r \cdot \sin b}{\cos b \cdot \cos a - \color{blue}{\mathsf{log1p}\left(\mathsf{expm1}\left(\sin b \cdot \sin a\right)\right)}}
\] |
Taylor expanded in b around inf 99.5%
Simplified99.5%
[Start]99.5% | \[ \frac{r \cdot \sin b}{\cos a \cdot \cos b - \sin a \cdot \sin b}
\] |
|---|---|
cancel-sign-sub-inv [=>]99.5% | \[ \frac{r \cdot \sin b}{\color{blue}{\cos a \cdot \cos b + \left(-\sin a\right) \cdot \sin b}}
\] |
*-commutative [=>]99.5% | \[ \frac{r \cdot \sin b}{\color{blue}{\cos b \cdot \cos a} + \left(-\sin a\right) \cdot \sin b}
\] |
*-commutative [<=]99.5% | \[ \frac{r \cdot \sin b}{\cos b \cdot \cos a + \color{blue}{\sin b \cdot \left(-\sin a\right)}}
\] |
+-commutative [=>]99.5% | \[ \frac{r \cdot \sin b}{\color{blue}{\sin b \cdot \left(-\sin a\right) + \cos b \cdot \cos a}}
\] |
fma-def [=>]99.5% | \[ \frac{r \cdot \sin b}{\color{blue}{\mathsf{fma}\left(\sin b, -\sin a, \cos b \cdot \cos a\right)}}
\] |
*-commutative [<=]99.5% | \[ \frac{r \cdot \sin b}{\mathsf{fma}\left(\sin b, -\sin a, \color{blue}{\cos a \cdot \cos b}\right)}
\] |
Final simplification99.5%
| Alternative 1 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 39040 |
| Alternative 2 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 32704 |
| Alternative 3 | |
|---|---|
| Accuracy | 99.5% |
| Cost | 32704 |
| Alternative 4 | |
|---|---|
| Accuracy | 76.1% |
| Cost | 13248 |
| Alternative 5 | |
|---|---|
| Accuracy | 76.1% |
| Cost | 13248 |
| Alternative 6 | |
|---|---|
| Accuracy | 75.9% |
| Cost | 7113 |
| Alternative 7 | |
|---|---|
| Accuracy | 75.8% |
| Cost | 6985 |
| Alternative 8 | |
|---|---|
| Accuracy | 75.8% |
| Cost | 6985 |
| Alternative 9 | |
|---|---|
| Accuracy | 60.2% |
| Cost | 6592 |
| Alternative 10 | |
|---|---|
| Accuracy | 34.2% |
| Cost | 576 |
| Alternative 11 | |
|---|---|
| Accuracy | 35.1% |
| Cost | 576 |
| Alternative 12 | |
|---|---|
| Accuracy | 34.2% |
| Cost | 448 |
| Alternative 13 | |
|---|---|
| Accuracy | 34.6% |
| Cost | 192 |
herbie shell --seed 2023271
(FPCore (r a b)
:name "rsin A (should all be same)"
:precision binary64
(/ (* r (sin b)) (cos (+ a b))))