![]() |
MFEM v4.9.0
Finite element discretization library
|
Base class for vector Coefficients that optionally depend on time and space. More...
#include <coefficient.hpp>
Public Member Functions | |
| VectorCoefficient (int vd) | |
| Initialize the VectorCoefficient with vector dimension vd. | |
| virtual void | SetTime (real_t t) |
| Set the time for time dependent coefficients. | |
| real_t | GetTime () |
| Get the time for time dependent coefficients. | |
| int | GetVDim () |
| Returns dimension of the vector. | |
| virtual void | Eval (Vector &V, ElementTransformation &T, const IntegrationPoint &ip)=0 |
| Evaluate the vector coefficient in the element described by T at the point ip, storing the result in V. | |
| virtual void | Eval (DenseMatrix &M, ElementTransformation &T, const IntegrationRule &ir) |
| Evaluate the vector coefficient in the element described by T at all points of ir, storing the result in M. | |
| virtual void | Project (QuadratureFunction &qf) |
| Fill the QuadratureFunction qf by evaluating the coefficient at the quadrature points. | |
| virtual | ~VectorCoefficient () |
Protected Attributes | |
| int | vdim |
| real_t | time |
Base class for vector Coefficients that optionally depend on time and space.
Definition at line 574 of file coefficient.hpp.
|
inline |
Initialize the VectorCoefficient with vector dimension vd.
Definition at line 582 of file coefficient.hpp.
|
inlinevirtual |
Definition at line 623 of file coefficient.hpp.
|
virtual |
Evaluate the vector coefficient in the element described by T at all points of ir, storing the result in M.
The dimensions of M are GetVDim() by ir.GetNPoints() and they must be set by the implementation of this method.
The general implementation provided by the base class (using the Eval method for one IntegrationPoint at a time) can be overloaded for more efficient implementation.
Reimplemented in Dist_Vector_Coefficient, mfem::common::AffineTransformation, mfem::common::KershawTransformation, mfem::common::NormalizedGradCoefficient, mfem::common::SpiralTransformation, mfem::CurlGridFunctionCoefficient, mfem::GradientGridFunctionCoefficient, mfem::LevelSetNormalGradCoeff, mfem::MatrixVectorProductCoefficient, mfem::NodeExtrudeCoefficient, mfem::NormalizedVectorCoefficient, mfem::PositionVectorCoefficient, mfem::PWVectorCoefficient, mfem::ScalarVectorProductCoefficient, mfem::ShiftedVectorFunctionCoefficient, mfem::VectorArrayCoefficient, mfem::VectorConstantCoefficient, mfem::VectorCrossProductCoefficient, mfem::VectorDeltaCoefficient, mfem::VectorFunctionCoefficient, mfem::VectorGridFunctionCoefficient, mfem::VectorQuadratureFunctionCoefficient, mfem::VectorRestrictedCoefficient, mfem::VectorSumCoefficient, and mfem::VolumeForceCoefficient.
Definition at line 309 of file coefficient.cpp.
|
pure virtual |
Evaluate the vector coefficient in the element described by T at the point ip, storing the result in V.
Implemented in Dist_Vector_Coefficient, mfem::common::AffineTransformation, mfem::common::KershawTransformation, mfem::common::NormalizedGradCoefficient, mfem::common::SpiralTransformation, mfem::CurlGridFunctionCoefficient, mfem::GradientGridFunctionCoefficient, mfem::LevelSetNormalGradCoeff, mfem::MatrixVectorProductCoefficient, mfem::NodeExtrudeCoefficient, mfem::NormalizedVectorCoefficient, mfem::PositionVectorCoefficient, mfem::PWVectorCoefficient, mfem::ScalarVectorProductCoefficient, mfem::ShiftedVectorFunctionCoefficient, mfem::VectorArrayCoefficient, mfem::VectorConstantCoefficient, mfem::VectorCrossProductCoefficient, mfem::VectorDeltaCoefficient, mfem::VectorFunctionCoefficient, mfem::VectorGridFunctionCoefficient, mfem::VectorQuadratureFunctionCoefficient, mfem::VectorRestrictedCoefficient, mfem::VectorSumCoefficient, and mfem::VolumeForceCoefficient.
|
inline |
Get the time for time dependent coefficients.
Definition at line 588 of file coefficient.hpp.
|
inline |
Returns dimension of the vector.
Definition at line 591 of file coefficient.hpp.
|
virtual |
Fill the QuadratureFunction qf by evaluating the coefficient at the quadrature points.
The vdim of the VectorCoefficient should be equal to the vdim of the QuadratureFunction.
Reimplemented in mfem::GradientGridFunctionCoefficient, mfem::VectorGridFunctionCoefficient, and mfem::VectorQuadratureFunctionCoefficient.
Definition at line 323 of file coefficient.cpp.
|
inlinevirtual |
Set the time for time dependent coefficients.
Reimplemented in mfem::MatrixVectorProductCoefficient, mfem::NormalizedVectorCoefficient, mfem::PWVectorCoefficient, mfem::ScalarVectorProductCoefficient, mfem::VectorArrayCoefficient, mfem::VectorCrossProductCoefficient, mfem::VectorDeltaCoefficient, mfem::VectorRestrictedCoefficient, and mfem::VectorSumCoefficient.
Definition at line 585 of file coefficient.hpp.
|
protected |
Definition at line 578 of file coefficient.hpp.
|
protected |
Definition at line 577 of file coefficient.hpp.