Class GooseFEM::Vector#

class Vector#

Class to switch between storage types.

In particular:

  • “dofval”: DOF values [ndof].

  • ”nodevec”: nodal vectors [nnode, ndim].

  • ”elemvec”: nodal vectors stored per element [nelem, nne, ndim].

Subclassed by GooseFEM::VectorPartitioned, GooseFEM::VectorPartitionedTyings

Public Functions

template<class S, class T>
inline Vector(const S &conn, const T &dofs)#

Constructor.

Parameters
inline size_t nelem() const#
Returns

Number of elements.

inline size_t nne() const#
Returns

Number of nodes per element.

inline size_t nnode() const#
Returns

Number of nodes.

inline size_t ndim() const#
Returns

Number of dimensions.

inline size_t ndof() const#
Returns

Number of DOFs.

inline const array_type::tensor<size_t, 2> &conn() const#
Returns

Connectivity (nodes per element) [nelem, nne].

inline const array_type::tensor<size_t, 2> &dofs() const#
Returns

DOFs per node [nnode, ndim]

template<class T>
inline T Copy(const T &nodevec_src, const T &nodevec_dest) const#

Copy “nodevec” to another “nodevec”.

Parameters
Returns

nodevec output [nnode, ndim]

template<class T>
inline void copy(const T &nodevec_src, T &nodevec_dest) const#

Copy “nodevec” to another “nodevec”.

Parameters
template<class T>
inline array_type::tensor<double, 1> AsDofs(const T &arg) const#

Convert “nodevec” or “elemvec” to “dofval” (overwrite entries that occur more than once).

Parameters

arg – nodevec [nnode, ndim] or elemvec [nelem, nne, ndim]

Returns

dofval [ndof]

template<class T, class R>
inline void asDofs(const T &arg, R &ret) const#

Convert “nodevec” or “elemvec” to “dofval” (overwrite entries that occur more than once).

Parameters
template<class T>
inline array_type::tensor<double, 2> AsNode(const T &arg) const#

Convert “dofval” or “elemvec” to “nodevec” (overwrite entries that occur more than once).

Parameters

arg – dofval [ndof] or elemvec [nelem, nne, ndim]

Returns

nodevec output [nnode, ndim]

template<class T, class R>
inline void asNode(const T &arg, R &ret) const#

Convert “dofval” or “elemvec” to “nodevec” (overwrite entries that occur more than once).

Parameters
template<class T>
inline array_type::tensor<double, 3> AsElement(const T &arg) const#

Convert “dofval” or “nodevec” to “elemvec” (overwrite entries that occur more than once).

Parameters

arg – dofval [ndof] or nodevec [nnode, ndim].

Returns

elemvec output [nelem, nne, ndim].

template<class T, class R>
inline void asElement(const T &arg, R &ret) const#

Convert “dofval” or “nodevec” to “elemvec” (overwrite entries that occur more than once).

Parameters
template<class T>
inline array_type::tensor<double, 1> AssembleDofs(const T &arg) const#

Assemble “nodevec” or “elemvec” to “dofval” (adds entries that occur more that once).

Parameters

arg – nodevec [nnode, ndim] or elemvec [nelem, nne, ndim]

Returns

dofval output [ndof]

template<class T, class R>
inline void assembleDofs(const T &arg, R &ret) const#

Assemble “nodevec” or “elemvec” to “dofval” (adds entries that occur more that once).

Parameters
template<class T>
inline array_type::tensor<double, 2> AssembleNode(const T &arg) const#

Assemble “elemvec” to “nodevec” (adds entries that occur more that once.

Parameters

arg – elemvec [nelem, nne, ndim]

Returns

nodevec output [nnode, ndim]

template<class T, class R>
inline void assembleNode(const T &arg, R &ret) const#

Assemble “elemvec” to “nodevec” (adds entries that occur more that once.

Parameters
inline std::array<size_t, 1> shape_dofval() const#

Shape of “dofval”.

Returns

[ndof]

inline std::array<size_t, 2> shape_nodevec() const#

Shape of “nodevec”.

Returns

[nnode, ndim]

inline std::array<size_t, 3> shape_elemvec() const#

Shape of “elemvec”.

Returns

[nelem, nne, ndim]

inline std::array<size_t, 3> shape_elemmat() const#

Shape of “elemmat”.

Returns

[nelem, nne * ndim, nne * ndim]

inline array_type::tensor<double, 1> allocate_dofval() const#

Allocated “dofval”.

Returns

[ndof]

inline array_type::tensor<double, 1> allocate_dofval(double val) const#

Allocated and initialised “dofval”.

Parameters

val – value to which to initialise.

Returns

[ndof]

inline array_type::tensor<double, 2> allocate_nodevec() const#

Allocated “nodevec”.

Returns

[nnode, ndim]

inline array_type::tensor<double, 2> allocate_nodevec(double val) const#

Allocated and initialised “nodevec”.

Parameters

val – value to which to initialise.

Returns

[nnode, ndim]

inline array_type::tensor<double, 3> allocate_elemvec() const#

Allocated “elemvec”.

Returns

[nelem, nne, ndim]

inline array_type::tensor<double, 3> allocate_elemvec(double val) const#

Allocated and initialised “elemvec”.

Parameters

val – value to which to initialise.

Returns

[nelem, nne, ndim]

inline array_type::tensor<double, 3> allocate_elemmat() const#

Allocated “elemmat”.

Returns

[nelem, nne * ndim, nne * ndim]

inline array_type::tensor<double, 3> allocate_elemmat(double val) const#

Allocated and initialised “elemmat”.

Parameters

val – value to which to initialise.

Returns

[nelem, nne * ndim, nne * ndim]