Class xlifepp::IntgBilinearForm#

class IntgBilinearForm : public xlifepp::BasicBilinearForm#

Inheritence diagram for xlifepp::IntgBilinearForm:

digraph { graph [bgcolor="#00000000"] node [shape=rectangle style=filled fillcolor="#FFFFFF" font=Helvetica padding=2] edge [color="#1414CE"] "2" [label="xlifepp::BasicBilinearForm" tooltip="xlifepp::BasicBilinearForm"] "1" [label="xlifepp::IntgBilinearForm" tooltip="xlifepp::IntgBilinearForm" fillcolor="#BFBFBF"] "1" -> "2" [dir=forward tooltip="public-inheritance"] }

Collaboration diagram for xlifepp::IntgBilinearForm:

digraph { graph [bgcolor="#00000000"] node [shape=rectangle style=filled fillcolor="#FFFFFF" font=Helvetica padding=2] edge [color="#1414CE"] "28" [label="xlifepp::Collection< string_t >" tooltip="xlifepp::Collection< string_t >"] "21" [label="xlifepp::Matrix< real_t >" tooltip="xlifepp::Matrix< real_t >"] "25" [label="xlifepp::Vector< real_t >" tooltip="xlifepp::Vector< real_t >"] "36" [label="xlifepp::Vector< xlifepp::Vector< real_t > >" tooltip="xlifepp::Vector< xlifepp::Vector< real_t > >"] "41" [label="std::list< std::pair< number_t, real_t > >" tooltip="std::list< std::pair< number_t, real_t > >"] "17" [label="std::map< number_t, std::vector< number_t > >" tooltip="std::map< number_t, std::vector< number_t > >"] "15" [label="std::map< number_t, xlifepp::Geometry * >" tooltip="std::map< number_t, xlifepp::Geometry * >"] "40" [label="std::map< string_t, number_t >" tooltip="std::map< string_t, number_t >"] "59" [label="std::map< string_t, std::pair< ValueType, StrucType > >" tooltip="std::map< string_t, std::pair< ValueType, StrucType > >"] "56" [label="std::map< string_t, structPair >" tooltip="std::map< string_t, structPair >"] "61" [label="std::map< xlifepp::GeomElement *, std::set< number_t > >" tooltip="std::map< xlifepp::GeomElement *, std::set< number_t > >"] "42" [label="std::list< T >" tooltip="std::list< T >"] "16" [label="std::map< K, T >" tooltip="std::map< K, T >"] "12" [label="std::vector< T >" tooltip="std::vector< T >"] "31" [label="std::vector< T >" tooltip="std::vector< T >"] "24" [label="std::vector< K >" tooltip="std::vector< K >"] "11" [label="std::vector< RealPair >" tooltip="std::vector< RealPair >"] "65" [label="std::vector< complex_t >" tooltip="std::vector< complex_t >"] "47" [label="std::vector< const xlifepp::GeomDomain * >" tooltip="std::vector< const xlifepp::GeomDomain * >"] "27" [label="std::vector< const xlifepp::Transformation * >" tooltip="std::vector< const xlifepp::Transformation * >"] "32" [label="std::vector< number_t >" tooltip="std::vector< number_t >"] "22" [label="std::vector< real_t >" tooltip="std::vector< real_t >"] "46" [label="std::vector< std::vector< GeoNumPair > >" tooltip="std::vector< std::vector< GeoNumPair > >"] "18" [label="std::vector< std::vector< int_t > >" tooltip="std::vector< std::vector< int_t > >"] "29" [label="std::vector< string_t >" tooltip="std::vector< string_t >"] "53" [label="std::vector< xlifepp::DifferentialOperator * >" tooltip="std::vector< xlifepp::DifferentialOperator * >"] "45" [label="std::vector< xlifepp::GeomDomain * >" tooltip="std::vector< xlifepp::GeomDomain * >"] "44" [label="std::vector< xlifepp::GeomElement * >" tooltip="std::vector< xlifepp::GeomElement * >"] "39" [label="std::vector< xlifepp::Parameter * >" tooltip="std::vector< xlifepp::Parameter * >"] "14" [label="std::vector< xlifepp::Point >" tooltip="std::vector< xlifepp::Point >"] "48" [label="std::vector< xlifepp::Space * >" tooltip="std::vector< xlifepp::Space * >"] "33" [label="std::vector< xlifepp::Transformation * >" tooltip="std::vector< xlifepp::Transformation * >"] "49" [label="std::vector< xlifepp::Unknown * >" tooltip="std::vector< xlifepp::Unknown * >"] "37" [label="std::vector< xlifepp::Vector< real_t > >" tooltip="std::vector< xlifepp::Vector< real_t > >"] "2" [label="xlifepp::BasicBilinearForm" tooltip="xlifepp::BasicBilinearForm"] "10" [label="xlifepp::BoundingBox" tooltip="xlifepp::BoundingBox"] "30" [label="xlifepp::Collection< T >" tooltip="xlifepp::Collection< T >"] "52" [label="xlifepp::DifferentialOperator" tooltip="xlifepp::DifferentialOperator"] "7" [label="xlifepp::DomainInfo" tooltip="xlifepp::DomainInfo"] "60" [label="xlifepp::Extension" tooltip="xlifepp::Extension"] "19" [label="xlifepp::ExtrusionData" tooltip="xlifepp::ExtrusionData"] "58" [label="xlifepp::Function" tooltip="xlifepp::Function"] "43" [label="xlifepp::GeoNode" tooltip="xlifepp::GeoNode"] "6" [label="xlifepp::GeomDomain" tooltip="xlifepp::GeomDomain"] "9" [label="xlifepp::Geometry" tooltip="xlifepp::Geometry"] "66" [label="xlifepp::IntegrationMethod" tooltip="xlifepp::IntegrationMethod"] "1" [label="xlifepp::IntgBilinearForm" tooltip="xlifepp::IntgBilinearForm" fillcolor="#BFBFBF"] "63" [label="xlifepp::Kernel" tooltip="xlifepp::Kernel"] "64" [label="xlifepp::KernelExpansion" tooltip="xlifepp::KernelExpansion"] "23" [label="xlifepp::Matrix< K >" tooltip="xlifepp::Matrix< K >"] "8" [label="xlifepp::Mesh" tooltip="xlifepp::Mesh"] "13" [label="xlifepp::MinimalBox" tooltip="xlifepp::MinimalBox"] "54" [label="xlifepp::Operand" tooltip="xlifepp::Operand"] "57" [label="xlifepp::OperatorOnFunction" tooltip="xlifepp::OperatorOnFunction"] "62" [label="xlifepp::OperatorOnKernel" tooltip="xlifepp::OperatorOnKernel"] "51" [label="xlifepp::OperatorOnUnknown" tooltip="xlifepp::OperatorOnUnknown"] "50" [label="xlifepp::OperatorOnUnknowns" tooltip="xlifepp::OperatorOnUnknowns"] "38" [label="xlifepp::Parameters" tooltip="xlifepp::Parameters"] "35" [label="xlifepp::Parametrization" tooltip="xlifepp::Parametrization"] "34" [label="xlifepp::Point" tooltip="xlifepp::Point"] "4" [label="xlifepp::Space" tooltip="xlifepp::Space"] "5" [label="xlifepp::SpaceInfo" tooltip="xlifepp::SpaceInfo"] "20" [label="xlifepp::Transformation" tooltip="xlifepp::Transformation"] "3" [label="xlifepp::Unknown" tooltip="xlifepp::Unknown"] "55" [label="xlifepp::Value" tooltip="xlifepp::Value"] "26" [label="xlifepp::Vector< K >" tooltip="xlifepp::Vector< K >"] "28" -> "29" [dir=forward tooltip="public-inheritance"] "28" -> "30" [dir=forward tooltip="template-instance"] "21" -> "22" [dir=forward tooltip="public-inheritance"] "21" -> "23" [dir=forward tooltip="template-instance"] "25" -> "22" [dir=forward tooltip="public-inheritance"] "25" -> "26" [dir=forward tooltip="template-instance"] "36" -> "37" [dir=forward tooltip="public-inheritance"] "36" -> "26" [dir=forward tooltip="template-instance"] "41" -> "42" [dir=forward tooltip="template-instance"] "17" -> "16" [dir=forward tooltip="template-instance"] "15" -> "16" [dir=forward tooltip="template-instance"] "40" -> "16" [dir=forward tooltip="template-instance"] "59" -> "16" [dir=forward tooltip="template-instance"] "56" -> "16" [dir=forward tooltip="template-instance"] "61" -> "16" [dir=forward tooltip="template-instance"] "24" -> "12" [dir=forward tooltip="template-instance"] "11" -> "12" [dir=forward tooltip="template-instance"] "65" -> "12" [dir=forward tooltip="template-instance"] "47" -> "12" [dir=forward tooltip="template-instance"] "27" -> "12" [dir=forward tooltip="template-instance"] "32" -> "12" [dir=forward tooltip="template-instance"] "22" -> "12" [dir=forward tooltip="template-instance"] "46" -> "12" [dir=forward tooltip="template-instance"] "18" -> "12" [dir=forward tooltip="template-instance"] "29" -> "12" [dir=forward tooltip="template-instance"] "53" -> "12" [dir=forward tooltip="template-instance"] "45" -> "12" [dir=forward tooltip="template-instance"] "44" -> "12" [dir=forward tooltip="template-instance"] "39" -> "12" [dir=forward tooltip="template-instance"] "14" -> "12" [dir=forward tooltip="template-instance"] "48" -> "12" [dir=forward tooltip="template-instance"] "33" -> "12" [dir=forward tooltip="template-instance"] "49" -> "12" [dir=forward tooltip="template-instance"] "37" -> "12" [dir=forward tooltip="template-instance"] "2" -> "3" [dir=forward tooltip="usage"] "2" -> "6" [dir=forward tooltip="usage"] "10" -> "11" [dir=forward tooltip="usage"] "30" -> "31" [dir=forward tooltip="public-inheritance"] "52" -> "53" [dir=forward tooltip="usage"] "7" -> "8" [dir=forward tooltip="usage"] "60" -> "6" [dir=forward tooltip="usage"] "60" -> "61" [dir=forward tooltip="usage"] "19" -> "20" [dir=forward tooltip="usage"] "19" -> "28" [dir=forward tooltip="usage"] "19" -> "32" [dir=forward tooltip="usage"] "19" -> "22" [dir=forward tooltip="usage"] "19" -> "25" [dir=forward tooltip="usage"] "19" -> "33" [dir=forward tooltip="usage"] "19" -> "34" [dir=forward tooltip="usage"] "58" -> "38" [dir=forward tooltip="usage"] "58" -> "58" [dir=forward tooltip="usage"] "58" -> "34" [dir=forward tooltip="usage"] "58" -> "59" [dir=forward tooltip="usage"] "43" -> "43" [dir=forward tooltip="usage"] "43" -> "9" [dir=forward tooltip="usage"] "6" -> "7" [dir=forward tooltip="usage"] "6" -> "6" [dir=forward tooltip="usage"] "6" -> "9" [dir=forward tooltip="usage"] "6" -> "47" [dir=forward tooltip="usage"] "9" -> "10" [dir=forward tooltip="usage"] "9" -> "13" [dir=forward tooltip="usage"] "9" -> "15" [dir=forward tooltip="usage"] "9" -> "17" [dir=forward tooltip="usage"] "9" -> "18" [dir=forward tooltip="usage"] "9" -> "19" [dir=forward tooltip="usage"] "9" -> "35" [dir=forward tooltip="usage"] "9" -> "9" [dir=forward tooltip="usage"] "9" -> "43" [dir=forward tooltip="usage"] "1" -> "2" [dir=forward tooltip="public-inheritance"] "1" -> "50" [dir=forward tooltip="usage"] "1" -> "66" [dir=forward tooltip="usage"] "63" -> "58" [dir=forward tooltip="usage"] "63" -> "63" [dir=forward tooltip="usage"] "63" -> "64" [dir=forward tooltip="usage"] "63" -> "38" [dir=forward tooltip="usage"] "63" -> "34" [dir=forward tooltip="usage"] "64" -> "58" [dir=forward tooltip="usage"] "23" -> "24" [dir=forward tooltip="public-inheritance"] "8" -> "9" [dir=forward tooltip="usage"] "8" -> "14" [dir=forward tooltip="usage"] "8" -> "44" [dir=forward tooltip="usage"] "8" -> "45" [dir=forward tooltip="usage"] "8" -> "32" [dir=forward tooltip="usage"] "8" -> "46" [dir=forward tooltip="usage"] "8" -> "8" [dir=forward tooltip="usage"] "13" -> "14" [dir=forward tooltip="usage"] "54" -> "55" [dir=forward tooltip="usage"] "54" -> "57" [dir=forward tooltip="usage"] "54" -> "62" [dir=forward tooltip="usage"] "57" -> "58" [dir=forward tooltip="usage"] "57" -> "52" [dir=forward tooltip="usage"] "57" -> "60" [dir=forward tooltip="usage"] "62" -> "63" [dir=forward tooltip="usage"] "62" -> "52" [dir=forward tooltip="usage"] "62" -> "60" [dir=forward tooltip="usage"] "51" -> "3" [dir=forward tooltip="usage"] "51" -> "52" [dir=forward tooltip="usage"] "51" -> "54" [dir=forward tooltip="usage"] "51" -> "65" [dir=forward tooltip="usage"] "51" -> "6" [dir=forward tooltip="usage"] "50" -> "51" [dir=forward tooltip="usage"] "38" -> "39" [dir=forward tooltip="usage"] "38" -> "40" [dir=forward tooltip="usage"] "35" -> "9" [dir=forward tooltip="usage"] "35" -> "25" [dir=forward tooltip="usage"] "35" -> "36" [dir=forward tooltip="usage"] "35" -> "8" [dir=forward tooltip="usage"] "35" -> "38" [dir=forward tooltip="usage"] "35" -> "41" [dir=forward tooltip="usage"] "34" -> "22" [dir=forward tooltip="public-inheritance"] "4" -> "4" [dir=forward tooltip="usage"] "4" -> "5" [dir=forward tooltip="usage"] "4" -> "48" [dir=forward tooltip="usage"] "5" -> "6" [dir=forward tooltip="usage"] "20" -> "21" [dir=forward tooltip="usage"] "20" -> "25" [dir=forward tooltip="usage"] "20" -> "27" [dir=forward tooltip="usage"] "3" -> "4" [dir=forward tooltip="usage"] "3" -> "3" [dir=forward tooltip="usage"] "3" -> "49" [dir=forward tooltip="usage"] "55" -> "56" [dir=forward tooltip="usage"] "26" -> "24" [dir=forward tooltip="public-inheritance"] }

describes a bilinear form based on a single integral

 intg_domain opu aopu opv
with opu, opv: operator on u and v aopu, aopv: algebraic operation (*,|,%,^)

Public Functions

IntgBilinearForm(const GeomDomain &dom, const OperatorOnUnknown &opu, AlgebraicOperator aop, const OperatorOnUnknown &opv, const IntegrationMethod &im, SymType st)#

constructor from explicit operators

IntgBilinearForm(const GeomDomain &dom, const OperatorOnUnknown &opu, AlgebraicOperator aop, const OperatorOnUnknown &opv, QuadRule qr, number_t qo, SymType st)#

constructor from explicit operators

IntgBilinearForm(const GeomDomain &dom, const OperatorOnUnknowns &opus, const IntegrationMethod &im, SymType st)#

constructor from OperatorOnUnknowns

IntgBilinearForm(const GeomDomain &dom, const OperatorOnUnknowns &opus, QuadRule qr, number_t qo, SymType st)#

constructor from OperatorOnUnknowns

IntgBilinearForm(const IntgBilinearForm &ibf)#

copy constructor

~IntgBilinearForm()#

destructor

inline AlgebraicOperator algop() const#

return the algebraic operator

virtual string_t asString() const#

interpret as string for print purpose

virtual BasicBilinearForm *clone() const#

clone of the linear form

inline const GeomDomain *domain() const#

return the pointer to the domain

virtual bool hasJump() const#

true if bilinear form has jump, mean operator

inline const IntegrationMethod *intgMethod() const#

pointer to integration method object

IntgBilinearForm &operator=(const IntgBilinearForm &ibf)#

assign operator

inline const OperatorOnUnknown &opu() const#

return the reference to the operator on unknown

inline const OperatorOnUnknown *opu_p() const#

return the pointer to the operator on unknown

inline const OperatorOnUnknown &opv() const#

return the reference to the operator on unknown

inline const OperatorOnUnknown *opv_p() const#

return the pointer to the operator on unknown

inline virtual void print(PrintStream &ps) const#

print utility

virtual void print(std::ostream &os) const#

true if bilinear form has jump, mean operator

print utility

void setComputationType()#

set computation type (_FEComputation,_SPComputation, _FESPComputation)

void setIntegrationMethod(const GeomDomain &dom, const OperatorOnUnknowns &opus, QuadRule qr, number_t qo)#

set integration method

virtual SymType setSymType() const#

set symmetry property

virtual void setUnknowns(const Unknown &u, const Unknown &v)#

set (change) the unknowns

virtual std::vector<bfPair> split() const#

split IntgBilinearForm involving particular operators (jump, mean)

split IntgBilinearForm involving particular operators (jump : u1-u2, mean : (u1+u2)/2 for instance, if G is one side of a crack with Gd the opposite side of gamma intg(G,[u]*v)= intg(G,(u|G-u|Gd)*v) is split as intg(G,u*v)-intg(G,u|Gd*v) (v continuous) intg(G,u*[v])= intg(G,u*(v|G-v|Gd)) is split as intg(G,u*v)-intg(G,u*v|Gd) (u continuous) intg(G,{u}*v)= intg(G,(u|G+u|Gd)*v) is split as intg(G,u*v)+intg(G,u|Gd*v) (v continuous) intg(G,u*{v})= intg(G,u*(v|G+v|Gd)) is split as intg(G,u*v)+intg(G,u*v|Gd) (u continuous) intg(G,[u]*[v])= intg(G,(u|G-u|Gd)*(v|G-v|Gd)) is split as intg(G,u*v)+intg(Gd,u*v)-intg(G,u*v|Gd)-intg(G,u|Gd*v) intg(G,{u}*{v})= intg(G,(u|G+u|Gd)*(v|G+v|Gd)) is split as intg(G,u*v)+intg(Gd,u*v)+intg(G,u*v|Gd)+intg(G,u|Gd*v) intg(G,{u}*[v])= intg(G,(u|G+u|Gd)*(v|G-v|Gd)) is split as intg(G,u*v)-intg(Gd,u*v)-intg(G,u*v|Gd)+intg(G,u|Gd*v) intg(G,[u]*{v})= intg(G,(u|G-u|Gd)*(v|G+v|Gd)) is split as intg(G,u*v)-intg(Gd,u*v)+intg(G,u*v|Gd)-intg(G,u|Gd*v)

gives the following table intg(G,u*v) intg(Gd,u*v) intg(G,u*v|Gd) intg(G,u|Gd*v) [u]*v 1 0 0 -1 u*[v] 1 0 -1 0 {u}*v 1 0 0 1 u*{v} 1 0 1 0 [u]*[v] 1 1 -1 -1 {u}*{v} 1 1 1 1 {u}*[v] 1 -1 -1 1 [u]*{v} 1 -1 1 -1 a b c all coefficient are multiplied by the factor f = 1 if no mean operator, f = 0.5 if one mean operator, f = 0.25 if two mean operators

inline virtual LinearFormType type() const#

return the type of the linear form

inline virtual ValueType valueType() const#

return the value type of the linear form