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

#include <vector_laplace.hpp>

Public Types

using SrcVectorType = linalg::VectorQ1Vec< ScalarT, VecDim >
 
using DstVectorType = linalg::VectorQ1Vec< ScalarT, VecDim >
 
using ScalarType = ScalarT
 

Public Member Functions

 VectorLaplace (const grid::shell::DistributedDomain &domain, const grid::Grid3DDataVec< ScalarT, 3 > &grid, const grid::Grid2DDataScalar< ScalarT > &radii, const grid::Grid4DDataScalar< grid::shell::ShellBoundaryFlag > &boundary_mask_data, BoundaryConditions bcs, bool diagonal, linalg::OperatorApplyMode operator_apply_mode=linalg::OperatorApplyMode::Replace, linalg::OperatorCommunicationMode operator_communication_mode=linalg::OperatorCommunicationMode::CommunicateAdditively)
 
void set_operator_apply_and_communication_modes (const linalg::OperatorApplyMode operator_apply_mode, const linalg::OperatorCommunicationMode operator_communication_mode)
 
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[8][VecDim], ScalarType dst_local_hex[8][VecDim], 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[8][VecDim], ScalarType dst_local_hex[8][VecDim], 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[8][VecDim], ScalarType dst_local_hex[8][VecDim], 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[8][VecDim], ScalarType dst_local_hex[8][VecDim], 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 , int VecDim = 3>
using terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::DstVectorType = linalg::VectorQ1Vec< ScalarT, VecDim >

◆ ScalarType

template<typename ScalarT , int VecDim = 3>
using terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::ScalarType = ScalarT

◆ SrcVectorType

template<typename ScalarT , int VecDim = 3>
using terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::SrcVectorType = linalg::VectorQ1Vec< ScalarT, VecDim >

Constructor & Destructor Documentation

◆ VectorLaplace()

template<typename ScalarT , int VecDim = 3>
terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::VectorLaplace ( const grid::shell::DistributedDomain domain,
const grid::Grid3DDataVec< ScalarT, 3 > &  grid,
const grid::Grid2DDataScalar< ScalarT > &  radii,
const grid::Grid4DDataScalar< grid::shell::ShellBoundaryFlag > &  boundary_mask_data,
BoundaryConditions  bcs,
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 , int VecDim = 3>
void terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::apply_impl ( const SrcVectorType src,
DstVectorType dst 
)
inline

◆ diagonal()

template<typename ScalarT , int VecDim = 3>
void terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::diagonal ( ScalarType  src_local_hex[8][VecDim],
ScalarType  dst_local_hex[8][VecDim],
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 , int VecDim = 3>
void terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::dirichlet_bot ( ScalarType  src_local_hex[8][VecDim],
ScalarType  dst_local_hex[8][VecDim],
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 , int VecDim = 3>
void terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::dirichlet_top ( ScalarType  src_local_hex[8][VecDim],
ScalarType  dst_local_hex[8][VecDim],
const int  wedge,
const ScalarType  quad_weight,
const ScalarType  abs_det,
const dense::Vec< ScalarType, 3 > *  grad_phy 
) const
inline

◆ neumann()

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

◆ operator()()

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

◆ set_operator_apply_and_communication_modes()

template<typename ScalarT , int VecDim = 3>
void terra::fe::wedge::operators::shell::VectorLaplace< ScalarT, VecDim >::set_operator_apply_and_communication_modes ( const linalg::OperatorApplyMode  operator_apply_mode,
const linalg::OperatorCommunicationMode  operator_communication_mode 
)
inline

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