Class xlifepp::Triangle#

class Triangle : public xlifepp::Polygon#

Inheritence diagram for xlifepp::Triangle:

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

Collaboration diagram for xlifepp::Triangle:

digraph { graph [bgcolor="#00000000"] node [shape=rectangle style=filled fillcolor="#FFFFFF" font=Helvetica padding=2] edge [color="#1414CE"] "23" [label="xlifepp::Collection< string_t >" tooltip="xlifepp::Collection< string_t >"] "16" [label="xlifepp::Matrix< real_t >" tooltip="xlifepp::Matrix< real_t >"] "20" [label="xlifepp::Vector< real_t >" tooltip="xlifepp::Vector< real_t >"] "31" [label="xlifepp::Vector< xlifepp::Vector< real_t > >" tooltip="xlifepp::Vector< xlifepp::Vector< real_t > >"] "40" [label="std::list< std::pair< number_t, real_t > >" tooltip="std::list< std::pair< number_t, real_t > >"] "12" [label="std::map< number_t, std::vector< number_t > >" tooltip="std::map< number_t, std::vector< number_t > >"] "10" [label="std::map< number_t, xlifepp::Geometry * >" tooltip="std::map< number_t, xlifepp::Geometry * >"] "39" [label="std::map< string_t, number_t >" tooltip="std::map< string_t, number_t >"] "41" [label="std::list< T >" tooltip="std::list< T >"] "11" [label="std::map< K, T >" tooltip="std::map< K, T >"] "7" [label="std::vector< T >" tooltip="std::vector< T >"] "26" [label="std::vector< T >" tooltip="std::vector< T >"] "19" [label="std::vector< K >" tooltip="std::vector< K >"] "6" [label="std::vector< RealPair >" tooltip="std::vector< RealPair >"] "22" [label="std::vector< const xlifepp::Transformation * >" tooltip="std::vector< const xlifepp::Transformation * >"] "27" [label="std::vector< number_t >" tooltip="std::vector< number_t >"] "17" [label="std::vector< real_t >" tooltip="std::vector< real_t >"] "36" [label="std::vector< std::vector< GeoNumPair > >" tooltip="std::vector< std::vector< GeoNumPair > >"] "13" [label="std::vector< std::vector< int_t > >" tooltip="std::vector< std::vector< int_t > >"] "24" [label="std::vector< string_t >" tooltip="std::vector< string_t >"] "35" [label="std::vector< xlifepp::GeomDomain * >" tooltip="std::vector< xlifepp::GeomDomain * >"] "34" [label="std::vector< xlifepp::GeomElement * >" tooltip="std::vector< xlifepp::GeomElement * >"] "38" [label="std::vector< xlifepp::Parameter * >" tooltip="std::vector< xlifepp::Parameter * >"] "9" [label="std::vector< xlifepp::Point >" tooltip="std::vector< xlifepp::Point >"] "28" [label="std::vector< xlifepp::Transformation * >" tooltip="std::vector< xlifepp::Transformation * >"] "32" [label="std::vector< xlifepp::Vector< real_t > >" tooltip="std::vector< xlifepp::Vector< real_t > >"] "5" [label="xlifepp::BoundingBox" tooltip="xlifepp::BoundingBox"] "25" [label="xlifepp::Collection< T >" tooltip="xlifepp::Collection< T >"] "14" [label="xlifepp::ExtrusionData" tooltip="xlifepp::ExtrusionData"] "42" [label="xlifepp::GeoNode" tooltip="xlifepp::GeoNode"] "4" [label="xlifepp::Geometry" tooltip="xlifepp::Geometry"] "18" [label="xlifepp::Matrix< K >" tooltip="xlifepp::Matrix< K >"] "33" [label="xlifepp::Mesh" tooltip="xlifepp::Mesh"] "8" [label="xlifepp::MinimalBox" tooltip="xlifepp::MinimalBox"] "37" [label="xlifepp::Parameters" tooltip="xlifepp::Parameters"] "30" [label="xlifepp::Parametrization" tooltip="xlifepp::Parametrization"] "29" [label="xlifepp::Point" tooltip="xlifepp::Point"] "2" [label="xlifepp::Polygon" tooltip="xlifepp::Polygon"] "3" [label="xlifepp::Surface" tooltip="xlifepp::Surface"] "15" [label="xlifepp::Transformation" tooltip="xlifepp::Transformation"] "1" [label="xlifepp::Triangle" tooltip="xlifepp::Triangle" fillcolor="#BFBFBF"] "21" [label="xlifepp::Vector< K >" tooltip="xlifepp::Vector< K >"] "23" -> "24" [dir=forward tooltip="public-inheritance"] "23" -> "25" [dir=forward tooltip="template-instance"] "16" -> "17" [dir=forward tooltip="public-inheritance"] "16" -> "18" [dir=forward tooltip="template-instance"] "20" -> "17" [dir=forward tooltip="public-inheritance"] "20" -> "21" [dir=forward tooltip="template-instance"] "31" -> "32" [dir=forward tooltip="public-inheritance"] "31" -> "21" [dir=forward tooltip="template-instance"] "40" -> "41" [dir=forward tooltip="template-instance"] "12" -> "11" [dir=forward tooltip="template-instance"] "10" -> "11" [dir=forward tooltip="template-instance"] "39" -> "11" [dir=forward tooltip="template-instance"] "19" -> "7" [dir=forward tooltip="template-instance"] "6" -> "7" [dir=forward tooltip="template-instance"] "22" -> "7" [dir=forward tooltip="template-instance"] "27" -> "7" [dir=forward tooltip="template-instance"] "17" -> "7" [dir=forward tooltip="template-instance"] "36" -> "7" [dir=forward tooltip="template-instance"] "13" -> "7" [dir=forward tooltip="template-instance"] "24" -> "7" [dir=forward tooltip="template-instance"] "35" -> "7" [dir=forward tooltip="template-instance"] "34" -> "7" [dir=forward tooltip="template-instance"] "38" -> "7" [dir=forward tooltip="template-instance"] "9" -> "7" [dir=forward tooltip="template-instance"] "28" -> "7" [dir=forward tooltip="template-instance"] "32" -> "7" [dir=forward tooltip="template-instance"] "5" -> "6" [dir=forward tooltip="usage"] "25" -> "26" [dir=forward tooltip="public-inheritance"] "14" -> "15" [dir=forward tooltip="usage"] "14" -> "23" [dir=forward tooltip="usage"] "14" -> "27" [dir=forward tooltip="usage"] "14" -> "17" [dir=forward tooltip="usage"] "14" -> "20" [dir=forward tooltip="usage"] "14" -> "28" [dir=forward tooltip="usage"] "14" -> "29" [dir=forward tooltip="usage"] "42" -> "42" [dir=forward tooltip="usage"] "42" -> "4" [dir=forward tooltip="usage"] "4" -> "5" [dir=forward tooltip="usage"] "4" -> "8" [dir=forward tooltip="usage"] "4" -> "10" [dir=forward tooltip="usage"] "4" -> "12" [dir=forward tooltip="usage"] "4" -> "13" [dir=forward tooltip="usage"] "4" -> "14" [dir=forward tooltip="usage"] "4" -> "30" [dir=forward tooltip="usage"] "4" -> "4" [dir=forward tooltip="usage"] "4" -> "42" [dir=forward tooltip="usage"] "18" -> "19" [dir=forward tooltip="public-inheritance"] "33" -> "4" [dir=forward tooltip="usage"] "33" -> "9" [dir=forward tooltip="usage"] "33" -> "34" [dir=forward tooltip="usage"] "33" -> "35" [dir=forward tooltip="usage"] "33" -> "27" [dir=forward tooltip="usage"] "33" -> "36" [dir=forward tooltip="usage"] "33" -> "33" [dir=forward tooltip="usage"] "8" -> "9" [dir=forward tooltip="usage"] "37" -> "38" [dir=forward tooltip="usage"] "37" -> "39" [dir=forward tooltip="usage"] "30" -> "4" [dir=forward tooltip="usage"] "30" -> "20" [dir=forward tooltip="usage"] "30" -> "31" [dir=forward tooltip="usage"] "30" -> "33" [dir=forward tooltip="usage"] "30" -> "37" [dir=forward tooltip="usage"] "30" -> "40" [dir=forward tooltip="usage"] "29" -> "17" [dir=forward tooltip="public-inheritance"] "2" -> "3" [dir=forward tooltip="public-inheritance"] "3" -> "4" [dir=forward tooltip="public-inheritance"] "3" -> "9" [dir=forward tooltip="usage"] "3" -> "17" [dir=forward tooltip="usage"] "3" -> "27" [dir=forward tooltip="usage"] "15" -> "16" [dir=forward tooltip="usage"] "15" -> "20" [dir=forward tooltip="usage"] "15" -> "22" [dir=forward tooltip="usage"] "1" -> "2" [dir=forward tooltip="public-inheritance"] "21" -> "19" [dir=forward tooltip="public-inheritance"] }

definition of a triangular geometry in R^3

Triangle constructors are based on a key-value system. Here are the available keys:

  • _v1, _v2, _v3: to define the vertices of the triangle, counterclockwise oriented

  • _nnodes: to define the number of nodes on each edge of the Triangle

  • _hsteps: to define the local mesh steps on the vertices of the Triangle

  • _domain_name: to define the domain name

  • _side_names: to define the side names

  • _varnames: to define the variable names for print purpose

Public Functions

Triangle()#

default constructor

default triangle is (0,0) (1,0) (0,1), parametrization not allocated

Triangle(const Point &p1, const Point &p2, const Point &p3, const std::vector<number_t> &n = std::vector<number_t>(3, 2), const string_t &domName = string_t())#

default constructor with 3 Point

Triangle(const Point &p1, const Point &p2, const Point &p3, const std::vector<real_t> &h, const string_t &domName = string_t())#

default constructor with 3 Point

Triangle(Parameter p1, Parameter p2, Parameter p3)#

constructor with 3 Parameter

Triangle(Parameter p1, Parameter p2, Parameter p3, Parameter p4)#

constructor with 4 Parameter

Triangle(Parameter p1, Parameter p2, Parameter p3, Parameter p4, Parameter p5)#

constructor with 5 Parameter

Triangle(Parameter p1, Parameter p2, Parameter p3, Parameter p4, Parameter p5, Parameter p6)#

constructor with 6 Parameter

inline virtual ~Triangle()#

destructor

virtual string_t asString() const#

format as string

inline virtual Geometry *clone() const#

virtual copy constructor for Geometry

inline virtual Polygon *clonePG() const#

virtual copy constructor for Polygon

inline virtual Surface *cloneS() const#

virtual copy constructor for Surface

Vector<real_t> duffyParametrization(const Point &pt, Parameters &pars, DiffOpType d = _id) const#

duffy parametrization on [0,1]x[0,1]

Duffy parametrization: p=(1-u)*p1+u(1-v)*p2+uv*p3 with 0<= u,v <=1 u=0, 0<=v<=1 -> p1 u=1, 0<=v<=1 -> [p2,p3] v=0, 0<=u<=1 -> [p1,p2] v=1, 0<=u<=1 -> [p1,p3].

Vector<real_t> funParametrization(const Point &pt, Parameters &pars, DiffOpType d = _id) const#

barycentric parametrization (1-u-v)*p1+u*p2+v*p3

parametrization (P1) : p = (1-u-v)*p1+u*p2+v*p3 = p1+u*(p2-p1)+v*(p3-p1) with 0<= u+v <=1

inline virtual Triangle &homothetize(const Parameter &p1)#

apply a homothety on a Triangle (1 key)

inline virtual Triangle &homothetize(const Parameter &p1, const Parameter &p2)#

apply a homothety on a Triangle (2 keys)

inline virtual Triangle &homothetize(const Point &c = Point(0., 0., 0.), real_t factor = 1.)#

apply a homothety on a Triangle

inline virtual Triangle &homothetize(real_t factor)#

apply a homothety on a Triangle

Vector<real_t> invDuffyParametrization(const Point &pt, Parameters &pars, DiffOpType d = _id) const#

inverse of duffy parametrization u,v)=invf(p)

inverse of Duffy parametrization u =( p-p1).o32 / (p2-p1).o32 with o32 any orthogonal vector to p3-p2 uv = (p-p1).o21 / (p3-p2).o21 with o21 any orthogonal vector to p2-p if p=p1 then u=0 and v may be anything

Vector<real_t> invParametrization(const Point &pt, Parameters &pars, DiffOpType d = _id) const#

inverse of barycentric parametrization (u,v)=invf(p)

inverse of parametrization (u,v)=invf(p)

virtual real_t measure() const#

return the length/area/volume of the geometry

inline virtual number_t nbSides() const#

returns the number of sides

inline virtual Triangle &pointReflect(const Parameter &p1)#

apply a point reflection on a Triangle (1 key)

inline virtual Triangle &pointReflect(const Point &c = Point(0., 0., 0.))#

apply a point reflection on a Triangle

inline virtual Triangle &reflect2d(const Parameter &p1)#

apply a reflection2d on a Triangle (1 key)

inline virtual Triangle &reflect2d(const Parameter &p1, const Parameter &p2)#

apply a reflection2d on a Triangle (2 keys)

inline virtual Triangle &reflect2d(const Point &c, real_t dx, real_t dy = 0.)#

apply a reflection2d on a Triangle

inline virtual Triangle &reflect2d(const Point &c = Point(0., 0.), std::vector<real_t> d = std::vector<real_t>(2, 0.))#

apply a reflection2d on a Triangle

inline virtual Triangle &reflect3d(const Parameter &p1)#

apply a reflection3d on a Triangle (1 key)

inline virtual Triangle &reflect3d(const Parameter &p1, const Parameter &p2)#

apply a reflection3d on a Triangle (2 keys)

inline virtual Triangle &reflect3d(const Point &c, real_t nx, real_t ny, real_t nz = 0.)#

apply a reflection3d on a Triangle

inline virtual Triangle &reflect3d(const Point &c = Point(0., 0., 0.), std::vector<real_t> n = std::vector<real_t>(3, 0.))#

apply a reflection3d on a Triangle

inline virtual Triangle &rotate2d(const Parameter &p1)#

apply a rotation 2D on a Triangle (1 key)

inline virtual Triangle &rotate2d(const Parameter &p1, const Parameter &p2)#

apply a rotation 2D on a Triangle (2 keys)

inline virtual Triangle &rotate2d(const Point &c, real_t angle = 0.)#

apply a rotation 2D on a Triangle

inline virtual Triangle &rotate3d(const Parameter &p1)#

apply a rotation 3D on a Triangle (1 key)

inline virtual Triangle &rotate3d(const Parameter &p1, const Parameter &p2)#

apply a rotation 3D on a Triangle (2 keys)

inline virtual Triangle &rotate3d(const Parameter &p1, const Parameter &p2, const Parameter &p3)#

apply a rotation 3D on a Triangle (3 keys)

inline virtual Triangle &rotate3d(const Point &c, real_t dx, real_t dy, real_t angle)#

apply a rotation on a Triangle

inline virtual Triangle &rotate3d(const Point &c, real_t dx, real_t dy, real_t dz, real_t angle)#

apply a rotation on a Triangle

inline virtual Triangle &rotate3d(const Point &c, std::vector<real_t> d = std::vector<real_t>(3, 0.), real_t angle = 0.)#

apply a rotation 3D on a Triangle

inline virtual Triangle &rotate3d(real_t dx, real_t dy, real_t angle)#

apply a rotation 3D on a Triangle

inline virtual Triangle &rotate3d(real_t dx, real_t dy, real_t dz, real_t angle)#

apply a rotation 3D on a Triangle

virtual std::vector<std::pair<ShapeType, std::vector<const Point*>>> surfs() const#

return list of surfaces (const)

virtual Triangle &transform(const Transformation &t)#

apply a geometrical transformation on a Triangle

inline virtual Triangle &translate(const Parameter &p1)#

apply a translation on a Triangle (1 key)

inline virtual Triangle &translate(real_t ux, real_t uy = 0., real_t uz = 0.)#

apply a translation on a Triangle (3 reals version)

inline virtual Triangle &translate(std::vector<real_t> u)#

apply a translation on a Triangle (vector version)

inline virtual Triangle *triangle()#

access to child Triangle object

inline virtual const Triangle *triangle() const#

access to child Triangle object (const)