xerus
a general purpose tensor library
|
Implementation of the blas and lapack wrapper functions. More...
#include <complex.h>
#include <cblas.h>
#include <lapacke.h>
#include <memory>
#include <xerus/misc/standard.h>
#include <xerus/misc/performanceAnalysis.h>
#include <xerus/misc/check.h>
#include <xerus/misc/stringUtilities.h>
#include <xerus/basic.h>
#include <xerus/blasLapackWrapper.h>
#include <xerus/misc/basicArraySupport.h>
#include <xerus/misc/math.h>
#include <xerus/misc/internal.h>
Go to the source code of this file.
Namespaces | |
xerus | |
The main namespace of xerus. | |
xerus::blasWrapper | |
In this namespace the minimal wrappers for the BLAS and LAPACK functions are collected. | |
Macros | |
#define | lapack_complex_double double _Complex |
#define | lapack_complex_float float _Complex |
Functions | |
std::tuple< std::unique_ptr< double[]>, std::unique_ptr< double[]>, size_t > | xerus::blasWrapper::cq (const double *const _A, const size_t _m, const size_t _n) |
: splits A = C*Q, with _C an rxm matrix (where r is the rank of _A) and _Q orthogonal. More... | |
std::tuple< std::unique_ptr< double[]>, std::unique_ptr< double[]>, size_t > | xerus::blasWrapper::cq_destructive (double *const _A, const size_t _m, const size_t _n) |
: splits A = C*Q, with _C an rxm matrix (where r is the rank of _A) and _Q orthogonal. Destroys A. More... | |
double | xerus::blasWrapper::dot_product (const double *const _x, const size_t _n, const double *const _y) |
: Computes the dot product = x^T*y More... | |
void | xerus::blasWrapper::dyadic_vector_product (double *_A, const size_t _m, const size_t _n, const double _alpha, const double *const _x, const double *const _y) |
: Performs A = alpha*x*y^T More... | |
void | xerus::blasWrapper::inplace_qr (double *const _AtoQ, double *const _R, const size_t _m, const size_t _n) |
: Performs (AtoQ,R) = QR(AtoQ) More... | |
void | xerus::blasWrapper::inplace_rq (double *const _R, double *const _AtoQ, const size_t _m, const size_t _n) |
: Performs (R,AtoQ) = RQ(AtoQ) More... | |
static bool | xerus::blasWrapper::is_symmetric (const double *const _A, const size_t _n) |
void | xerus::blasWrapper::matrix_matrix_product (double *const _C, const size_t _leftDim, const size_t _rightDim, const double _alpha, const double *const _A, const size_t _lda, const bool _transposeA, const size_t _middleDim, const double *const _B, const size_t _ldb, const bool _transposeB) |
: Performs the Matrix-Matrix product C = alpha*OP(A) * OP(B) More... | |
void | xerus::blasWrapper::matrix_vector_product (double *const _x, const size_t _m, const double _alpha, const double *const _A, const size_t _n, const bool _transposed, const double *const _y) |
: Perfroms x = alpha*OP(A)*y More... | |
double | xerus::blasWrapper::one_norm (const double *const _x, const size_t _n) |
: Computes the one norm =||x||_1 More... | |
static bool | xerus::blasWrapper::pos_neg_definite_diagonal (const double *const _A, const size_t _n) |
checks whether the diagonal of _A is all positive or all negative. returns false otherwise More... | |
std::tuple< std::unique_ptr< double[]>, std::unique_ptr< double[]>, size_t > | xerus::blasWrapper::qc (const double *const _A, const size_t _m, const size_t _n) |
: splits A = Q*C, with _C an rxn matrix (where r is the rank of _A) and _Q orthogonal. More... | |
std::tuple< std::unique_ptr< double[]>, std::unique_ptr< double[]>, size_t > | xerus::blasWrapper::qc_destructive (double *const _A, const size_t _m, const size_t _n) |
: splits A = Q*C, with _C an rxn matrix (where r is the rank of _A) and _Q orthogonal. Destroys A. More... | |
void | xerus::blasWrapper::qr (double *const _Q, double *const _R, const double *const _A, const size_t _m, const size_t _n) |
: Performs (Q,R) = QR(A) More... | |
void | xerus::blasWrapper::qr_destructive (double *const _Q, double *const _R, double *const _A, const size_t _m, const size_t _n) |
: Performs (Q,R) = QR(A), destroys A in the process More... | |
void | xerus::blasWrapper::rq (double *const _R, double *const _Q, const double *const _A, const size_t _m, const size_t _n) |
: Performs (R,Q) = RQ(A) More... | |
void | xerus::blasWrapper::rq_destructive (double *const _R, double *const _Q, double *const _A, const size_t _m, const size_t _n) |
: Performs (R,Q) = RQ(A), destroys A in the process More... | |
void | xerus::blasWrapper::solve (double *_x, const double *_A, size_t _m, size_t _n, const double *_b, size_t _p) |
: Solves Ax = b for x More... | |
void | xerus::blasWrapper::solve_least_squares (double *const _x, const double *const _A, const size_t _m, const size_t _n, const double *const _b, const size_t _p) |
: Solves min ||Ax - b||_2 for x More... | |
void | xerus::blasWrapper::solve_least_squares_destructive (double *const _x, double *const _A, const size_t _m, const size_t _n, double *const _b, const size_t _p) |
: Solves min ||Ax - b||_2 for x More... | |
void | xerus::blasWrapper::svd (double *const _U, double *const _S, double *const _Vt, const double *const _A, const size_t _m, const size_t _n) |
: Performs (U,S,V) = SVD(A) More... | |
void | xerus::blasWrapper::svd_destructive (double *const _U, double *const _S, double *const _Vt, double *const _A, const size_t _m, const size_t _n) |
: Performs (U,S,V) = SVD(A). Destroys A. More... | |
double | xerus::blasWrapper::two_norm (const double *const _x, const size_t _n) |
: Computes the two norm =||x||_2 More... | |
Implementation of the blas and lapack wrapper functions.
Definition in file blasLapackWrapper.cpp.
#define lapack_complex_double double _Complex |
Definition at line 32 of file blasLapackWrapper.cpp.
#define lapack_complex_float float _Complex |
Definition at line 31 of file blasLapackWrapper.cpp.