Class xlifepp::ParametrizedGeodesic#

class ParametrizedGeodesic : public xlifepp::Geodesic#

Inheritence diagram for xlifepp::ParametrizedGeodesic:

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

Collaboration diagram for xlifepp::ParametrizedGeodesic:

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

ParametrizedGeodesic class handling any geodesic got using surface parametrization require a GeomDomain or a Geometry or a Parametrization in any case, it constructs geodesic using a RK4 scheme to solve the geodesic EDO dt(x(t),y(t))=F(x(t),y(t)) x(t)=x0, y(t)=y(0) F function (involving Cristoffel symbols) is based on a Parametrization When the Parametrization is a PiecewiseParametrization, the computation is done using an iterative process to go from one parametrization to the other.

Public Functions

inline ParametrizedGeodesic()#

vector of geodesic tangent vectors in 2D parametrization space

bool checkBound(Point &p, const Parametrization &par, real_t tol = 0) const#

tool to check if p in [0,1]x[0,1], project p along op

bool checkBound(Point &p, const Point &o, const Parametrization &par, real_t tol = 0) const#

function involved when solving geodesic equation x” = F(x,x’)

Geodesic &compute(const Parametrization &par, Point &uv, Point &duv, real_t &l, real_t lmax, number_t &k, number_t n, real_t dt)#

compute geodesic from x, dx (entry)

virtual Geodesic &compute(Point &x, Point &dx, real_t &l, real_t lmax, number_t n, real_t dt = 0)#

tool to check if p in [0,1]x[0,1], project p along axis

Geodesic &computePiecewise(Point &x, Point &dx, real_t &l, real_t lmax, number_t n, real_t dt = 0)#

compute geodesic from x, dx (global parametrization)

Point F(const Point &u, const Point &du, const Parametrization *par = nullptr) const#

clear xs_,dxs_,curAbcs

inline virtual string_t strtype() const#

compute geodesic from x, dx (piecewise parametrization)

Public Members

std::vector<Point> dus_#

vector of geodesic points in 2D parametrization space