G+Smo  25.01.0
Geometry + Simulation Modules
 
Loading...
Searching...
No Matches
gsBulk.h
Go to the documentation of this file.
1
14#pragma once
15
16namespace gismo
17{
18
27template<class T>
28class gsBulk : public gsGeometry<T>
29{
30
31public:
33 typedef memory::shared_ptr< gsBulk > Ptr;
34
36 typedef memory::unique_ptr< gsBulk > uPtr;
37
38 typedef T Scalar_t;
39public:
40
43
45 gsBulk() : gsGeometry<T>() { }
46
51 {
52 GISMO_ASSERT( this->m_coefs.size() >= 1,
53 "Coefficient matrix cannot be empty.\n");
54 // GISMO_ASSERT( coefs.cols() >= 2,
55 // "Surface must be embedded in dimension at least two.\n");
56 }
57
59
60 GISMO_UPTR_FUNCTION_PURE(gsBulk, clone)
61
62 short_t domainDim() const { return 4; }
63
64}; // class gsBulk
65
66} // namespace gismo
67
68
69#ifndef GISMO_BUILD_LIB
70#include GISMO_HPP_HEADER(gsBulk.hpp)
71#endif
A basis represents a family of scalar basis functions defined over a common parameter domain.
Definition gsBasis.h:79
Abstract base class representing a 4D bulk.
Definition gsBulk.h:29
memory::shared_ptr< gsBulk > Ptr
Shared pointer for gsBulk.
Definition gsBulk.h:33
memory::unique_ptr< gsBulk > uPtr
Unique pointer for gsBulk.
Definition gsBulk.h:36
short_t domainDim() const
Dimension d of the parameter domain (overriding gsFunction::domainDim()).
Definition gsBulk.h:62
gsBulk(const gsBasis< T > &basis, gsMatrix< T > coefs)
Definition gsBulk.h:49
gsBulk()
Default empty constructor.
Definition gsBulk.h:45
uPtr clone()
Clone methode. Produceds a deep copy inside a uPtr.
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
#define short_t
Definition gsConfig.h:35
#define GISMO_ASSERT(cond, message)
Definition gsDebug.h:89
The G+Smo namespace, containing all definitions for the library.
S give(S &x)
Definition gsMemory.h:266