20 #ifndef TRILINEAR_3D_H 21 #define TRILINEAR_3D_H 23 #ifndef SHEAF_DLL_SPEC_H 24 #include "SheafSystem/sheaf_dll_spec.h" 27 #ifndef LINEAR_FCN_SPACE_H 28 #include "SheafSystem/linear_fcn_space.h" 66 double inverse_jacobian(
const double xjacobian[3][3],
67 double xinverse_jacobian[3][3]);
86 enum static_const_int {DL = 8};
91 value_type _basis_value_buffer[DL];
96 value_type _basis_deriv_value_buffer[3*DL];
102 value_type _jacobian_value_buffer[128];
119 virtual int dl()
const;
124 virtual void basis_at_coord(
const dof_type xlocal_coord[],
size_type xlocal_coord_ub);
129 void basis_derivs_at_coord(
const dof_type xlocal_coords[],
148 value_type jacobian_determinant(
const dof_type xcoord_dofs[],
157 value_type volume(
const dof_type xcoord_dofs[],
164 virtual void integrate(
const dof_type xcoord_dofs[],
169 value_type xresult_integrals[],
175 virtual void integrate(
const dof_type xcoord_dofs[],
179 value_type xresult_integrals[],
206 void dxi_local(
size_type xlocal_coord_index,
215 void jacobian(
const dof_type xcoord_dofs[],
247 virtual int db()
const;
260 virtual bool in_standard_domain(
const dof_type xlocal_coords[],
281 virtual void coord_at_value(
const dof_type xdofs[],
319 virtual bool invariant()
const;
324 virtual bool is_ancestor_of(
const any* xother)
const;
336 #endif // ifndef TRILINEAR_3D_H sec_vd_dof_type dof_type
The type of degree of freedom.
Abstract base class with useful features for all objects.
A section evaluator using trilinear interpolation over a cubic 3D domain.
An abstract integrable section evaluator which is a member of a linear function space.
unsigned long size_type
An unsigned integral type used to represent sizes and capacities.
chart_point_coord_type coord_type
The type of local coordinate; the scalar type for the local coordinate vector space.
An abstract local section evaluator; a map from {local coordinates x dofs} to section value...
int_type pod_index_type
The plain old data index type.
Namespace for the fiber_bundles component of the sheaf system.