v0.15.0
Loading...
Searching...
No Matches
Public Member Functions | List of all members
EdgeFlippingOps::OpLhsSymTensorLeastSquaresProjImpl< DIM, GAUSS, AssemblyDomainEleOp > Struct Template Reference

#include "users_modules/multifield-thermoplasticity-private/src/EdgeFlippingOps.hpp"

Inheritance diagram for EdgeFlippingOps::OpLhsSymTensorLeastSquaresProjImpl< DIM, GAUSS, AssemblyDomainEleOp >:
[legend]
Collaboration diagram for EdgeFlippingOps::OpLhsSymTensorLeastSquaresProjImpl< DIM, GAUSS, AssemblyDomainEleOp >:
[legend]

Public Member Functions

 OpLhsSymTensorLeastSquaresProjImpl (const std::string row_field_name, const std::string col_field_name)
 
MoFEMErrorCode iNtegrate (EntitiesFieldData::EntData &row_data, EntitiesFieldData::EntData &col_data)
 

Detailed Description

template<int DIM, typename AssemblyDomainEleOp>
struct EdgeFlippingOps::OpLhsSymTensorLeastSquaresProjImpl< DIM, GAUSS, AssemblyDomainEleOp >

Definition at line 359 of file EdgeFlippingOps.hpp.

Constructor & Destructor Documentation

◆ OpLhsSymTensorLeastSquaresProjImpl()

template<int DIM, typename AssemblyDomainEleOp >
EdgeFlippingOps::OpLhsSymTensorLeastSquaresProjImpl< DIM, GAUSS, AssemblyDomainEleOp >::OpLhsSymTensorLeastSquaresProjImpl ( const std::string  row_field_name,
const std::string  col_field_name 
)

Definition at line 370 of file EdgeFlippingOps.hpp.

373 : AssemblyDomainEleOp(row_field_name, col_field_name,
374 AssemblyDomainEleOp::OPROWCOL) {
375 AssemblyDomainEleOp::sYmm = false;
376}
FormsIntegrators< DomainEleOp >::Assembly< A >::OpBase AssemblyDomainEleOp

Member Function Documentation

◆ iNtegrate()

template<int DIM, typename AssemblyDomainEleOp >
MoFEMErrorCode EdgeFlippingOps::OpLhsSymTensorLeastSquaresProjImpl< DIM, GAUSS, AssemblyDomainEleOp >::iNtegrate ( EntitiesFieldData::EntData &  row_data,
EntitiesFieldData::EntData &  col_data 
)

Definition at line 380 of file EdgeFlippingOps.hpp.

382 {
384
385 FTENSOR_INDEX(DIM, i);
386 FTENSOR_INDEX(DIM, j);
387 FTENSOR_INDEX(DIM, k);
388 FTENSOR_INDEX(DIM, l);
389 constexpr auto size_symm = (DIM * (DIM + 1)) / 2;
392
393 auto &locMat = AssemblyDomainEleOp::locMat;
394
395 const auto nb_integration_pts = AssemblyDomainEleOp::getGaussPts().size2();
396 const auto nb_row_base_functions = row_data.getN().size2();
397
399
400 auto t_w = AssemblyDomainEleOp::getFTensor0IntegrationWeight();
401 auto t_row_base = row_data.getFTensor0N();
402 for (size_t gg = 0; gg != nb_integration_pts; ++gg) {
403 double alpha = AssemblyDomainEleOp::getMeasure() * t_w;
404 ++t_w;
405
407 t_res_mat(O, L) = alpha * (t_L(i, j, O) * t_L(i, j, L));
408
409 size_t rr = 0;
410 for (; rr != AssemblyDomainEleOp::nbRows / size_symm; ++rr) {
412 rr, locMat, FTensor::Number<SPACE_DIM>());
413 auto t_col_base = col_data.getFTensor0N(gg, 0);
414 for (size_t cc = 0; cc != AssemblyDomainEleOp::nbCols / size_symm; ++cc) {
415 t_mat(O, L) += ((t_row_base * t_col_base) * t_res_mat(O, L));
416 ++t_mat;
417 ++t_col_base;
418 }
419
420 ++t_row_base;
421 }
422
423 for (; rr < nb_row_base_functions; ++rr)
424 ++t_row_base;
425 }
426
428}
#define FTENSOR_INDEX(DIM, I)
#define MoFEMFunctionBegin
First executable line of each MoFEM function, used for error handling. Final line of MoFEM functions ...
#define MoFEMFunctionReturn(a)
Last executable line of each PETSc function used for error handling. Replaces return()
FTensor::Index< 'i', SPACE_DIM > i
FTensor::Index< 'l', 3 > l
FTensor::Index< 'j', 3 > j
FTensor::Index< 'k', 3 > k
static auto get_mat_tensor_sym_dtensor_sym(size_t rr, MatrixDouble &mat, FTensor::Number< 2 >)
auto symm_L_tensor(FTensor::Number< DIM >)
constexpr auto size_symm
Definition plastic.cpp:42

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