Loading...
Searching...
No Matches
terra::fe::wedge::operators::shell::Laplace< ScalarT > Class Template Reference

#include <laplace.hpp>

Public Types

using SrcVectorType = linalg::VectorQ1Scalar< ScalarT >
 
using DstVectorType = linalg::VectorQ1Scalar< ScalarT >
 
using ScalarType = ScalarT
 

Public Member Functions

 Laplace (const grid::shell::DistributedDomain &domain, const grid::Grid3DDataVec< ScalarT, 3 > &grid, const grid::Grid2DDataScalar< ScalarT > &radii, const grid::Grid4DDataScalar< grid::shell::ShellBoundaryFlag > &mask, bool treat_boundary, bool diagonal, linalg::OperatorApplyMode operator_apply_mode=linalg::OperatorApplyMode::Replace, linalg::OperatorCommunicationMode operator_communication_mode=linalg::OperatorCommunicationMode::CommunicateAdditively)
 
void apply_impl (const SrcVectorType &src, DstVectorType &dst)
 
void operator() (const int local_subdomain_id, const int x_cell, const int y_cell, const int r_cell) const
 
void neumann (ScalarType *src_local_hex, ScalarType *dst_local_hex, const int wedge, const ScalarType quad_weight, const ScalarType abs_det, const dense::Vec< ScalarType, 3 > *grad_phy) const
 
void dirichlet_bot (ScalarType *src_local_hex, ScalarType *dst_local_hex, const int wedge, const ScalarType quad_weight, const ScalarType abs_det, const dense::Vec< ScalarType, 3 > *grad_phy) const
 
void dirichlet_top (ScalarType *src_local_hex, ScalarType *dst_local_hex, const int wedge, const ScalarType quad_weight, const ScalarType abs_det, const dense::Vec< ScalarType, 3 > *grad_phy) const
 
void diagonal (ScalarType *src_local_hex, ScalarType *dst_local_hex, const int wedge, const ScalarType quad_weight, const ScalarType abs_det, const dense::Vec< ScalarType, 3 > *grad_phy) const
 

Member Typedef Documentation

◆ DstVectorType

template<typename ScalarT >
using terra::fe::wedge::operators::shell::Laplace< ScalarT >::DstVectorType = linalg::VectorQ1Scalar< ScalarT >

◆ ScalarType

template<typename ScalarT >
using terra::fe::wedge::operators::shell::Laplace< ScalarT >::ScalarType = ScalarT

◆ SrcVectorType

template<typename ScalarT >
using terra::fe::wedge::operators::shell::Laplace< ScalarT >::SrcVectorType = linalg::VectorQ1Scalar< ScalarT >

Constructor & Destructor Documentation

◆ Laplace()

template<typename ScalarT >
terra::fe::wedge::operators::shell::Laplace< ScalarT >::Laplace ( const grid::shell::DistributedDomain domain,
const grid::Grid3DDataVec< ScalarT, 3 > &  grid,
const grid::Grid2DDataScalar< ScalarT > &  radii,
const grid::Grid4DDataScalar< grid::shell::ShellBoundaryFlag > &  mask,
bool  treat_boundary,
bool  diagonal,
linalg::OperatorApplyMode  operator_apply_mode = linalg::OperatorApplyMode::Replace,
linalg::OperatorCommunicationMode  operator_communication_mode = linalg::OperatorCommunicationMode::CommunicateAdditively 
)
inline

Member Function Documentation

◆ apply_impl()

template<typename ScalarT >
void terra::fe::wedge::operators::shell::Laplace< ScalarT >::apply_impl ( const SrcVectorType src,
DstVectorType dst 
)
inline

◆ diagonal()

template<typename ScalarT >
void terra::fe::wedge::operators::shell::Laplace< ScalarT >::diagonal ( ScalarType src_local_hex,
ScalarType dst_local_hex,
const int  wedge,
const ScalarType  quad_weight,
const ScalarType  abs_det,
const dense::Vec< ScalarType, 3 > *  grad_phy 
) const
inline

◆ dirichlet_bot()

template<typename ScalarT >
void terra::fe::wedge::operators::shell::Laplace< ScalarT >::dirichlet_bot ( ScalarType src_local_hex,
ScalarType dst_local_hex,
const int  wedge,
const ScalarType  quad_weight,
const ScalarType  abs_det,
const dense::Vec< ScalarType, 3 > *  grad_phy 
) const
inline

◆ dirichlet_top()

template<typename ScalarT >
void terra::fe::wedge::operators::shell::Laplace< ScalarT >::dirichlet_top ( ScalarType src_local_hex,
ScalarType dst_local_hex,
const int  wedge,
const ScalarType  quad_weight,
const ScalarType  abs_det,
const dense::Vec< ScalarType, 3 > *  grad_phy 
) const
inline

◆ neumann()

template<typename ScalarT >
void terra::fe::wedge::operators::shell::Laplace< ScalarT >::neumann ( ScalarType src_local_hex,
ScalarType dst_local_hex,
const int  wedge,
const ScalarType  quad_weight,
const ScalarType  abs_det,
const dense::Vec< ScalarType, 3 > *  grad_phy 
) const
inline

◆ operator()()

template<typename ScalarT >
void terra::fe::wedge::operators::shell::Laplace< ScalarT >::operator() ( const int  local_subdomain_id,
const int  x_cell,
const int  y_cell,
const int  r_cell 
) const
inline

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