| Alternative 1 | |
|---|---|
| Accuracy | 99.2% |
| Cost | 39176 |
(FPCore (x eps) :precision binary64 (- (cos (+ x eps)) (cos x)))
(FPCore (x eps) :precision binary64 (fma (- (sin x)) (sin eps) (* (cos x) (* (tan (/ eps 2.0)) (- (sin eps))))))
double code(double x, double eps) {
return cos((x + eps)) - cos(x);
}
double code(double x, double eps) {
return fma(-sin(x), sin(eps), (cos(x) * (tan((eps / 2.0)) * -sin(eps))));
}
function code(x, eps) return Float64(cos(Float64(x + eps)) - cos(x)) end
function code(x, eps) return fma(Float64(-sin(x)), sin(eps), Float64(cos(x) * Float64(tan(Float64(eps / 2.0)) * Float64(-sin(eps))))) end
code[x_, eps_] := N[(N[Cos[N[(x + eps), $MachinePrecision]], $MachinePrecision] - N[Cos[x], $MachinePrecision]), $MachinePrecision]
code[x_, eps_] := N[((-N[Sin[x], $MachinePrecision]) * N[Sin[eps], $MachinePrecision] + N[(N[Cos[x], $MachinePrecision] * N[(N[Tan[N[(eps / 2.0), $MachinePrecision]], $MachinePrecision] * (-N[Sin[eps], $MachinePrecision])), $MachinePrecision]), $MachinePrecision]), $MachinePrecision]
\cos \left(x + \varepsilon\right) - \cos x
\mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\tan \left(\frac{\varepsilon}{2}\right) \cdot \left(-\sin \varepsilon\right)\right)\right)
Initial program 36.1%
Applied egg-rr59.0%
[Start]36.1 | \[ \cos \left(x + \varepsilon\right) - \cos x
\] |
|---|---|
cos-sum [=>]59.0 | \[ \color{blue}{\left(\cos x \cdot \cos \varepsilon - \sin x \cdot \sin \varepsilon\right)} - \cos x
\] |
sub-neg [=>]59.0 | \[ \color{blue}{\left(\cos x \cdot \cos \varepsilon + \left(-\sin x \cdot \sin \varepsilon\right)\right)} - \cos x
\] |
Simplified59.0%
[Start]59.0 | \[ \left(\cos x \cdot \cos \varepsilon + \left(-\sin x \cdot \sin \varepsilon\right)\right) - \cos x
\] |
|---|---|
+-commutative [=>]59.0 | \[ \color{blue}{\left(\left(-\sin x \cdot \sin \varepsilon\right) + \cos x \cdot \cos \varepsilon\right)} - \cos x
\] |
distribute-lft-neg-in [=>]59.0 | \[ \left(\color{blue}{\left(-\sin x\right) \cdot \sin \varepsilon} + \cos x \cdot \cos \varepsilon\right) - \cos x
\] |
*-commutative [=>]59.0 | \[ \left(\color{blue}{\sin \varepsilon \cdot \left(-\sin x\right)} + \cos x \cdot \cos \varepsilon\right) - \cos x
\] |
fma-def [=>]59.0 | \[ \color{blue}{\mathsf{fma}\left(\sin \varepsilon, -\sin x, \cos x \cdot \cos \varepsilon\right)} - \cos x
\] |
*-commutative [=>]59.0 | \[ \mathsf{fma}\left(\sin \varepsilon, -\sin x, \color{blue}{\cos \varepsilon \cdot \cos x}\right) - \cos x
\] |
Applied egg-rr91.4%
[Start]59.0 | \[ \mathsf{fma}\left(\sin \varepsilon, -\sin x, \cos \varepsilon \cdot \cos x\right) - \cos x
\] |
|---|---|
fma-udef [=>]59.0 | \[ \color{blue}{\left(\sin \varepsilon \cdot \left(-\sin x\right) + \cos \varepsilon \cdot \cos x\right)} - \cos x
\] |
associate--l+ [=>]91.3 | \[ \color{blue}{\sin \varepsilon \cdot \left(-\sin x\right) + \left(\cos \varepsilon \cdot \cos x - \cos x\right)}
\] |
neg-mul-1 [=>]91.3 | \[ \sin \varepsilon \cdot \color{blue}{\left(-1 \cdot \sin x\right)} + \left(\cos \varepsilon \cdot \cos x - \cos x\right)
\] |
associate-*r* [=>]91.3 | \[ \color{blue}{\left(\sin \varepsilon \cdot -1\right) \cdot \sin x} + \left(\cos \varepsilon \cdot \cos x - \cos x\right)
\] |
fma-def [=>]91.4 | \[ \color{blue}{\mathsf{fma}\left(\sin \varepsilon \cdot -1, \sin x, \cos \varepsilon \cdot \cos x - \cos x\right)}
\] |
Taylor expanded in eps around inf 59.0%
Simplified91.4%
[Start]59.0 | \[ \left(-1 \cdot \left(\sin x \cdot \sin \varepsilon\right) + \cos x \cdot \cos \varepsilon\right) - \cos x
\] |
|---|---|
associate--l+ [=>]91.3 | \[ \color{blue}{-1 \cdot \left(\sin x \cdot \sin \varepsilon\right) + \left(\cos x \cdot \cos \varepsilon - \cos x\right)}
\] |
associate-*r* [=>]91.3 | \[ \color{blue}{\left(-1 \cdot \sin x\right) \cdot \sin \varepsilon} + \left(\cos x \cdot \cos \varepsilon - \cos x\right)
\] |
sub-neg [=>]91.3 | \[ \left(-1 \cdot \sin x\right) \cdot \sin \varepsilon + \color{blue}{\left(\cos x \cdot \cos \varepsilon + \left(-\cos x\right)\right)}
\] |
*-commutative [=>]91.3 | \[ \left(-1 \cdot \sin x\right) \cdot \sin \varepsilon + \left(\color{blue}{\cos \varepsilon \cdot \cos x} + \left(-\cos x\right)\right)
\] |
neg-mul-1 [=>]91.3 | \[ \left(-1 \cdot \sin x\right) \cdot \sin \varepsilon + \left(\cos \varepsilon \cdot \cos x + \color{blue}{-1 \cdot \cos x}\right)
\] |
distribute-rgt-in [<=]91.3 | \[ \left(-1 \cdot \sin x\right) \cdot \sin \varepsilon + \color{blue}{\cos x \cdot \left(\cos \varepsilon + -1\right)}
\] |
metadata-eval [<=]91.3 | \[ \left(-1 \cdot \sin x\right) \cdot \sin \varepsilon + \cos x \cdot \left(\cos \varepsilon + \color{blue}{\left(-1\right)}\right)
\] |
sub-neg [<=]91.3 | \[ \left(-1 \cdot \sin x\right) \cdot \sin \varepsilon + \cos x \cdot \color{blue}{\left(\cos \varepsilon - 1\right)}
\] |
fma-udef [<=]91.4 | \[ \color{blue}{\mathsf{fma}\left(-1 \cdot \sin x, \sin \varepsilon, \cos x \cdot \left(\cos \varepsilon - 1\right)\right)}
\] |
mul-1-neg [=>]91.4 | \[ \mathsf{fma}\left(\color{blue}{-\sin x}, \sin \varepsilon, \cos x \cdot \left(\cos \varepsilon - 1\right)\right)
\] |
sub-neg [=>]91.4 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \color{blue}{\left(\cos \varepsilon + \left(-1\right)\right)}\right)
\] |
metadata-eval [=>]91.4 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\cos \varepsilon + \color{blue}{-1}\right)\right)
\] |
Applied egg-rr99.1%
[Start]91.4 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\cos \varepsilon + -1\right)\right)
\] |
|---|---|
flip-+ [=>]91.0 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \color{blue}{\frac{\cos \varepsilon \cdot \cos \varepsilon - -1 \cdot -1}{\cos \varepsilon - -1}}\right)
\] |
div-inv [=>]91.0 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \color{blue}{\left(\left(\cos \varepsilon \cdot \cos \varepsilon - -1 \cdot -1\right) \cdot \frac{1}{\cos \varepsilon - -1}\right)}\right)
\] |
metadata-eval [=>]91.0 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\left(\cos \varepsilon \cdot \cos \varepsilon - \color{blue}{1}\right) \cdot \frac{1}{\cos \varepsilon - -1}\right)\right)
\] |
sub-1-cos [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\color{blue}{\left(-\sin \varepsilon \cdot \sin \varepsilon\right)} \cdot \frac{1}{\cos \varepsilon - -1}\right)\right)
\] |
pow2 [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\left(-\color{blue}{{\sin \varepsilon}^{2}}\right) \cdot \frac{1}{\cos \varepsilon - -1}\right)\right)
\] |
sub-neg [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\left(-{\sin \varepsilon}^{2}\right) \cdot \frac{1}{\color{blue}{\cos \varepsilon + \left(--1\right)}}\right)\right)
\] |
metadata-eval [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\left(-{\sin \varepsilon}^{2}\right) \cdot \frac{1}{\cos \varepsilon + \color{blue}{1}}\right)\right)
\] |
Simplified99.6%
[Start]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(\left(-{\sin \varepsilon}^{2}\right) \cdot \frac{1}{\cos \varepsilon + 1}\right)\right)
\] |
|---|---|
associate-*r/ [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \color{blue}{\frac{\left(-{\sin \varepsilon}^{2}\right) \cdot 1}{\cos \varepsilon + 1}}\right)
\] |
*-rgt-identity [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \frac{\color{blue}{-{\sin \varepsilon}^{2}}}{\cos \varepsilon + 1}\right)
\] |
distribute-frac-neg [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \color{blue}{\left(-\frac{{\sin \varepsilon}^{2}}{\cos \varepsilon + 1}\right)}\right)
\] |
unpow2 [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(-\frac{\color{blue}{\sin \varepsilon \cdot \sin \varepsilon}}{\cos \varepsilon + 1}\right)\right)
\] |
associate-/l* [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(-\color{blue}{\frac{\sin \varepsilon}{\frac{\cos \varepsilon + 1}{\sin \varepsilon}}}\right)\right)
\] |
associate-/r/ [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(-\color{blue}{\frac{\sin \varepsilon}{\cos \varepsilon + 1} \cdot \sin \varepsilon}\right)\right)
\] |
+-commutative [=>]99.1 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(-\frac{\sin \varepsilon}{\color{blue}{1 + \cos \varepsilon}} \cdot \sin \varepsilon\right)\right)
\] |
hang-0p-tan [=>]99.6 | \[ \mathsf{fma}\left(-\sin x, \sin \varepsilon, \cos x \cdot \left(-\color{blue}{\tan \left(\frac{\varepsilon}{2}\right)} \cdot \sin \varepsilon\right)\right)
\] |
Final simplification99.6%
| Alternative 1 | |
|---|---|
| Accuracy | 99.2% |
| Cost | 39176 |
| Alternative 2 | |
|---|---|
| Accuracy | 99.2% |
| Cost | 32777 |
| Alternative 3 | |
|---|---|
| Accuracy | 99.2% |
| Cost | 32777 |
| Alternative 4 | |
|---|---|
| Accuracy | 99.2% |
| Cost | 26441 |
| Alternative 5 | |
|---|---|
| Accuracy | 76.3% |
| Cost | 13769 |
| Alternative 6 | |
|---|---|
| Accuracy | 76.3% |
| Cost | 13641 |
| Alternative 7 | |
|---|---|
| Accuracy | 75.7% |
| Cost | 13632 |
| Alternative 8 | |
|---|---|
| Accuracy | 76.1% |
| Cost | 13257 |
| Alternative 9 | |
|---|---|
| Accuracy | 75.4% |
| Cost | 7113 |
| Alternative 10 | |
|---|---|
| Accuracy | 65.9% |
| Cost | 7052 |
| Alternative 11 | |
|---|---|
| Accuracy | 52.4% |
| Cost | 6857 |
| Alternative 12 | |
|---|---|
| Accuracy | 23.9% |
| Cost | 585 |
| Alternative 13 | |
|---|---|
| Accuracy | 25.9% |
| Cost | 576 |
| Alternative 14 | |
|---|---|
| Accuracy | 25.9% |
| Cost | 448 |
| Alternative 15 | |
|---|---|
| Accuracy | 17.3% |
| Cost | 256 |
herbie shell --seed 2023157
(FPCore (x eps)
:name "2cos (problem 3.3.5)"
:precision binary64
(- (cos (+ x eps)) (cos x)))