Public Types |
typedef NumTraits< Scalar >::Real | RealScalar |
Public Member Functions |
JacobiRotation | adjoint () const |
Scalar & | c () |
Scalar | c () const |
| JacobiRotation () |
| JacobiRotation (const Scalar &c, const Scalar &s) |
void | makeGivens (const Scalar &p, const Scalar &q, Scalar *z=0) |
template<typename Derived > |
bool | makeJacobi (const MatrixBase< Derived > &, typename Derived::Index p, typename Derived::Index q) |
bool | makeJacobi (RealScalar x, Scalar y, RealScalar z) |
JacobiRotation | operator* (const JacobiRotation &other) |
Scalar & | s () |
Scalar | s () const |
JacobiRotation | transpose () const |
Protected Member Functions |
void | makeGivens (const Scalar &p, const Scalar &q, Scalar *z, internal::true_type) |
void | makeGivens (const Scalar &p, const Scalar &q, Scalar *z, internal::false_type) |
Protected Attributes |
Scalar | m_c |
Scalar | m_s |
template<typename Scalar>
class JacobiRotation< Scalar >
Rotation given by a cosine-sine pair.
This class represents a Jacobi or Givens rotation. This is a 2D rotation in the plane J
of angle defined by its cosine c
and sine s
as follow:
You can apply the respective counter-clockwise rotation to a column vector v
by applying its adjoint on the left: that translates to the following Eigen code:
v.applyOnTheLeft(J.adjoint());
- See also:
- MatrixBase::applyOnTheLeft(), MatrixBase::applyOnTheRight()
Definition at line 47 of file Jacobi.h.
template<typename Scalar >
Makes *this
as a Givens rotation G
such that applying to the left of the vector yields: .
The value of z is returned if z is not null (the default is null). Also note that G is built such that the cosine is always real.
Example:
Vector2f v = Vector2f::Random();
JacobiRotation<float> G;
G.makeGivens(v.x(), v.y());
cout << "Here is the vector v:" << endl << v << endl;
v.applyOnTheLeft(0, 1, G.adjoint());
cout << "Here is the vector J' * v:" << endl << v << endl;
Output:
This function implements the continuous Givens rotation generation algorithm found in Anderson (2000), Discontinuous Plane Rotations and the Symmetric Eigenvalue Problem. LAPACK Working Note 150, University of Tennessee, UT-CS-00-454, December 4, 2000.
- See also:
- MatrixBase::applyOnTheLeft(), MatrixBase::applyOnTheRight()
Definition at line 158 of file Jacobi.h.