Flow123d  JS_before_hm-1972-g3b0f4cd6d
Public Types | Public Member Functions | Static Public Member Functions | Private Attributes | Friends | List of all members
MassAssemblyDG< dim, Model > Class Template Reference

#include <assembly_dg.hh>

Inheritance diagram for MassAssemblyDG< dim, Model >:
Inheritance graph
[legend]
Collaboration diagram for MassAssemblyDG< dim, Model >:
Collaboration graph
[legend]

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

 MassAssemblyDG (EqFields *eq_fields, EqData *eq_data)
 Constructor. More...
 
 ~MassAssemblyDG ()
 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)
 Assemble integral over element. More...
 
void begin () override
 Implements AssemblyBase::begin. More...
 
void end () override
 Implements AssemblyBase::end. 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...
 
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< BulkPointbulk_points (unsigned int element_patch_idx) const
 Return BulkPoint range of appropriate dimension. More...
 
Range< EdgePointedge_points (const DHCellSide &cell_side) const
 Return EdgePoint range of appropriate dimension. More...
 
Range< CouplingPointcoupling_points (const DHCellSide &cell_side) const
 Return CouplingPoint range of appropriate dimension. More...
 
Range< BoundaryPointboundary_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...
 
 DECLARE_EXCEPTION (ExcBCNotSupported,<< "BC type not supported.\n")
 
virtual void fix_velocity (const DHCellAccessor &dh_cell)=0
 
virtual void assemble (const DHCellAccessor &dh_cell)=0
 
virtual void assemble_reconstruct (const DHCellAccessor &dh_cell)=0
 
virtual void update_water_content (const DHCellAccessor &dh_cell)=0
 Updates water content in Richards. More...
 
virtual ~AssemblyBase ()
 

Static Public Member Functions

static constexpr const char * name ()
 
- Static Public Member Functions inherited from AssemblyBase< dim >
template<template< int dim > class Impl, class Data >
static MultidimAssembly create (Data data)
 

Private Attributes

shared_ptr< FiniteElement< dim > > fe_
 Finite element for the solution of the advection-diffusion equation. More...
 
EqFieldseq_fields_
 Data objects shared with TransportDG. More...
 
EqDataeq_data_
 
FieldSet used_fields_
 Sub field set contains fields used in calculation. More...
 
unsigned int ndofs_
 Number of dofs. More...
 
FEValues< 3 > fe_values_
 FEValues of object (of P disc finite element type) More...
 
vector< LongIdxdof_indices_
 Vector of global DOF indices. More...
 
vector< PetscScalar > local_matrix_
 Auxiliary vector for assemble methods. More...
 
vector< PetscScalar > local_retardation_balance_vector_
 Auxiliary vector for assemble mass matrix. More...
 
vector< PetscScalar > local_mass_balance_vector_
 Same as previous. 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 >
Quadraturequad_
 Quadrature used in assembling methods. More...
 
Quadraturequad_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...
 
ElementCacheMapelement_cache_map_
 ElementCacheMap shared with GenericAssembly object. More...
 

Detailed Description

template<unsigned int dim, class Model>
class MassAssemblyDG< dim, Model >

Auxiliary container class for Finite element and related objects of given dimension.

Definition at line 36 of file assembly_dg.hh.

Member Typedef Documentation

◆ EqData

template<unsigned int dim, class Model >
typedef TransportDG<Model>::EqData MassAssemblyDG< dim, Model >::EqData

Definition at line 40 of file assembly_dg.hh.

◆ EqFields

template<unsigned int dim, class Model >
typedef TransportDG<Model>::EqFields MassAssemblyDG< dim, Model >::EqFields

Definition at line 39 of file assembly_dg.hh.

Constructor & Destructor Documentation

◆ MassAssemblyDG()

template<unsigned int dim, class Model >
MassAssemblyDG< dim, Model >::MassAssemblyDG ( EqFields eq_fields,
EqData eq_data 
)
inline

Constructor.

Definition at line 45 of file assembly_dg.hh.

◆ ~MassAssemblyDG()

template<unsigned int dim, class Model >
MassAssemblyDG< dim, Model >::~MassAssemblyDG ( )
inline

Destructor.

Definition at line 53 of file assembly_dg.hh.

Member Function Documentation

◆ begin()

template<unsigned int dim, class Model >
void MassAssemblyDG< dim, Model >::begin ( )
inlineoverridevirtual

Implements AssemblyBase::begin.

Reimplemented from AssemblyBase< dim >.

Definition at line 124 of file assembly_dg.hh.

◆ cell_integral()

template<unsigned int dim, class Model >
void MassAssemblyDG< dim, Model >::cell_integral ( DHCellAccessor  cell,
unsigned int  element_patch_idx 
)
inline

Assemble integral over element.

Definition at line 74 of file assembly_dg.hh.

◆ end()

template<unsigned int dim, class Model >
void MassAssemblyDG< dim, Model >::end ( )
inlineoverridevirtual

Implements AssemblyBase::end.

Reimplemented from AssemblyBase< dim >.

Definition at line 130 of file assembly_dg.hh.

◆ initialize()

template<unsigned int dim, class Model >
void MassAssemblyDG< dim, Model >::initialize ( ElementCacheMap element_cache_map)
inline

Initialize auxiliary vectors and other data members.

Definition at line 56 of file assembly_dg.hh.

◆ name()

template<unsigned int dim, class Model >
static constexpr const char* MassAssemblyDG< dim, Model >::name ( )
inlinestaticconstexpr

Definition at line 42 of file assembly_dg.hh.

Friends And Related Function Documentation

◆ GenericAssembly

template<unsigned int dim, class Model >
template<template< IntDim... > class DimAssembly>
friend class GenericAssembly
friend

Definition at line 154 of file assembly_dg.hh.

Member Data Documentation

◆ dof_indices_

template<unsigned int dim, class Model >
vector<LongIdx> MassAssemblyDG< dim, Model >::dof_indices_
private

Vector of global DOF indices.

Definition at line 148 of file assembly_dg.hh.

◆ eq_data_

template<unsigned int dim, class Model >
EqData* MassAssemblyDG< dim, Model >::eq_data_
private

Definition at line 140 of file assembly_dg.hh.

◆ eq_fields_

template<unsigned int dim, class Model >
EqFields* MassAssemblyDG< dim, Model >::eq_fields_
private

Data objects shared with TransportDG.

Definition at line 139 of file assembly_dg.hh.

◆ fe_

template<unsigned int dim, class Model >
shared_ptr<FiniteElement<dim> > MassAssemblyDG< dim, Model >::fe_
private

Finite element for the solution of the advection-diffusion equation.

Definition at line 136 of file assembly_dg.hh.

◆ fe_values_

template<unsigned int dim, class Model >
FEValues<3> MassAssemblyDG< dim, Model >::fe_values_
private

FEValues of object (of P disc finite element type)

Definition at line 146 of file assembly_dg.hh.

◆ local_mass_balance_vector_

template<unsigned int dim, class Model >
vector<PetscScalar> MassAssemblyDG< dim, Model >::local_mass_balance_vector_
private

Same as previous.

Definition at line 151 of file assembly_dg.hh.

◆ local_matrix_

template<unsigned int dim, class Model >
vector<PetscScalar> MassAssemblyDG< dim, Model >::local_matrix_
private

Auxiliary vector for assemble methods.

Definition at line 149 of file assembly_dg.hh.

◆ local_retardation_balance_vector_

template<unsigned int dim, class Model >
vector<PetscScalar> MassAssemblyDG< dim, Model >::local_retardation_balance_vector_
private

Auxiliary vector for assemble mass matrix.

Definition at line 150 of file assembly_dg.hh.

◆ ndofs_

template<unsigned int dim, class Model >
unsigned int MassAssemblyDG< dim, Model >::ndofs_
private

Number of dofs.

Definition at line 145 of file assembly_dg.hh.

◆ used_fields_

template<unsigned int dim, class Model >
FieldSet MassAssemblyDG< dim, Model >::used_fields_
private

Sub field set contains fields used in calculation.

Definition at line 143 of file assembly_dg.hh.


The documentation for this class was generated from the following file: