|
BEM++
2.0
|
Adjoint abstract boundary operator. More...
#include </home/wojtek/Projects/BEM/bempp-sven/bempp/lib/assembly/adjoint_abstract_boundary_operator.hpp>
Public Types | |
| typedef Base::BasisFunctionType | BasisFunctionType |
| Type of the values of the (components of the) basis functions into which functions acted upon by the operator are expanded. More... | |
| typedef Base::ResultType | ResultType |
| Type used to represent elements of the weak form of the operator. More... | |
| typedef Base::CoordinateType | CoordinateType |
| Type used to represent coordinates. More... | |
| typedef Base::QuadratureStrategy | QuadratureStrategy |
| Type of the appropriate instantiation of Fiber::QuadratureStrategy. More... | |
Public Types inherited from Bempp::AbstractBoundaryOperator< BasisFunctionType_, ResultType_ > | |
| typedef BasisFunctionType_ | BasisFunctionType |
| Type of the values of the (components of the) basis functions into which functions acted upon by the operator are expanded. | |
| typedef ResultType_ | ResultType |
| Type used to represent elements of the weak form of the operator. | |
|
typedef ScalarTraits < ResultType >::RealType | CoordinateType |
| Type used to represent coordinates. | |
|
typedef Fiber::QuadratureStrategy < BasisFunctionType, ResultType, GeometryFactory > | QuadratureStrategy |
| Type of the appropriate instantiation of Fiber::QuadratureStrategy. | |
Public Member Functions | |
| AdjointAbstractBoundaryOperator (const BoundaryOperator< BasisFunctionType, ResultType > &boundaryOp, int symmetry=AUTO_SYMMETRY) | |
| Constructor. More... | |
| AdjointAbstractBoundaryOperator (const BoundaryOperator< BasisFunctionType, ResultType > &boundaryOp, const shared_ptr< const Space< BasisFunctionType > > &range, int symmetry=AUTO_SYMMETRY) | |
| Constructor. More... | |
| virtual bool | isLocal () const |
| Return whether this operator is local. More... | |
Public Member Functions inherited from Bempp::AbstractBoundaryOperator< BasisFunctionType_, ResultType_ > | |
| AbstractBoundaryOperator (const shared_ptr< const Space< BasisFunctionType > > &domain, const shared_ptr< const Space< BasisFunctionType > > &range, const shared_ptr< const Space< BasisFunctionType > > &dualToRange, const std::string &label, int symmetry) | |
| Constructor. More... | |
| virtual | ~AbstractBoundaryOperator () |
| Destructor. | |
| virtual BEMPP_DEPRECATED shared_ptr< const AbstractBoundaryOperatorId > | id () const |
| Return the identifier of this operator. More... | |
| shared_ptr< const Space < BasisFunctionType > > | domain () const |
| Domain. More... | |
| shared_ptr< const Space < BasisFunctionType > > | range () const |
| Range. More... | |
| shared_ptr< const Space < BasisFunctionType > > | dualToRange () const |
| Dual to range. More... | |
| std::string | label () const |
| Return the label of the operator. | |
| int | symmetry () const |
| Return the symmetry properties of the operator. More... | |
| shared_ptr < DiscreteBoundaryOperator < ResultType_ > > | assembleWeakForm (const Context< BasisFunctionType_, ResultType_ > &context) const |
| Assemble and return the operator's weak form. More... | |
Protected Member Functions | |
| virtual shared_ptr < DiscreteBoundaryOperator < ResultType_ > > | assembleWeakFormImpl (const Context< BasisFunctionType, ResultType > &context) const |
| Assemble and return the operator's weak form. More... | |
Protected Member Functions inherited from Bempp::AbstractBoundaryOperator< BasisFunctionType_, ResultType_ > | |
| void | collectDataForAssemblerConstruction (const AssemblyOptions &options, shared_ptr< Fiber::RawGridGeometry< CoordinateType > > &testRawGeometry, shared_ptr< Fiber::RawGridGeometry< CoordinateType > > &trialRawGeometry, shared_ptr< GeometryFactory > &testGeometryFactory, shared_ptr< GeometryFactory > &trialGeometryFactory, shared_ptr< std::vector< const Fiber::Shapeset< BasisFunctionType_ > * > > &testShapesets, shared_ptr< std::vector< const Fiber::Shapeset< BasisFunctionType_ > * > > &trialShapesets, shared_ptr< Fiber::OpenClHandler > &openClHandler, bool &cacheSingularIntegrals) const |
| Given an AssemblyOptions object, construct objects necessary for subsequent local assembler construction. | |
| void | collectOptionsIndependentDataForAssemblerConstruction (shared_ptr< Fiber::RawGridGeometry< CoordinateType > > &testRawGeometry, shared_ptr< Fiber::RawGridGeometry< CoordinateType > > &trialRawGeometry, shared_ptr< GeometryFactory > &testGeometryFactory, shared_ptr< GeometryFactory > &trialGeometryFactory, shared_ptr< std::vector< const Fiber::Shapeset< BasisFunctionType_ > * > > &testShapesets, shared_ptr< std::vector< const Fiber::Shapeset< BasisFunctionType_ > * > > &trialShapesets) const |
| Construct those objects necessary for subsequent local assembler construction that are independent from assembly options. | |
| void | collectOptionsDependentDataForAssemblerConstruction (const AssemblyOptions &options, const shared_ptr< Fiber::RawGridGeometry< CoordinateType > > &testRawGeometry, const shared_ptr< Fiber::RawGridGeometry< CoordinateType > > &trialRawGeometry, shared_ptr< Fiber::OpenClHandler > &openClHandler, bool &cacheSingularIntegrals) const |
| Construct those objects necessary for subsequent local assembler construction that depend on assembly options. | |
Private Types | |
|
typedef AbstractBoundaryOperator < BasisFunctionType_, ResultType_ > | Base |
Private Attributes | |
|
BoundaryOperator < BasisFunctionType, ResultType > | m_operator |
Adjoint abstract boundary operator.
This class represents the adjoint of an abstract boundary operator.
Currently the adjoint operator can be constructed only for operators acting on real-valued basis functions. Let
be such an operator, and let
be its discrete weak form. Then the discrete weak form of the adjoint of
is the transpose of
.
Note that this definition is not the one most usual in mathematics (where the conjugate transpose would be used). However, it corresponds to the relation between the double-layer potential boundary operator and adjoint double-layer potential boundary operator for Laplace and Helmholtz equation as defined in standard texts. Hence, for example, the discrete weak forms of the operators B and C in the code snippet below are numerically identical (at least to within quadrature accuracy):
| typedef Base::BasisFunctionType Bempp::AdjointAbstractBoundaryOperator< BasisFunctionType_, ResultType_ >::BasisFunctionType |
Type of the values of the (components of the) basis functions into which functions acted upon by the operator are expanded.
| typedef Base::CoordinateType Bempp::AdjointAbstractBoundaryOperator< BasisFunctionType_, ResultType_ >::CoordinateType |
Type used to represent coordinates.
| typedef Base::QuadratureStrategy Bempp::AdjointAbstractBoundaryOperator< BasisFunctionType_, ResultType_ >::QuadratureStrategy |
Type of the appropriate instantiation of Fiber::QuadratureStrategy.
| typedef Base::ResultType Bempp::AdjointAbstractBoundaryOperator< BasisFunctionType_, ResultType_ >::ResultType |
Type used to represent elements of the weak form of the operator.
| Bempp::AdjointAbstractBoundaryOperator< BasisFunctionType, ResultType >::AdjointAbstractBoundaryOperator | ( | const BoundaryOperator< BasisFunctionType, ResultType > & | boundaryOp, |
| int | symmetry = AUTO_SYMMETRY |
||
| ) |
Constructor.
Construct the boundary operator
, where
is the scalar weight and
is the operator represented by boundaryOp.
By default the symmetry of the weak form of the resulting operator is determined automatically. It can be set manually via the parameter symmetry, which can be any combination of the flags defined in the enumeration type Symmetry.
References Bempp::BoundaryOperator< BasisFunctionType, ResultType >::domain(), Bempp::BoundaryOperator< BasisFunctionType, ResultType >::dualToRange(), and Bempp::BoundaryOperator< BasisFunctionType, ResultType >::range().
| Bempp::AdjointAbstractBoundaryOperator< BasisFunctionType, ResultType >::AdjointAbstractBoundaryOperator | ( | const BoundaryOperator< BasisFunctionType, ResultType > & | boundaryOp, |
| const shared_ptr< const Space< BasisFunctionType > > & | range, | ||
| int | symmetry = AUTO_SYMMETRY |
||
| ) |
Constructor.
This constructor allows to explicitly specify the range space. This is useful if the standard heuristic to detect this space fails. An example is a boundary operator, where the domain and range live on different grids.
|
protectedvirtual |
Assemble and return the operator's weak form.
This virtual function is invoked by assembleWeakForm() to do the actual work.
Implements Bempp::AbstractBoundaryOperator< BasisFunctionType_, ResultType_ >.
References Bempp::TRANSPOSE.
|
virtual |
Return whether this operator is local.
Suppose that an operator
acting on a function
produces another function
. We say that
is local if the value of
at any point
depends only on the values of
in an infinitesimal neighbourhood of
.
Multiplicative and differential operators are local and discretization of their weak forms with finite elements leads to sparse matrices. Conversely, integral operators are in general non-local and discretization of their weak forms leads to dense matrices.
Implements Bempp::AbstractBoundaryOperator< BasisFunctionType_, ResultType_ >.
1.8.5