Flow123d
DF_patch_fe_data_tables-3ffbd47
|
#include <patch_point_values.hh>
Public Member Functions | |
PatchPointValues (uint dim, AssemblyArena &asm_arena) | |
void | initialize (uint int_cols) |
void | init_finalize (PatchArena *patch_arena) |
void | reset () |
Reset number of columns (points and elements) More... | |
uint | dim () const |
Getter for dim_. More... | |
uint | n_rows () const |
Getter for n_rows_. More... | |
uint | n_elems () const |
Getter for n_elems_. More... | |
uint | n_points () const |
Getter for n_points_. More... | |
Quadrature * | get_quadrature () const |
Getter for quadrature. More... | |
void | resize_tables (uint n_elems, uint n_points) |
Resize data tables. Method is called before reinit of patch. More... | |
uint | register_element (arma::mat coords, uint element_patch_idx) |
uint | register_side (arma::mat elm_coords, arma::mat side_coords) |
uint | register_bulk_point (uint elem_table_row, uint value_patch_idx, uint elem_idx, uint i_point_on_elem) |
uint | register_side_point (uint elem_table_row, uint value_patch_idx, uint elem_idx, uint side_idx) |
ElOp< spacedim > & | make_new_op (std::initializer_list< uint > shape, ReinitFunction reinit_f, std::vector< uint > input_ops_vec, OpSizeType size_type=pointOp) |
ElOp< spacedim > & | make_fixed_op (std::initializer_list< uint > shape, ReinitFunction reinit_f) |
ElOp< spacedim > & | make_expansion (ElOp< spacedim > &el_op, std::initializer_list< uint > shape, ReinitFunction reinit_f) |
ElOp< spacedim > & | make_fe_op (std::initializer_list< uint > shape, ReinitFunction reinit_f, std::vector< uint > input_ops_vec, uint n_dofs, OpSizeType size_type=pointOp) |
void | reinit_patch () |
Scalar | scalar_val (uint result_row, uint point_idx) const |
Scalar | scalar_value (uint op_idx, uint point_idx, uint i_dof=0) const |
Vector | vector_val (uint result_row, uint point_idx) const |
Vector | vector_value (uint op_idx, uint point_idx, uint i_dof=0) const |
Tensor | tensor_val (uint result_row, uint point_idx) const |
Tensor | tensor_value (uint op_idx, uint point_idx, uint i_dof=0) const |
void | print_data_tables (ostream &stream, bool points, bool ints) const |
void | print_operations (ostream &stream, uint bulk_side) const |
Protected Attributes | |
TableDbl | point_vals_ |
TableInt | int_vals_ |
std::vector< ElOp< spacedim > > | operations_ |
Vector of all defined operations. More... | |
uint | dim_ |
Dimension. More... | |
uint | n_rows_ |
Number of columns of point_vals table. More... | |
uint | n_points_ |
Number of points in patch. More... | |
uint | n_elems_ |
Number of elements in patch. More... | |
uint | i_elem_ |
Index of registered element in table, helper value used during patch creating. More... | |
Quadrature * | quad_ |
Quadrature of given dimension and order passed in constructor. More... | |
std::vector< uint > | elements_map_ |
Map of element patch indices to el_vals_ table. More... | |
std::vector< uint > | points_map_ |
Map of point patch indices to point_vals_ and int_vals_ tables. More... | |
std::vector< OpSizeType > | row_sizes_ |
hold sizes of rows by type of operation More... | |
AssemblyArena & | asm_arena_ |
Reference to global assembly arena of PatchFeValues. More... | |
PatchArena * | patch_arena_ |
Pointer to global patch arena of PatchFeValues. More... | |
Friends | |
class | PatchFEValues< spacedim > |
class | ElOp< spacedim > |
template<unsigned int dim> | |
class | BulkValues |
template<unsigned int dim> | |
class | SideValues |
template<unsigned int dim> | |
class | JoinValues |
v Class for storing FE data of quadrature points on one patch.
Store data of bulk or side quadrature points of one dimension.
Definition at line 122 of file patch_point_values.hh.
|
inline |
|
inline |
Getter for dim_.
Definition at line 160 of file patch_point_values.hh.
|
inline |
Getter for quadrature.
Definition at line 180 of file patch_point_values.hh.
|
inline |
Definition at line 148 of file patch_point_values.hh.
|
inline |
Initialize object, set number of columns (quantities) in tables.
Number of columns of int_vals_ table is passed by argument int_cols
, number of columns of other tables is given by n_rows_ value.
Definition at line 141 of file patch_point_values.hh.
|
inline |
Adds accessor of expansion operation to operations_ vector
el_op | Source operation of expansion. |
shape | Shape of function output |
reinit_f | Reinitialize function |
Definition at line 321 of file patch_point_values.hh.
|
inline |
Adds accessor of FE operation and adds operation dynamically to operations_ vector
shape | Shape of function output |
reinit_f | Reinitialize function |
input_ops_vec | Indices of input operations in operations_ vector. |
n_dofs | Number of DOFs |
size_type | Type of operation by size of rows |
Definition at line 338 of file patch_point_values.hh.
|
inline |
Adds accessor of new operation with fixed data size (ref data) to operations_ vector
shape | Shape of function output |
reinit_f | Reinitialize function |
Definition at line 310 of file patch_point_values.hh.
|
inline |
Adds accessor of new operation to operations_ vector
shape | Shape of function output |
reinit_f | Reinitialize function |
input_ops_vec | Indices of input operations in operations_ vector. |
size_type | Type of operation by size of rows |
Definition at line 296 of file patch_point_values.hh.
|
inline |
Getter for n_elems_.
Definition at line 170 of file patch_point_values.hh.
|
inline |
Getter for n_points_.
Definition at line 175 of file patch_point_values.hh.
|
inline |
Getter for n_rows_.
Definition at line 165 of file patch_point_values.hh.
|
inline |
Performs output of data tables to stream.
Development method.
points | Allows switched off output of point table, |
ints | Allows switched off output of int (connectivity to elements) table, |
Definition at line 423 of file patch_point_values.hh.
|
inline |
Performs table of fixed operations to stream.
Development method.
bulk_side | Needs set 0 (bulk) or 1 (side) for correct output of operation names. |
Definition at line 457 of file patch_point_values.hh.
|
inline |
Register bulk point, add to int_vals_ table
elem_table_row | Index of element in temporary element table. |
value_patch_idx | Index of point in ElementCacheMap. |
elem_idx | Index of element in Mesh. |
i_point_on_elem | Index of point on element |
Definition at line 259 of file patch_point_values.hh.
|
inline |
Register element, add to point_vals_ table
coords | Coordinates of element nodes. |
element_patch_idx | Index of element on patch. |
Definition at line 211 of file patch_point_values.hh.
|
inline |
Register side, add to point_vals_ table
coords | Coordinates of element nodes. |
side_coords | Coordinates of side nodes. |
Definition at line 233 of file patch_point_values.hh.
|
inline |
Register side point, add to int_vals_ table
elem_table_row | Index of side in temporary element table. |
value_patch_idx | Index of point in ElementCacheMap. |
elem_idx | Index of element in Mesh. |
side_idx | Index of side on element. |
Definition at line 278 of file patch_point_values.hh.
|
inline |
Reinitializes patch data.
Calls reinit functions defined on each operations.
Definition at line 353 of file patch_point_values.hh.
|
inline |
Reset number of columns (points and elements)
Definition at line 153 of file patch_point_values.hh.
|
inline |
Resize data tables. Method is called before reinit of patch.
Definition at line 185 of file patch_point_values.hh.
|
inline |
Returns scalar output value given by index of first row and index of quadrature point.
result_row | Row of operation in point_vals_ data table |
point_idx | Index of quadrature point in ElementCacheMap |
Definition at line 365 of file patch_point_values.hh.
|
inline |
Definition at line 368 of file patch_point_values.hh.
|
inline |
Returns tensor output value given by index of first row and index of quadrature point.
result_row | First row of operation in point_vals_ data table |
point_idx | Index of quadrature point in ElementCacheMap |
Definition at line 399 of file patch_point_values.hh.
|
inline |
Definition at line 406 of file patch_point_values.hh.
|
inline |
Returns vector output value given by index of first row and index of quadrature point.
result_row | First row of operation in point_vals_ data table |
point_idx | Index of quadrature point in ElementCacheMap |
Definition at line 378 of file patch_point_values.hh.
|
inline |
Definition at line 384 of file patch_point_values.hh.
Definition at line 513 of file patch_point_values.hh.
|
friend |
Definition at line 508 of file patch_point_values.hh.
Definition at line 517 of file patch_point_values.hh.
|
friend |
Definition at line 508 of file patch_point_values.hh.
Definition at line 515 of file patch_point_values.hh.
|
protected |
Reference to global assembly arena of PatchFeValues.
Definition at line 507 of file patch_point_values.hh.
|
protected |
Dimension.
Definition at line 497 of file patch_point_values.hh.
|
protected |
Map of element patch indices to el_vals_ table.
Definition at line 504 of file patch_point_values.hh.
|
protected |
Index of registered element in table, helper value used during patch creating.
Definition at line 501 of file patch_point_values.hh.
|
protected |
Hold integer values of quadrature points of previous table.
Table contains following columns: 0: Index of quadrature point on patch 1: Row of element/side in point_vals_ table in registration step (before expansion) 2: Element idx in Mesh 3: Index of side in element (column is allocated only for side point table) Number of used rows is given by n_points_.
Definition at line 492 of file patch_point_values.hh.
|
protected |
Number of elements in patch.
Definition at line 500 of file patch_point_values.hh.
|
protected |
Number of points in patch.
Definition at line 499 of file patch_point_values.hh.
|
protected |
Number of columns of point_vals
table.
Definition at line 498 of file patch_point_values.hh.
|
protected |
Vector of all defined operations.
Definition at line 495 of file patch_point_values.hh.
|
protected |
Pointer to global patch arena of PatchFeValues.
Definition at line 508 of file patch_point_values.hh.
|
protected |
Store data of bulk or side quadrature points of one dimension
Number of columns is given by n_rows_, number of used rows by n_points_.
Definition at line 481 of file patch_point_values.hh.
|
protected |
Map of point patch indices to point_vals_ and int_vals_ tables.
Definition at line 505 of file patch_point_values.hh.
|
protected |
Quadrature of given dimension and order passed in constructor.
Definition at line 502 of file patch_point_values.hh.
|
protected |
hold sizes of rows by type of operation
Definition at line 506 of file patch_point_values.hh.