MFEM v4.7.0
Finite element discretization library
Loading...
Searching...
No Matches
mfem::MatrixCoefficient Class Referenceabstract

Base class for Matrix Coefficients that optionally depend on time and space. More...

#include <coefficient.hpp>

Inheritance diagram for mfem::MatrixCoefficient:
[legend]

Public Member Functions

 MatrixCoefficient (int dim, bool symm=false)
 Construct a dim x dim matrix coefficient.
 
 MatrixCoefficient (int h, int w, bool symm=false)
 Construct a h x w matrix coefficient.
 
virtual void SetTime (real_t t)
 Set the time for time dependent coefficients.
 
real_t GetTime ()
 Get the time for time dependent coefficients.
 
int GetHeight () const
 Get the height of the matrix.
 
int GetWidth () const
 Get the width of the matrix.
 
int GetVDim () const
 For backward compatibility get the width of the matrix.
 
bool IsSymmetric () const
 
virtual void Eval (DenseMatrix &K, ElementTransformation &T, const IntegrationPoint &ip)=0
 Evaluate the matrix coefficient in the element described by T at the point ip, storing the result in K.
 
virtual void Project (QuadratureFunction &qf, bool transpose=false)
 Fill the QuadratureFunction qf by evaluating the coefficient at the quadrature points. The matrix will be transposed or not according to the boolean argument transpose.
 
virtual void EvalSymmetric (Vector &K, ElementTransformation &T, const IntegrationPoint &ip)
 (DEPRECATED) Evaluate a symmetric matrix coefficient.
 
virtual ~MatrixCoefficient ()
 

Protected Attributes

int height
 
int width
 
real_t time
 
bool symmetric
 

Detailed Description

Base class for Matrix Coefficients that optionally depend on time and space.

Definition at line 1040 of file coefficient.hpp.

Constructor & Destructor Documentation

◆ MatrixCoefficient() [1/2]

mfem::MatrixCoefficient::MatrixCoefficient ( int dim,
bool symm = false )
inlineexplicit

Construct a dim x dim matrix coefficient.

Definition at line 1049 of file coefficient.hpp.

◆ MatrixCoefficient() [2/2]

mfem::MatrixCoefficient::MatrixCoefficient ( int h,
int w,
bool symm = false )
inline

Construct a h x w matrix coefficient.

Definition at line 1053 of file coefficient.hpp.

◆ ~MatrixCoefficient()

virtual mfem::MatrixCoefficient::~MatrixCoefficient ( )
inlinevirtual

Definition at line 1101 of file coefficient.hpp.

Member Function Documentation

◆ Eval()

◆ EvalSymmetric()

virtual void mfem::MatrixCoefficient::EvalSymmetric ( Vector & K,
ElementTransformation & T,
const IntegrationPoint & ip )
inlinevirtual

(DEPRECATED) Evaluate a symmetric matrix coefficient.

Evaluate the upper triangular entries of the matrix coefficient in the symmetric case, similarly to Eval. Matrix entry (i,j) is stored in K[j - i + os_i] for 0 <= i <= j < width, os_0 = 0, os_{i+1} = os_i + width - i. That is, K = {M(0,0), ..., M(0,w-1), M(1,1), ..., M(1,w-1), ..., M(w-1,w-1) with w = width.

Deprecated
Use Eval() instead.

Reimplemented in mfem::MatrixFunctionCoefficient.

Definition at line 1097 of file coefficient.hpp.

◆ GetHeight()

int mfem::MatrixCoefficient::GetHeight ( ) const
inline

Get the height of the matrix.

Definition at line 1063 of file coefficient.hpp.

◆ GetTime()

real_t mfem::MatrixCoefficient::GetTime ( )
inline

Get the time for time dependent coefficients.

Definition at line 1060 of file coefficient.hpp.

◆ GetVDim()

int mfem::MatrixCoefficient::GetVDim ( ) const
inline

For backward compatibility get the width of the matrix.

Definition at line 1069 of file coefficient.hpp.

◆ GetWidth()

int mfem::MatrixCoefficient::GetWidth ( ) const
inline

Get the width of the matrix.

Definition at line 1066 of file coefficient.hpp.

◆ IsSymmetric()

bool mfem::MatrixCoefficient::IsSymmetric ( ) const
inline
Deprecated
Use SymmetricMatrixCoefficient instead

Definition at line 1072 of file coefficient.hpp.

◆ Project()

void mfem::MatrixCoefficient::Project ( QuadratureFunction & qf,
bool transpose = false )
virtual

Fill the QuadratureFunction qf by evaluating the coefficient at the quadrature points. The matrix will be transposed or not according to the boolean argument transpose.

The vdim of the QuadratureFunction should be equal to the height times the width of the matrix.

Definition at line 628 of file coefficient.cpp.

◆ SetTime()

Member Data Documentation

◆ height

int mfem::MatrixCoefficient::height
protected

Definition at line 1043 of file coefficient.hpp.

◆ symmetric

bool mfem::MatrixCoefficient::symmetric
protected

Definition at line 1045 of file coefficient.hpp.

◆ time

real_t mfem::MatrixCoefficient::time
protected

Definition at line 1044 of file coefficient.hpp.

◆ width

int mfem::MatrixCoefficient::width
protected

Definition at line 1043 of file coefficient.hpp.


The documentation for this class was generated from the following files: