42 : neudata_ptr( bc.function().get() ), side(bc.side())
50 : neudata_ptr(&neudata), side(s)
59 for (
int i = 0; i < basis.dim(); ++i)
60 numQuadNodes[i] = basis.
degree(i) + 1;
61 numQuadNodes[dir] = 1;
96 numActive = actives.rows();
105 neudata_ptr->eval_into(md.values[0], neuData);
108 localRhs.setZero(numActive, neudata_ptr->targetDim() );
115 for (
index_t k = 0; k < quWeights.rows(); ++k)
118 outerNormal(md, k, side, unormal);
121 const T weight = quWeights[k] * unormal.norm();
124 transformGradients(md, k, basisGrads, physBasisGrad);
126 localRhs.noalias() += weight *(( physBasisGrad.transpose() * unormal )* neuData.col(k).transpose());
Abstract base class representing a geometry map.
Definition: gsGeometry.h:92
Class representing a reference quadrature rule.
Definition: gsQuadRule.h:28
void mapColIndices(const gsMatrix< index_t > &actives, const index_t patchIndex, gsMatrix< index_t > &result, const index_t c=0) const
mapColIndices Maps a set of basis indices by the corresponding dofMapper.
Definition: gsSparseSystem.h:584
virtual void computeMap(gsMapData< T > &InOut) const
Computes map function data.
Definition: gsFunction.hpp:822
virtual short_t degree(short_t i) const
Degree with respect to the i-th variable. If the basis is a tensor product of (piecewise) polynomial ...
Definition: gsBasis.hpp:650
the gsMapData is a cache of pre-computed function (map) values.
Definition: gsFuncData.h:324
Abstract class representing a PDE (partial differential equation).
Definition: gsPde.h:43
#define index_t
Definition: gsConfig.h:32
A function from a n-dimensional domain to an m-dimensional image.
Definition: gsFunction.h:59
const index_t & getInt(const std::string &label) const
Reads value for option label from options.
Definition: gsOptionList.cpp:37
void assemble(gsDomainIterator< T > &, gsVector< T > const &quWeights)
Assemble on element.
Definition: gsVisitorNeumannBiharmonic.h:112
Class which enables iteration over all elements of a parameter domain.
Definition: gsDomainIterator.h:67
void initialize(const gsBasis< T > &basis, const index_t, const gsOptionList &options, gsQuadRule< T > &rule)
Initialize.
Definition: gsVisitorNeumannBiharmonic.h:72
void localToGlobal(const index_t patchIndex, const std::vector< gsMatrix< T > > &, gsSparseSystem< T > &system)
Adds the contributions to the sparse system.
Definition: gsVisitorNeumannBiharmonic.h:131
Interface for the set of functions defined on a domain (the total number of functions in the set equa...
Definition: gsFuncData.h:23
gsVisitorNeumannBiharmonic(const gsFunction< T > &neudata, boxSide s)
Constructor.
Definition: gsVisitorNeumannBiharmonic.h:49
Struct which represents a certain side of a box.
Definition: gsBoundary.h:84
The density of the measure pull back.
Definition: gsForwardDeclarations.h:76
gsVisitorNeumannBiharmonic(const gsPde< T > &pde, const boundary_condition< T > &bc)
Constructor.
Definition: gsVisitorNeumannBiharmonic.h:41
Class that defines a boundary condition for a side of a patch for some unknown variable of a PDE...
Definition: gsBoundaryConditions.h:106
Visitor for Neumann boundary condition for the biharmonic equation.
Definition: gsVisitorNeumannBiharmonic.h:33
void pushToRhs(const gsMatrix< T > &localRhs, const gsMatrix< index_t > &actives, const size_t r=0)
pushToRhs pushes the local rhs for an element to the global system
Definition: gsSparseSystem.h:884
Value of the object.
Definition: gsForwardDeclarations.h:72
#define GISMO_UNUSED(x)
Definition: gsDebug.h:112
Gradient transformation matrix.
Definition: gsForwardDeclarations.h:77
Class which holds a list of parameters/options, and provides easy access to them. ...
Definition: gsOptionList.h:32
void evaluate(const gsBasis< T > &basis, const gsGeometry< T > &geo, gsMatrix< T > &quNodes)
Evaluate on element.
Definition: gsVisitorNeumannBiharmonic.h:87
Class that represents the (tensor) Gauss-Legendre quadrature rule.
Definition: gsGaussRule.h:27
void initialize(const gsBasis< T > &basis, gsQuadRule< T > &rule)
Initialize.
Definition: gsVisitorNeumannBiharmonic.h:54
virtual void deriv_into(const gsMatrix< T > &u, gsMatrix< T > &result) const
Evaluates the first partial derivatives of the nonzero basis function.
Definition: gsBasis.hpp:451
short_t direction() const
Returns the parametric direction orthogonal to this side.
Definition: gsBoundary.h:113
A basis represents a family of scalar basis functions defined over a common parameter domain...
Definition: gsBasis.h:78
Real getReal(const std::string &label) const
Reads value for option label from options.
Definition: gsOptionList.cpp:44
virtual void active_into(const gsMatrix< T > &u, gsMatrix< index_t > &result) const
Returns the indices of active basis functions at points u, as a list of indices, in result...
Definition: gsBasis.hpp:293