Name
HPL_dtrsm B := A^{-1} * B or B := B * A^{-1}.
Synopsis
#include <hpl.h>
void
HPL_dtrsm(
const enum HPL_ORDER
ORDER
,
const enum HPL_SIDE
SIDE
,
const enum HPL_UPLO
UPLO
,
const enum HPL_TRANS
TRANS
,
const enum HPL_DIAG
DIAG
,
const int
M
,
const int
N
,
const double
ALPHA
,
const double *
A
,
const int
LDA
,
double *
B
,
const int
LDB
);
Description
HPL_dtrsm
solves one of the matrix equations
op( A ) * X = alpha * B, or X * op( A ) = alpha * B,
where alpha is a scalar, X and B are m by n matrices, A is a unit, or
non-unit, upper or lower triangular matrix and op(A) is one of
op( A ) = A or op( A ) = A^T.
The matrix X is overwritten on B.
No test for singularity or near-singularity is included in this
routine. Such tests must be performed before calling this routine.
Arguments
ORDER (local input) const enum HPL_ORDER
On entry, ORDER specifies the storage format of the operands
as follows:
ORDER = HplRowMajor,
ORDER = HplColumnMajor.
SIDE (local input) const enum HPL_SIDE
On entry, SIDE specifies whether op(A) appears on the left
or right of X as follows:
SIDE==HplLeft op( A ) * X = alpha * B,
SIDE==HplRight X * op( A ) = alpha * B.
UPLO (local input) const enum HPL_UPLO
On entry, UPLO specifies whether the upper or lower
triangular part of the array A is to be referenced. When
UPLO==HplUpper, only the upper triangular part of A is to be
referenced, otherwise only the lower triangular part of A is
to be referenced.
TRANS (local input) const enum HPL_TRANS
On entry, TRANSA specifies the form of op(A) to be used in
the matrix-matrix operation follows:
TRANSA==HplNoTrans : op( A ) = A,
TRANSA==HplTrans : op( A ) = A^T,
TRANSA==HplConjTrans : op( A ) = A^T.
DIAG (local input) const enum HPL_DIAG
On entry, DIAG specifies whether A is unit triangular or
not. When DIAG==HplUnit, A is assumed to be unit triangular,
and otherwise, A is not assumed to be unit triangular.
M (local input) const int
On entry, M specifies the number of rows of the matrix B.
M must be at least zero.
N (local input) const int
On entry, N specifies the number of columns of the matrix B.
N must be at least zero.
ALPHA (local input) const double
On entry, ALPHA specifies the scalar alpha. When ALPHA is
supplied as zero then the elements of the matrix B need not
be set on input.
A (local input) const double *
On entry, A points to an array of size equal to or greater
than LDA * k, where k is m when SIDE==HplLeft and is n
otherwise. Before entry with UPLO==HplUpper, the leading
k by k upper triangular part of the array A must contain the
upper triangular matrix and the strictly lower triangular
part of A is not referenced. When UPLO==HplLower on entry,
the leading k by k lower triangular part of the array A must
contain the lower triangular matrix and the strictly upper
triangular part of A is not referenced.
Note that when DIAG==HplUnit, the diagonal elements of A
not referenced either, but are assumed to be unity.
LDA (local input) const int
On entry, LDA specifies the leading dimension of A as
declared in the calling (sub) program. LDA must be at
least MAX(1,m) when SIDE==HplLeft, and MAX(1,n) otherwise.
B (local input/output) double *
On entry, B points to an array of size equal to or greater
than LDB * n. Before entry, the leading m by n part of the
array B must contain the matrix B, except when beta is zero,
in which case B need not be set on entry. On exit, the array
B is overwritten by the m by n solution matrix.
LDB (local input) const int
On entry, LDB specifies the leading dimension of B as
declared in the calling (sub) program. LDB must be at
least MAX(1,m).
Example
#include <hpl.h>
int main(int argc, char *argv[])
{
double a[2*2], b[2*2];
a[0] = 4.0; a[1] = 1.0; a[2] = 2.0; a[3] = 5.0;
b[0] = 2.0; b[1] = 1.0; b[2] = 1.0; b[3] = 2.0;
HPL_dtrsm( HplColumnMajor, HplLeft, HplUpper,
HplNoTrans, HplNonUnit, 2, 2, 2.0,
a, 2, b, 2 );
printf("b=[%f,%f]", b[0], b[2]);
printf(" [%f,%f]", b[1], b[3]);
exit(0);
return(0);
}
See Also
HPL_dgemm