Flow123d
3.9.0-be1f591da
|
#include <assembly_dg.hh>
Public Types | |
typedef TransportDG< Model >::EqFields | EqFields |
typedef TransportDG< Model >::EqData | EqData |
Public Types inherited from AssemblyBase< dim > | |
typedef GenericAssemblyBase::BulkIntegralData | BulkIntegralData |
typedef GenericAssemblyBase::EdgeIntegralData | EdgeIntegralData |
typedef GenericAssemblyBase::CouplingIntegralData | CouplingIntegralData |
typedef GenericAssemblyBase::BoundaryIntegralData | BoundaryIntegralData |
Public Member Functions | |
StiffnessAssemblyDG (EqFields *eq_fields, EqData *eq_data) | |
Constructor. More... | |
~StiffnessAssemblyDG () | |
Destructor. More... | |
void | initialize (ElementCacheMap *element_cache_map) |
Initialize auxiliary vectors and other data members. More... | |
void | cell_integral (DHCellAccessor cell, unsigned int element_patch_idx) |
Assembles the cell (volume) integral into the stiffness matrix. More... | |
void | boundary_side_integral (DHCellSide cell_side) |
Assembles the fluxes on the boundary. More... | |
void | edge_integral (RangeConvert< DHEdgeSide, DHCellSide > edge_side_range) |
Assembles the fluxes between sides of elements of the same dimension. More... | |
void | dimjoin_intergral (DHCellAccessor cell_lower_dim, DHCellSide neighb_side) |
Assembles the fluxes between elements of different dimensions. More... | |
Public Member Functions inherited from AssemblyBase< dim > | |
AssemblyBase (unsigned int quad_order) | |
Constructor. More... | |
virtual | ~AssemblyBase () |
Destructor. More... | |
virtual void | cell_integral (FMT_UNUSED DHCellAccessor cell, FMT_UNUSED unsigned int element_patch_idx) |
Assembles the volume integrals on cell. More... | |
virtual void | boundary_side_integral (FMT_UNUSED DHCellSide cell_side) |
Assembles the fluxes on the boundary. More... | |
virtual void | edge_integral (FMT_UNUSED RangeConvert< DHEdgeSide, DHCellSide > edge_side_range) |
Assembles the fluxes between sides on the edge. More... | |
virtual void | dimjoin_intergral (FMT_UNUSED DHCellAccessor cell_lower_dim, FMT_UNUSED DHCellSide neighb_side) |
Assembles the fluxes between elements of different dimensions. More... | |
virtual void | begin () |
Method prepares object before assemblation (e.g. balance, ...). More... | |
virtual void | end () |
Method finishes object after assemblation (e.g. balance, ...). More... | |
int | n_active_integrals () const |
Getter of active_integrals. More... | |
void | create_integrals (std::shared_ptr< EvalPoints > eval_points, AssemblyIntegrals &integrals) |
Create integrals according to dim of assembly object. More... | |
Range< BulkPoint > | bulk_points (unsigned int element_patch_idx) const |
Return BulkPoint range of appropriate dimension. More... | |
Range< EdgePoint > | edge_points (const DHCellSide &cell_side) const |
Return EdgePoint range of appropriate dimension. More... | |
Range< CouplingPoint > | coupling_points (const DHCellSide &cell_side) const |
Return CouplingPoint range of appropriate dimension. More... | |
Range< BoundaryPoint > | boundary_points (const DHCellSide &cell_side) const |
Return BoundaryPoint range of appropriate dimension. More... | |
virtual void | assemble_cell_integrals (const RevertableList< BulkIntegralData > &bulk_integral_data) |
Assembles the cell integrals for the given dimension. More... | |
void | assemble_boundary_side_integrals (const RevertableList< BoundaryIntegralData > &boundary_integral_data) |
Assembles the boundary side integrals for the given dimension. More... | |
void | assemble_edge_integrals (const RevertableList< EdgeIntegralData > &edge_integral_data) |
Assembles the edge integrals for the given dimension. More... | |
void | assemble_neighbour_integrals (const RevertableList< CouplingIntegralData > &coupling_integral_data) |
Assembles the neighbours integrals for the given dimension. More... | |
Static Public Member Functions | |
static constexpr const char * | name () |
Private Attributes | |
shared_ptr< FiniteElement< dim > > | fe_ |
Finite element for the solution of the advection-diffusion equation. More... | |
shared_ptr< FiniteElement< dim-1 > > | fe_low_ |
Finite element for the solution of the advection-diffusion equation (dim-1). More... | |
EqFields * | eq_fields_ |
Data objects shared with TransportDG. More... | |
EqData * | eq_data_ |
FieldSet | used_fields_ |
Sub field set contains fields used in calculation. More... | |
unsigned int | ndofs_ |
Number of dofs. More... | |
unsigned int | qsize_lower_dim_ |
Size of quadrature of dim-1. More... | |
FEValues< 3 > | fe_values_ |
FEValues of object (of P disc finite element type) More... | |
FEValues< 3 > | fe_values_vb_ |
FEValues of dim-1 object (of P disc finite element type) More... | |
FEValues< 3 > | fe_values_side_ |
FEValues of object (of P disc finite element type) More... | |
vector< FEValues< 3 > > | fe_values_vec_ |
Vector of FEValues of object (of P disc finite element types) More... | |
vector< FEValues< 3 > * > | fv_sb_ |
Auxiliary vector, holds FEValues objects for assemble element-side. More... | |
vector< LongIdx > | dof_indices_ |
Vector of global DOF indices. More... | |
vector< vector< LongIdx > > | side_dof_indices_ |
Vector of vectors of side DOF indices. More... | |
vector< LongIdx > | side_dof_indices_vb_ |
Vector of side DOF indices (assemble element-side fluxex) More... | |
vector< PetscScalar > | local_matrix_ |
Auxiliary vector for assemble methods. More... | |
vector< double * > | averages |
Auxiliary storage for averages of shape functions. More... | |
vector< double * > | waverages |
Auxiliary storage for weighted averages of shape functions. More... | |
vector< double * > | jumps |
Auxiliary storage for jumps of shape functions. More... | |
Friends | |
template<template< IntDim... > class DimAssembly> | |
class | GenericAssembly |
Additional Inherited Members | |
Protected Member Functions inherited from AssemblyBase< dim > | |
AssemblyBase () | |
std::string | print_update_flags (UpdateFlags u) const |
Print update flags to string format. More... | |
Protected Attributes inherited from AssemblyBase< dim > | |
Quadrature * | quad_ |
Quadrature used in assembling methods. More... | |
Quadrature * | quad_low_ |
Quadrature used in assembling methods (dim-1). More... | |
int | active_integrals_ |
Holds mask of active integrals. More... | |
DimIntegrals | integrals_ |
Set of used integrals. More... | |
ElementCacheMap * | element_cache_map_ |
ElementCacheMap shared with GenericAssembly object. More... | |
Auxiliary container class for Finite element and related objects of given dimension.
Definition at line 163 of file assembly_dg.hh.
typedef TransportDG<Model>::EqData StiffnessAssemblyDG< dim, Model >::EqData |
Definition at line 167 of file assembly_dg.hh.
typedef TransportDG<Model>::EqFields StiffnessAssemblyDG< dim, Model >::EqFields |
Definition at line 166 of file assembly_dg.hh.
|
inline |
Constructor.
Definition at line 172 of file assembly_dg.hh.
|
inline |
Destructor.
Definition at line 186 of file assembly_dg.hh.
|
inline |
Assembles the fluxes on the boundary.
Definition at line 282 of file assembly_dg.hh.
|
inline |
Assembles the cell (volume) integral into the stiffness matrix.
Definition at line 243 of file assembly_dg.hh.
|
inline |
Assembles the fluxes between elements of different dimensions.
Definition at line 538 of file assembly_dg.hh.
|
inline |
Assembles the fluxes between sides of elements of the same dimension.
Definition at line 369 of file assembly_dg.hh.
|
inline |
Initialize auxiliary vectors and other data members.
Definition at line 193 of file assembly_dg.hh.
|
inlinestaticconstexpr |
Definition at line 169 of file assembly_dg.hh.
|
friend |
Definition at line 642 of file assembly_dg.hh.
|
private |
Auxiliary storage for averages of shape functions.
Definition at line 637 of file assembly_dg.hh.
|
private |
Vector of global DOF indices.
Definition at line 632 of file assembly_dg.hh.
|
private |
Definition at line 619 of file assembly_dg.hh.
|
private |
Data objects shared with TransportDG.
Definition at line 618 of file assembly_dg.hh.
|
private |
Finite element for the solution of the advection-diffusion equation.
Definition at line 614 of file assembly_dg.hh.
|
private |
Finite element for the solution of the advection-diffusion equation (dim-1).
Definition at line 615 of file assembly_dg.hh.
|
private |
FEValues of object (of P disc finite element type)
Definition at line 626 of file assembly_dg.hh.
|
private |
FEValues of object (of P disc finite element type)
Definition at line 628 of file assembly_dg.hh.
|
private |
FEValues of dim-1 object (of P disc finite element type)
Definition at line 627 of file assembly_dg.hh.
|
private |
Vector of FEValues of object (of P disc finite element types)
Definition at line 629 of file assembly_dg.hh.
|
private |
Auxiliary vector, holds FEValues objects for assemble element-side.
Definition at line 630 of file assembly_dg.hh.
|
private |
Auxiliary storage for jumps of shape functions.
Definition at line 639 of file assembly_dg.hh.
|
private |
Auxiliary vector for assemble methods.
Definition at line 635 of file assembly_dg.hh.
|
private |
Number of dofs.
Definition at line 624 of file assembly_dg.hh.
|
private |
Size of quadrature of dim-1.
Definition at line 625 of file assembly_dg.hh.
|
private |
Vector of vectors of side DOF indices.
Definition at line 633 of file assembly_dg.hh.
|
private |
Vector of side DOF indices (assemble element-side fluxex)
Definition at line 634 of file assembly_dg.hh.
|
private |
Sub field set contains fields used in calculation.
Definition at line 622 of file assembly_dg.hh.
|
private |
Auxiliary storage for weighted averages of shape functions.
Definition at line 638 of file assembly_dg.hh.