MFEM  v4.2.0
Finite element discretization library
 All Classes Namespaces Files Functions Variables Typedefs Enumerations Enumerator Friends Pages
Public Member Functions | Protected Member Functions | List of all members
mfem::MixedVectorCurlIntegrator Class Reference

#include <bilininteg.hpp>

Inheritance diagram for mfem::MixedVectorCurlIntegrator:
[legend]
Collaboration diagram for mfem::MixedVectorCurlIntegrator:
[legend]

Public Member Functions

 MixedVectorCurlIntegrator ()
 
 MixedVectorCurlIntegrator (Coefficient &q)
 
 MixedVectorCurlIntegrator (VectorCoefficient &dq)
 
 MixedVectorCurlIntegrator (MatrixCoefficient &mq)
 
- Public Member Functions inherited from mfem::MixedVectorIntegrator
virtual void AssembleElementMatrix2 (const FiniteElement &trial_fe, const FiniteElement &test_fe, ElementTransformation &Trans, DenseMatrix &elmat)
 
virtual void AssembleElementMatrix (const FiniteElement &fe, ElementTransformation &Trans, DenseMatrix &elmat)
 Support for use in BilinearForm. Can be used only when appropriate. More...
 
- Public Member Functions inherited from mfem::BilinearFormIntegrator
virtual void AssemblePA (const FiniteElementSpace &fes)
 Method defining partial assembly. More...
 
virtual void AssemblePAInteriorFaces (const FiniteElementSpace &fes)
 
virtual void AssemblePABoundaryFaces (const FiniteElementSpace &fes)
 
virtual void AssembleDiagonalPA (Vector &diag)
 Assemble diagonal and add it to Vector diag. More...
 
virtual void AssembleDiagonalPA_ADAt (const Vector &D, Vector &diag)
 Assemble diagonal of ADA^T (A is this integrator) and add it to diag. More...
 
virtual void AddMultTransposePA (const Vector &x, Vector &y) const
 Method for partially assembled transposed action. More...
 
virtual void AssembleEA (const FiniteElementSpace &fes, Vector &emat, const bool add=true)
 Method defining element assembly. More...
 
virtual void AssembleMF (const FiniteElementSpace &fes)
 Method defining matrix-free assembly. More...
 
virtual void AddMultMF (const Vector &x, Vector &y) const
 
virtual void AddMultTransposeMF (const Vector &x, Vector &y) const
 
virtual void AssembleDiagonalMF (Vector &diag)
 Assemble diagonal and add it to Vector diag. More...
 
virtual void AssembleEAInteriorFaces (const FiniteElementSpace &fes, Vector &ea_data_int, Vector &ea_data_ext, const bool add=true)
 
virtual void AssembleEABoundaryFaces (const FiniteElementSpace &fes, Vector &ea_data_bdr, const bool add=true)
 
virtual void AssembleFaceMatrix (const FiniteElement &el1, const FiniteElement &el2, FaceElementTransformations &Trans, DenseMatrix &elmat)
 
virtual void AssembleFaceMatrix (const FiniteElement &trial_face_fe, const FiniteElement &test_fe1, const FiniteElement &test_fe2, FaceElementTransformations &Trans, DenseMatrix &elmat)
 
virtual void AssembleElementVector (const FiniteElement &el, ElementTransformation &Tr, const Vector &elfun, Vector &elvect)
 Perform the local action of the BilinearFormIntegrator. Note that the default implementation in the base class is general but not efficient. More...
 
virtual void AssembleFaceVector (const FiniteElement &el1, const FiniteElement &el2, FaceElementTransformations &Tr, const Vector &elfun, Vector &elvect)
 Perform the local action of the BilinearFormIntegrator resulting from a face integral term. Note that the default implementation in the base class is general but not efficient. More...
 
virtual void AssembleElementGrad (const FiniteElement &el, ElementTransformation &Tr, const Vector &elfun, DenseMatrix &elmat)
 Assemble the local gradient matrix. More...
 
virtual void AssembleFaceGrad (const FiniteElement &el1, const FiniteElement &el2, FaceElementTransformations &Tr, const Vector &elfun, DenseMatrix &elmat)
 Assemble the local action of the gradient of the NonlinearFormIntegrator resulting from a face integral term. More...
 
virtual void ComputeElementFlux (const FiniteElement &el, ElementTransformation &Trans, Vector &u, const FiniteElement &fluxelem, Vector &flux, bool with_coef=true)
 Virtual method required for Zienkiewicz-Zhu type error estimators. More...
 
virtual double ComputeFluxEnergy (const FiniteElement &fluxelem, ElementTransformation &Trans, Vector &flux, Vector *d_energy=NULL)
 Virtual method required for Zienkiewicz-Zhu type error estimators. More...
 
virtual ~BilinearFormIntegrator ()
 
- Public Member Functions inherited from mfem::NonlinearFormIntegrator
void SetIntRule (const IntegrationRule *ir)
 Prescribe a fixed IntegrationRule to use (when ir != NULL) or let the integrator choose (when ir == NULL). More...
 
void SetIntegrationRule (const IntegrationRule &irule)
 Prescribe a fixed IntegrationRule to use. More...
 
virtual double GetElementEnergy (const FiniteElement &el, ElementTransformation &Tr, const Vector &elfun)
 Compute the local energy. More...
 
virtual ~NonlinearFormIntegrator ()
 

Protected Member Functions

virtual bool VerifyFiniteElementTypes (const FiniteElement &trial_fe, const FiniteElement &test_fe) const
 
virtual const char * FiniteElementTypeFailureMessage () const
 
virtual void CalcTrialShape (const FiniteElement &trial_fe, ElementTransformation &Trans, DenseMatrix &shape)
 
virtual void AssemblePA (const FiniteElementSpace &trial_fes, const FiniteElementSpace &test_fes)
 
virtual void AddMultPA (const Vector &, Vector &) const
 Method for partially assembled action. More...
 
- Protected Member Functions inherited from mfem::MixedVectorIntegrator
 MixedVectorIntegrator ()
 
 MixedVectorIntegrator (Coefficient &q)
 
 MixedVectorIntegrator (VectorCoefficient &dq, bool diag=true)
 
 MixedVectorIntegrator (MatrixCoefficient &mq)
 
virtual int GetIntegrationOrder (const FiniteElement &trial_fe, const FiniteElement &test_fe, ElementTransformation &Trans)
 
virtual void CalcTestShape (const FiniteElement &test_fe, ElementTransformation &Trans, DenseMatrix &shape)
 
- Protected Member Functions inherited from mfem::BilinearFormIntegrator
 BilinearFormIntegrator (const IntegrationRule *ir=NULL)
 
- Protected Member Functions inherited from mfem::NonlinearFormIntegrator
 NonlinearFormIntegrator (const IntegrationRule *ir=NULL)
 

Additional Inherited Members

- Protected Attributes inherited from mfem::MixedVectorIntegrator
bool same_calc_shape
 
CoefficientQ
 
VectorCoefficientVQ
 
VectorCoefficientDQ
 
MatrixCoefficientMQ
 
- Protected Attributes inherited from mfem::NonlinearFormIntegrator
const IntegrationRuleIntRule
 

Detailed Description

Class for integrating the bilinear form a(u,v) := (Q curl u, v) in 3D and where Q is an optional coefficient (of type scalar, matrix, or diagonal matrix) u is in H(Curl) and v is in H(Div) or H(Curl).

Definition at line 1702 of file bilininteg.hpp.

Constructor & Destructor Documentation

mfem::MixedVectorCurlIntegrator::MixedVectorCurlIntegrator ( )
inline

Definition at line 1705 of file bilininteg.hpp.

mfem::MixedVectorCurlIntegrator::MixedVectorCurlIntegrator ( Coefficient q)
inline

Definition at line 1706 of file bilininteg.hpp.

mfem::MixedVectorCurlIntegrator::MixedVectorCurlIntegrator ( VectorCoefficient dq)
inline

Definition at line 1708 of file bilininteg.hpp.

mfem::MixedVectorCurlIntegrator::MixedVectorCurlIntegrator ( MatrixCoefficient mq)
inline

Definition at line 1710 of file bilininteg.hpp.

Member Function Documentation

void mfem::MixedVectorCurlIntegrator::AddMultPA ( const Vector x,
Vector y 
) const
protectedvirtual

Method for partially assembled action.

Perform the action of integrator on the input x and add the result to the output y. Both x and y are E-vectors, i.e. they represent the element-wise discontinuous version of the FE space.

This method can be called only after the method AssemblePA() has been called.

Reimplemented from mfem::BilinearFormIntegrator.

Definition at line 3944 of file bilininteg_hcurl.cpp.

void mfem::MixedVectorCurlIntegrator::AssemblePA ( const FiniteElementSpace trial_fes,
const FiniteElementSpace test_fes 
)
protectedvirtual

Used with BilinearFormIntegrators that have different spaces.

Reimplemented from mfem::BilinearFormIntegrator.

Definition at line 2860 of file bilininteg_hcurl.cpp.

virtual void mfem::MixedVectorCurlIntegrator::CalcTrialShape ( const FiniteElement trial_fe,
ElementTransformation Trans,
DenseMatrix shape 
)
inlineprotectedvirtual

Reimplemented from mfem::MixedVectorIntegrator.

Definition at line 1730 of file bilininteg.hpp.

virtual const char* mfem::MixedVectorCurlIntegrator::FiniteElementTypeFailureMessage ( ) const
inlineprotectedvirtual

Reimplemented from mfem::MixedVectorIntegrator.

Definition at line 1723 of file bilininteg.hpp.

virtual bool mfem::MixedVectorCurlIntegrator::VerifyFiniteElementTypes ( const FiniteElement trial_fe,
const FiniteElement test_fe 
) const
inlineprotectedvirtual

Reimplemented from mfem::MixedVectorIntegrator.

Definition at line 1714 of file bilininteg.hpp.


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