52 typedef std::vector<Point2D, typename Point2D::aalloc> VectorType;
54 typedef memory::shared_ptr<gsParametrization<T> > uPtr;
101 real_t = 0, real_t = 1)
const
106 gsParametrization<T>& setOptions(
const gsOptionList& list);
148 const size_t vertexIndex,
149 const bool innerVertex = 1);
238 const size_t parametrizationMethod = 2);
304 const size_t parametrizationMethod = 2);
313 const std::vector<T> &
getLambdas(
const size_t i)
const;
322 const std::vector<index_t>
323 getBoundaryCorners(
const size_t method,
const T range = 0.1,
const size_t number = 4)
const;
328 static const Point2D findPointOnBoundary(T w,
size_t index);
331 std::vector<T> midpoints(
const size_t numberOfCorners,
const T length)
const;
332 void searchAreas(
const T range,
333 std::vector<std::pair<T, size_t> > &sortedAngles,
334 std::vector<index_t> &corners)
const;
335 void takeCornersWithSmallestAngles(
size_t number,
336 std::vector<std::pair<T, size_t> > &sortedAngles,
337 std::vector<index_t> &corners)
const;
341 std::vector<LocalParametrization> m_localParametrizations;
342 std::vector<LocalNeighbourhood> m_localBoundaryNeighbourhoods;
372 std::vector<size_t> indices(
const gsMatrix<T>& vertices)
const
374 std::vector<size_t> result;
375 GISMO_ASSERT(vertices.rows() == 3,
"three rows expected in vertices");
376 for(
index_t c=0; c<vertices.cols(); c++)
378 result.push_back(
m_mesh.findVertex(vertices(0, c), vertices(1, c), vertices(2, c),
true));
383 void calculate(
const size_t boundaryMethod,
384 const size_t paraMethod,
385 const std::vector<index_t> &cornersInput,
387 const size_t numberInput);
389 T findLengthOfPositionPart(
const size_t position,
390 const size_t numberOfPositions,
391 const std::vector<index_t> &bounds,
392 const std::vector<T> &lengths);
394 bool rangeCheck(
const std::vector<index_t> &corners,
const size_t minimum,
const size_t maximum);
398 const gsHalfEdgeMesh<T> & mesh()
const {
return m_mesh;}
400 const VectorType & pointParameters()
const
409#ifndef GISMO_BUILD_LIB
410#include GISMO_HPP_HEADER(gsParametrization.hpp)
Class that maintains chain of halfedges.
Definition gsHalfEdgeMesh.h:157
gsHalfEdgeMesh is a gsMesh implementation that handles Halfedges
Definition gsHalfEdgeMesh.h:47
A matrix with arbitrary coefficient type and fixed or dynamic size.
Definition gsMatrix.h:41
Class Representing a triangle mesh with 3D vertices.
Definition gsMesh.h:32
Class which holds a list of parameters/options, and provides easy access to them.
Definition gsOptionList.h:33
Class that maintains the local neighbourhood properties.
Definition gsParametrization.h:128
gsHalfEdgeMesh< T >::Chain m_neighbours
chain of neighbours
Definition gsParametrization.h:207
size_t getVertexIndex() const
Get vertex index.
Definition gsParametrization.hpp:742
size_t m_vertexIndex
vertex index
Definition gsParametrization.h:206
size_t getNumberOfNeighbours() const
Get number of neighbours.
Definition gsParametrization.hpp:748
T getInnerAngle() const
Get inner angle.
Definition gsParametrization.hpp:766
std::list< T > m_angles
list of angles between neighbours
Definition gsParametrization.h:208
std::list< T > getNeighbourDistances() const
Get neighbour distances.
Definition gsParametrization.hpp:777
const std::list< T > & getAngles() const
Get angles.
Definition gsParametrization.hpp:760
const std::list< size_t > getVertexIndicesOfNeighbours() const
Get vertex indices of neighbours.
Definition gsParametrization.hpp:754
std::list< T > m_neighbourDistances
list of distances to neighbours
Definition gsParametrization.h:209
Class maintains local parametrization This class represents a local parametrization for a point in th...
Definition gsParametrization.h:222
const std::vector< T > & getLambdas() const
Get lambdas The lambdas are returned.
Definition gsParametrization.hpp:607
size_t m_vertexIndex
vertex index
Definition gsParametrization.h:258
std::vector< T > m_lambdas
lambdas
Definition gsParametrization.h:259
void calculateLambdas(const size_t N, VectorType &points)
Calculate lambdas The lambdas according to Floater's algorithm are calculated.
Definition gsParametrization.hpp:619
Class that maintains neighbourhood information of triangle mesh. Represents the neighbourhood propert...
Definition gsParametrization.h:286
const std::vector< index_t > getBoundaryCorners(const size_t method, const T range=0.1, const size_t number=4) const
Get boundary corners depending on the method.
Definition gsParametrization.hpp:288
const std::vector< T > & getLambdas(const size_t i) const
Get vector of lambdas.
Definition gsParametrization.hpp:282
Class that maintains parametrization This class Parametrization stores the mesh information and the t...
Definition gsParametrization.h:47
virtual gsMesh< T > createFlatMesh() const
Definition gsParametrization.hpp:188
virtual void restrictMatrices(gsMatrix< T > &, const gsMatrix< T > &, real_t=0, real_t=1) const
It might make sense in the derived classes to restrict the parameters to [0, 1]^2.
Definition gsParametrization.h:100
void writeTexturedMesh(std::string filename) const
Definition gsParametrization.hpp:207
void constructAndSolveEquationSystem(const Neighbourhood &neighbourhood, const size_t n, const size_t N)
Constructs linear equation system and solves it.
Definition gsParametrization.hpp:125
const Point2D & getParameterPoint(size_t vertexIndex) const
Get parameter point Returns the parameter point with given vertex index.
Definition gsParametrization.hpp:160
gsMatrix< T > createXYZmatrix()
Definition gsParametrization.hpp:177
virtual void compute()
Main function which performs the computation.
Definition gsParametrization.hpp:227
gsMatrix< T > createUVmatrix()
Definition gsParametrization.hpp:166
VectorType m_parameterPoints
parameter points
Definition gsParametrization.h:58
const gsHalfEdgeMesh< T > m_mesh
mesh information
Definition gsParametrization.h:57
static gsOptionList defaultOptions()
Returns the list of default options for gsParametrization.
Definition gsParametrization.hpp:35
A Point in T^d, with an index number.
Definition gsPoint.h:27
#define index_t
Definition gsConfig.h:32
#define GISMO_ASSERT(cond, message)
Definition gsDebug.h:89
Provides declaration of the gsHalfEdgeMesh class.
This is the main header file that collects wrappers of Eigen for linear algebra.
Provides a list of labeled parameters/options that can be set and accessed easily.
The G+Smo namespace, containing all definitions for the library.