53 template <
class T, TLAPACK_SMATRIX matrix_t>
63 const idx_t n = ncols(
A);
64 const idx_t
nw_max = (n - 3) / 3;
118 enable_if_t<is_complex<type_t<vector_t>>,
int>>
134 const idx_t n = ncols(
A);
135 const idx_t
nw_max = (n - 3) / 3;
142 if (
jw >= (idx_t)
opts.nmin) {
150 workinfo.minMax(internal::aggressive_early_deflation_worksize_gehrd<T>(
167 enable_if_t<is_complex<type_t<vector_t>>,
int>>
189 const idx_t n = ncols(
A);
192 const idx_t
nw_max = (n - 3) / 3;
247 for (idx_t j = 0; j <
jw; ++j)
248 for (idx_t i = 0; i < min(j + 2,
jw); ++i)
252 if (
jw < (idx_t)
opts.nmin)
257 for (idx_t j = 0; j <
jw; ++j)
258 for (idx_t i = j + 2; i <
jw; ++i)
296 sqrt(abs(
TW(
ns - 1,
ns - 2))) * sqrt(abs(
TW(
ns - 2,
ns - 1)));
408 for (idx_t i = 0; i <
ns; ++i) {
440 for (idx_t j = 0; j <
jw; ++j)
441 for (idx_t i = 0; i < min(j + 2,
jw); ++i)
490 idx_t
iblock = std::min<idx_t>(n - i, nrows(
WV));
518 enable_if_t<is_complex<type_t<vector_t>>,
int> = 0>
521 size_type<matrix_t> ilo,
522 size_type<matrix_t> ihi,
523 size_type<matrix_t> nw,
527 size_type<matrix_t>& ns,
528 size_type<matrix_t>& nd,
531 FrancisOpts opts = {};
595 enable_if_t<is_complex<type_t<vector_t>>,
int> = 0>
617 const idx_t n = ncols(
A);
620 const idx_t
nw_max = (n - 3) / 3;
651 want_t,
want_z,
ilo,
ihi,
nw,
A,
s,
Z,
ns,
nd,
opts);
652 std::vector<T>
work_;
674 enable_if_t<is_complex<type_t<vector_t>>,
int> = 0>
677 size_type<matrix_t> ilo,
678 size_type<matrix_t> ihi,
679 size_type<matrix_t> nw,
683 size_type<matrix_t>& ns,
684 size_type<matrix_t>& nd)
686 FrancisOpts opts = {};
687 aggressive_early_deflation(want_t, want_z, ilo, ihi, nw, A, s, Z, ns, nd,
constexpr internal::LowerTriangle LOWER_TRIANGLE
Lower Triangle access.
Definition types.hpp:188
constexpr internal::RightSide RIGHT_SIDE
right side
Definition types.hpp:296
constexpr internal::Forward FORWARD
Forward direction.
Definition types.hpp:381
constexpr internal::GeneralAccess GENERAL
General access.
Definition types.hpp:180
constexpr internal::ConjTranspose CONJ_TRANS
conjugate transpose
Definition types.hpp:264
constexpr internal::ColumnwiseStorage COLUMNWISE_STORAGE
Columnwise storage.
Definition types.hpp:414
constexpr internal::NoTranspose NO_TRANS
no transpose
Definition types.hpp:260
constexpr internal::LeftSide LEFT_SIDE
left side
Definition types.hpp:294
constexpr T conj(const T &x) noexcept
Extends std::conj() to real datatypes.
Definition utils.hpp:100
constexpr real_type< T > abs1(const T &x)
1-norm absolute value, |Re(x)| + |Im(x)|
Definition utils.hpp:133
#define TLAPACK_SVECTOR
Macro for tlapack::concepts::SliceableVector compatible with C++17.
Definition concepts.hpp:909
#define TLAPACK_SMATRIX
Macro for tlapack::concepts::SliceableMatrix compatible with C++17.
Definition concepts.hpp:899
#define TLAPACK_WORKSPACE
Macro for tlapack::concepts::Workspace compatible with C++17.
Definition concepts.hpp:912
#define TLAPACK_VECTOR
Macro for tlapack::concepts::Vector compatible with C++17.
Definition concepts.hpp:906
#define TLAPACK_MATRIX
Macro for tlapack::concepts::Matrix compatible with C++17.
Definition concepts.hpp:896
void aggressive_early_deflation(bool want_t, bool want_z, size_type< matrix_t > ilo, size_type< matrix_t > ihi, size_type< matrix_t > nw, matrix_t &A, vector_t &s, matrix_t &Z, size_type< matrix_t > &ns, size_type< matrix_t > &nd, FrancisOpts &opts)
aggressive_early_deflation accepts as input an upper Hessenberg matrix H and performs an orthogonal s...
Definition aggressive_early_deflation.hpp:596
void lahqr_eig22(T a00, T a01, T a10, T a11, complex_type< T > &s1, complex_type< T > &s2)
Computes the eigenvalues of a 2x2 matrix A.
Definition lahqr_eig22.hpp:34
void laset(uplo_t uplo, const type_t< matrix_t > &alpha, const type_t< matrix_t > &beta, matrix_t &A)
Initializes a matrix to diagonal and off-diagonal values.
Definition laset.hpp:38
int lahqr(bool want_t, bool want_z, size_type< matrix_t > ilo, size_type< matrix_t > ihi, matrix_t &A, vector_t &w, matrix_t &Z)
lahqr computes the eigenvalues and optionally the Schur factorization of an upper Hessenberg matrix,...
Definition lahqr.hpp:73
int schur_swap(bool want_q, matrix_t &A, matrix_t &Q, const size_type< matrix_t > &j0, const size_type< matrix_t > &n1, const size_type< matrix_t > &n2)
schur_swap, swaps 2 eigenvalues of A.
Definition schur_swap.hpp:49
void larfg(storage_t storeMode, type_t< vector_t > &alpha, vector_t &x, type_t< vector_t > &tau)
Generates a elementary Householder reflection.
Definition larfg.hpp:73
int schur_move(bool want_q, matrix_t &A, matrix_t &Q, size_type< matrix_t > &ifst, size_type< matrix_t > &ilst)
schur_move reorders the Schur factorization of a matrix S = Q*A*Q**H, so that the diagonal element of...
Definition schur_move.hpp:47
void lacpy(uplo_t uplo, const matrixA_t &A, matrixB_t &B)
Copies a matrix from A to B.
Definition lacpy.hpp:38
void larf_work(side_t side, storage_t storeMode, vector_t const &x, const tau_t &tau, vectorC0_t &C0, matrixC1_t &C1, work_t &work)
Applies an elementary reflector defined by tau and v to a m-by-n matrix C decomposed into C0 and C1....
Definition larf.hpp:48
void gemm(Op transA, Op transB, const alpha_t &alpha, const matrixA_t &A, const matrixB_t &B, const beta_t &beta, matrixC_t &C)
General matrix-matrix multiply:
Definition gemm.hpp:61
int gehrd_work(size_type< matrix_t > ilo, size_type< matrix_t > ihi, matrix_t &A, vector_t &tau, work_t &work, const GehrdOpts &opts={})
Reduces a general square matrix to upper Hessenberg form. Workspace is provided as an argument.
Definition gehrd.hpp:99
void aggressive_early_deflation_work(bool want_t, bool want_z, size_type< matrix_t > ilo, size_type< matrix_t > ihi, size_type< matrix_t > nw, matrix_t &A, vector_t &s, matrix_t &Z, size_type< matrix_t > &ns, size_type< matrix_t > &nd, work_t &work, FrancisOpts &opts)
aggressive_early_deflation accepts as input an upper Hessenberg matrix H and performs an orthogonal s...
Definition aggressive_early_deflation.hpp:168
int multishift_qr_work(bool want_t, bool want_z, size_type< matrix_t > ilo, size_type< matrix_t > ihi, matrix_t &A, vector_t &w, matrix_t &Z, work_t &work, FrancisOpts &opts)
multishift_qr computes the eigenvalues and optionally the Schur factorization of an upper Hessenberg ...
Definition multishift_qr.hpp:114
int unmhr_work(Side side, Op trans, size_type< matrix_t > ilo, size_type< matrix_t > ihi, const matrix_t &A, const vector_t &tau, matrix_t &C, work_t &work)
Applies unitary matrix Q to a matrix C. Workspace is provided as an argument.
Definition unmhr.hpp:83
#define tlapack_check(cond)
Throw an error if cond is false.
Definition exceptionHandling.hpp:98
constexpr WorkInfo aggressive_early_deflation_worksize_gehrd(size_type< matrix_t > ilo, size_type< matrix_t > ihi, size_type< matrix_t > nw, const matrix_t &A)
Workspace query for gehrd() in aggressive_early_deflation().
Definition aggressive_early_deflation.hpp:54
WorkInfo aggressive_early_deflation_worksize(bool want_t, bool want_z, size_type< matrix_t > ilo, size_type< matrix_t > ihi, size_type< matrix_t > nw, const matrix_t &A, const vector_t &s, const matrix_t &Z, const size_type< matrix_t > &ns, const size_type< matrix_t > &nd, const FrancisOpts &opts)
Worspace query of aggressive_early_deflation().
Definition aggressive_early_deflation.hpp:119
typename traits::real_type_traits< Types..., int >::type real_type
The common real type of the list of types.
Definition scalar_type_traits.hpp:113
Options struct for multishift_qr().
Definition FrancisOpts.hpp:23
Output information in the workspace query.
Definition workspace.hpp:16