35 typedef memory::shared_ptr< gsSurface >
Ptr;
38 typedef memory::unique_ptr< gsSurface >
uPtr;
55 "Coefficient matrix cannot be empty.\n");
63private:
virtual gsSurface * clone_impl()
const = 0;
64public:
inline uPtr clone()
const {
return uPtr(clone_impl()); }
68 void toMesh(
gsMesh<T> & msh,
int npoints = 625)
const;
75#ifndef GISMO_BUILD_LIB
76#include GISMO_HPP_HEADER(gsSurface.hpp)
A basis represents a family of scalar basis functions defined over a common parameter domain.
Definition gsBasis.h:79
Abstract base class representing a geometry map.
Definition gsGeometry.h:93
gsMatrix< T > & coefs()
Definition gsGeometry.h:340
virtual const gsBasis< T > & basis() const =0
Returns a const reference to the basis of the geometry.
gsMatrix< T > m_coefs
Coefficient matrix of size coefsSize() x geoDim()
Definition gsGeometry.h:629
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
Abstract base class representing a surface.
Definition gsSurface.h:31
memory::shared_ptr< gsSurface > Ptr
Shared pointer for gsSurface.
Definition gsSurface.h:35
gsSurface(const gsBasis< T > &basis, gsMatrix< T > coefs)
Definition gsSurface.h:51
short_t domainDim() const
Dimension d of the parameter domain (overriding gsFunction::domainDim()).
Definition gsSurface.h:66
memory::unique_ptr< gsSurface > uPtr
Unique pointer for gsSurface.
Definition gsSurface.h:38
gsSurface()
Default empty constructor.
Definition gsSurface.h:47
#define short_t
Definition gsConfig.h:35
#define GISMO_ASSERT(cond, message)
Definition gsDebug.h:89
Provides declaration of Geometry abstract interface.
The G+Smo namespace, containing all definitions for the library.
S give(S &x)
Definition gsMemory.h:266