|
| TridiagInvD () |
| Allocate nothing, Call construct method before usage.
|
|
| TridiagInvD (const thrust::host_vector< real_type > ©able) |
| Construct from vector.
|
|
| TridiagInvD (unsigned size) |
| Construct from size of vector.
|
|
void | resize (unsigned new_size) |
| Resize inverse tridiagonal matrix and helper vectors.
|
|
void | operator() (const dg::TriDiagonal< thrust::host_vector< real_type > > &T, dg::SquareMatrix< real_type > &Tinv) |
| Compute the inverse of a tridiagonal matrix T.
|
|
dg::SquareMatrix< real_type > | operator() (const dg::TriDiagonal< thrust::host_vector< real_type > > &T) |
| Compute the inverse of a tridiagonal matrix T.
|
|
template<class ContainerType0 , class ContainerType1 , class ContainerType2 > |
void | operator() (const ContainerType0 &a, const ContainerType1 &b, const ContainerType2 &c, dg::SquareMatrix< real_type > &Tinv) |
| Compute the inverse of a tridiagonal matrix with diagonal vectors a,b,c.
|
|
template<class real_type>
class dg::mat::TridiagInvD< real_type >
Compute the inverse of a general tridiagonal matrix.
- Attention
- If roughly the matrix size m>150 the algorithm is unstable. However, it performs extremely fast if it stays below this value. This is the algorihm of "Inversion of a Tridiagonal Jacobi Matrix" by Riaz A. Usmani
- Template Parameters
-
template<class real_type >
template<class ContainerType0 , class ContainerType1 , class ContainerType2 >
Compute the inverse of a tridiagonal matrix with diagonal vectors a,b,c.
The diagonal vectors are given as in the dg::TriDiagonal
matrix format
- Parameters
-
a | "0" diagonal vector (index 0 is on row 0, O in dg::TriDiagonal ) |
b | "+1" diagonal vector (index 0 is on row 0, last index outside, P in dg::TriDiagonal ) |
c | "-1" diagonal vector (index 0 is on row 0, outside of matrix, M in dg::TriDiagonal ) |
Tinv | the inverse of the tridiagonal matrix (coordinate format) gets resized if necessary |