There is one prototype of tbmv
available, please see below.
tbmv( const int_t k, const MatrixA& a, VectorX& x );
tbmv (short for triangular,
banded, matrix-vector operation) provides a C++ interface to BLAS routines
STBMV, DTBMV, CTBMV, and ZTBMV. tbmv
performs one of the matrix-vector operations
x := A*x, or x := A'*x, or x := conjg( A' )*x,
where x is an n element vector and A is an n by n unit, or non-unit, upper or lower triangular band matrix, with ( k + 1 ) diagonals.
The selection of the BLAS routine is done during compile-time, and is
determined by the type of values contained in type MatrixA.
The type of values is obtained through the value_type
meta-function typename value_type<MatrixA>::type. Table X below illustrates to
which specific routine this dispatching will take place.
Table 1.70. Dispatching of tbmv.
|
Value type of MatrixA |
BLAS routine |
CBLAS routine |
CUBLAS routine |
|---|---|---|---|
|
|
STBMV |
cblas_stbmv |
cublasStbmv |
|
|
DTBMV |
cblas_dtbmv |
Unavailable |
|
|
CTBMV |
cblas_ctbmv |
cublasCtbmv |
|
|
ZTBMV |
cblas_ztbmv |
Unavailable |
The original routines STBMV, DTBMV, CTBMV, and ZTBMV have nine arguments,
whereas tbmv requires
three arguments.
Defined in header boost/numeric/bindings/blas/level2/tbmv.hpp.
Parameters
The definition of term 1
The definition of term 2
The definition of term 3.
Definitions may contain paragraphs.
#include <boost/numeric/bindings/blas/level2/tbmv.hpp> using namespace boost::numeric::bindings; blas::tbmv( x, y, z );
this will output
[5] 0 1 2 3 4 5