imate
C++/CUDA Reference
|
#include <c_dense_affine_matrix_function.h>
Public Member Functions | |
cDenseAffineMatrixFunction (const DataType *A_, const FlagType A_is_row_major_, const LongIndexType num_rows_, const LongIndexType num_colums_) | |
Constructor. Matrix B is assumed to be the identity matrix. More... | |
cDenseAffineMatrixFunction (const DataType *A_, const FlagType A_is_row_major_, const LongIndexType num_rows_, const LongIndexType num_columns_, const DataType *B_, const FlagType B_is_row_major_) | |
virtual | ~cDenseAffineMatrixFunction () |
virtual void | dot (const DataType *vector, DataType *product) |
Computes the matrix vector product: More... | |
virtual void | transpose_dot (const DataType *vector, DataType *product) |
Computes the matrix vector product: More... | |
Public Member Functions inherited from cAffineMatrixFunction< DataType > | |
cAffineMatrixFunction (const LongIndexType num_rows_, const LongIndexType num_columns_) | |
Constructor. More... | |
virtual | ~cAffineMatrixFunction () |
Virtual destructor. More... | |
void | set_parameters (DataType *t) |
DataType | get_eigenvalue (const DataType *known_parameters, const DataType known_eigenvalue, const DataType *inquiry_parameters) const |
This function defines an analytic relationship between a given set of parameters and the corresponding eigenvalue of the operator. Namely, given a set of parameters and a known eigenvalue of the operator for that specific set of parameters, this function obtains the eigenvalue of the operator for an other given set of parameters. More... | |
Public Member Functions inherited from cLinearOperator< DataType > | |
cLinearOperator () | |
Default constructor. More... | |
cLinearOperator (const LongIndexType num_rows_, const LongIndexType num_columns_) | |
Constructor with setting num_rows and num_columns . More... | |
virtual | ~cLinearOperator () |
LongIndexType | get_num_rows () const |
LongIndexType | get_num_columns () const |
void | set_parameters (DataType *parameters_) |
Sets the scalar parameter this->parameters . Parameter is initialized to NULL . However, before calling dot or transpose_dot functions, the parameters must be set. More... | |
IndexType | get_num_parameters () const |
FlagType | is_eigenvalue_relation_known () const |
Returns a flag that determines whether a relation between the parameters of the operator and its eigenvalue(s) is known. More... | |
Protected Attributes | |
cDenseMatrix< DataType > | A |
cDenseMatrix< DataType > | B |
Protected Attributes inherited from cAffineMatrixFunction< DataType > | |
bool | B_is_identity |
Protected Attributes inherited from cLinearOperator< DataType > | |
const LongIndexType | num_rows |
const LongIndexType | num_columns |
FlagType | eigenvalue_relation_known |
DataType * | parameters |
IndexType | num_parameters |
Additional Inherited Members | |
Protected Member Functions inherited from cAffineMatrixFunction< DataType > | |
void | _add_scaled_vector (const DataType *input_vector, const LongIndexType vector_size, const DataType scale, DataType *output_vector) const |
Performs the operation \( \boldsymbol{c} = \boldsymbol{c} + \alpha * \boldsymbol{b} \), where \( \boldsymbol{b} \) is an input vector scaled by \( \alpha \) and \( \boldsymbol{c} \) it the output vector. More... | |
Definition at line 30 of file c_dense_affine_matrix_function.h.
cDenseAffineMatrixFunction< DataType >::cDenseAffineMatrixFunction | ( | const DataType * | A_, |
const FlagType | A_is_row_major_, | ||
const LongIndexType | num_rows_, | ||
const LongIndexType | num_colums_ | ||
) |
Constructor. Matrix B
is assumed to be the identity matrix.
Definition at line 29 of file c_dense_affine_matrix_function.cpp.
References cAffineMatrixFunction< DataType >::B_is_identity, and cLinearOperator< DataType >::eigenvalue_relation_known.
cDenseAffineMatrixFunction< DataType >::cDenseAffineMatrixFunction | ( | const DataType * | A_, |
const FlagType | A_is_row_major_, | ||
const LongIndexType | num_rows_, | ||
const LongIndexType | num_columns_, | ||
const DataType * | B_, | ||
const FlagType | B_is_row_major_ | ||
) |
Definition at line 54 of file c_dense_affine_matrix_function.cpp.
References cDenseAffineMatrixFunction< DataType >::B, cAffineMatrixFunction< DataType >::B_is_identity, and cLinearOperator< DataType >::eigenvalue_relation_known.
|
virtual |
Definition at line 83 of file c_dense_affine_matrix_function.cpp.
|
virtual |
Computes the matrix vector product:
\[ \boldsymbol{c} = (\mathbf{A} + t \mathbf{B}) \boldsymbol{b}. \]
[in] | vector | The input vector :math:\\boldsymbol{b} is given by vector . If \( \mathbf{A} \) and \( \mathbf{B} \) are \( m \times n \) matrices, the length of input c vector is n . |
[out] | product | The output of the product, \( \boldsymbol{c} \), is written in-place into this array. Let m be the number of rows of \( \mathbf{A} \) and \( \mathbf{B} \), then, the output vector product is 1D column array of length m . |
Implements cLinearOperator< DataType >.
Definition at line 109 of file c_dense_affine_matrix_function.cpp.
|
virtual |
Computes the matrix vector product:
\[ \boldsymbol{c} = (\mathbf{A} + t \mathbf{B})^{\intercal} \boldsymbol{b}. \]
[in] | vector | The input vector \( \boldsymbol{b} \) is given by vector . If \( \mathbf{A} \) and \( \mathbf{B} \) are \( m \times n \) matrices, the length of input vector is n . |
[out] | product | The output of the product, \( \boldsymbol{c} \), is written in-place into this array. Let n be the number of columns of \( \mathbf{A} \) and \( \mathbf{B} \), then, the output vector product is 1D column array of length m . |
Implements cLinearOperator< DataType >.
Definition at line 165 of file c_dense_affine_matrix_function.cpp.
|
protected |
Definition at line 62 of file c_dense_affine_matrix_function.h.
|
protected |
Definition at line 63 of file c_dense_affine_matrix_function.h.
Referenced by cDenseAffineMatrixFunction< DataType >::cDenseAffineMatrixFunction().