-
Notifications
You must be signed in to change notification settings - Fork 10
Trigonometry
In the trigonometric solvers module, we provide support for computing the sine and cosine of matrices.
The basis of these methods is to expand the cosine function on a set of Chebyshev polynomials, and use that to compute the matrix function. Using the base cosine function, it is of course possible to also compute the sine function, using the identity:
![sin(x) = cos(x - frac{pi}{2})](http://mathurl.com/yb5xtj9e.png)
One difficulty of this approach is that the spectrum of the input matrix not necessarily contained in the range [-1, 1]. This can be addressed using the double angle formula:
![cos(2x) = 2cos(x)^2 - 1](http://mathurl.com/yd5os5rh)
The cosine function is an even function, which allows for further savings when expanding the matrix using Chebyshev polynomials.
It's appropriate to cite the following two articles for the basic double angle method:
- @article{higham2003computing,
- title={Computing the matrix cosine}, author={Higham, Nicholas J and Smith, Matthew I}, journal={Numerical Algorithms}, volume={34}, number={1}, pages={13--26}, year={2003}, publisher={Springer}
}
The following article was the inspiration for the particular factorization utilized:
- @article{yau1993reducing,
- title={Reducing the symmetric matrix eigenvalue problem to matrix multiplications}, author={Yau, Shing-Tung and Lu, Ya Yan}, journal={SIAM Journal on Scientific Computing}, volume={14}, number={1}, pages={121--136}, year={1993}, publisher={SIAM}
}