12#ifndef TLAPACK_UNG2L_HH
13#define TLAPACK_UNG2L_HH
32template <
class T, TLAPACK_SMATRIX matrix_t, TLAPACK_VECTOR vector_t>
39 const idx_t n = ncols(
A);
42 auto&&
C = cols(
A,
range{1, n});
44 col(
A, 0),
tau[0],
C);
103template <TLAPACK_SMATRIX matrix_t, TLAPACK_VECTOR vector_t>
113 const idx_t n = ncols(
A);
116 if (n <= 0)
return 0;
120 std::vector<T>
work_;
constexpr internal::Backward BACKWARD
Backward direction.
Definition types.hpp:383
constexpr internal::ColumnwiseStorage COLUMNWISE_STORAGE
Columnwise storage.
Definition types.hpp:414
constexpr internal::LeftSide LEFT_SIDE
left side
Definition types.hpp:294
#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
int ung2l(matrix_t &A, const vector_t &tau)
Generates an m-by-n matrix Q with orthonormal columns, which is defined as the last n columns of a pr...
Definition ung2l.hpp:104
int ung2l_work(matrix_t &A, const vector_t &tau, work_t &work)
Generates an m-by-n matrix Q with orthonormal columns, which is defined as the last n columns of a pr...
Definition ung2l.hpp:76
int ungq_level2_work(direction_t direction, storage_t storeMode, matrix_t &A, const vector_t &tau, work_t &work)
Generates a matrix Q that is the product of elementary reflectors. Workspace is provided as an argu...
Definition ungq_level2.hpp:90
constexpr WorkInfo ung2l_worksize(const matrix_t &A, const vector_t &tau)
Worspace query of ung2l()
Definition ung2l.hpp:33
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
Output information in the workspace query.
Definition workspace.hpp:16