 |
| v0.14.0
|
Go to the documentation of this file.
17 #ifndef __ESHELBIAN_PLASTICITY_HPP__
18 #define __ESHELBIAN_PLASTICITY_HPP__
24 using CachePhi = boost::tuple<int, int, MatrixDouble>;
30 BaseFunctionUnknownInterface **iface)
const;
32 boost::shared_ptr<BaseFunctionCtx> ctx_ptr);
60 :
public boost::enable_shared_from_this<DataAtIntegrationPts> {
134 return boost::shared_ptr<double>(shared_from_this(), &
piolaScale);
138 return boost::shared_ptr<MatrixDouble>(shared_from_this(),
142 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
approxPAtPts);
146 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
divPAtPts);
150 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
divSigmaAtPts);
154 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
wL2AtPts);
158 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
wL2DotAtPts);
162 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
wL2DotDotAtPts);
166 return boost::shared_ptr<MatrixDouble>(shared_from_this(),
171 return boost::shared_ptr<MatrixDouble>(shared_from_this(),
176 return boost::shared_ptr<MatrixDouble>(shared_from_this(),
181 return boost::shared_ptr<MatrixDouble>(shared_from_this(),
186 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
rotAxisAtPts);
190 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
rotAxis0AtPts);
194 return boost::shared_ptr<MatrixDouble>(shared_from_this(),
199 return boost::shared_ptr<MatrixDouble>(shared_from_this(),
204 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
GAtPts);
208 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
GAtPts);
212 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
matD);
216 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
matInvD);
220 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
matAxiatorD);
224 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
matDeviatorD);
228 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
wH1AtPts);
232 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
XH1AtPts);
236 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
contactL2AtPts);
240 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
wGradH1AtPts);
244 return boost::shared_ptr<VectorDouble>(shared_from_this(), &
jacobianAtPts);
248 return boost::shared_ptr<MatrixDouble>(shared_from_this(),
253 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
varRotAxis);
257 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
varLogStreach);
261 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
varPiola);
265 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
varDivPiola);
269 return boost::shared_ptr<MatrixDouble>(shared_from_this(), &
varWL2);
302 boost::shared_ptr<DataAtIntegrationPts> data_ptr,
303 boost::shared_ptr<PhysicalEquations> physics_ptr) = 0;
307 boost::shared_ptr<DataAtIntegrationPts> data_ptr,
308 const double alpha_u);
311 std::string row_field, std::string col_field,
312 boost::shared_ptr<DataAtIntegrationPts> data_ptr,
const double alpha);
316 boost::shared_ptr<double> total_energy_ptr);
319 boost::shared_ptr<DataAtIntegrationPts> data_ptr,
320 boost::shared_ptr<PhysicalEquations> physics_ptr);
323 boost::shared_ptr<DataAtIntegrationPts> data_ptr,
324 boost::shared_ptr<PhysicalEquations> physics_ptr);
328 boost::shared_ptr<PhysicalEquations> physics_ptr);
341 &
v[S + 5], &
v[S + 6], &
v[S + 7], &
v[S + 8]);
353 const int A00 = nba * 0 + S0;
354 const int A01 = nba * 1 + S0;
355 const int A02 = nba * 2 + S0;
356 const int A10 = nba * 3 + S0;
357 const int A11 = nba * 4 + S0;
358 const int A12 = nba * 5 + S0;
359 const int A20 = nba * 6 + S0;
360 const int A21 = nba * 7 + S0;
361 const int A22 = nba * 8 + S0;
365 &
v[A00 + 0], &
v[A00 + 1], &
v[A00 + 2], &
v[A01 + 0], &
v[A01 + 1],
366 &
v[A01 + 2], &
v[A02 + 0], &
v[A02 + 1], &
v[A02 + 2],
368 &
v[A10 + 0], &
v[A10 + 1], &
v[A10 + 2], &
v[A11 + 0], &
v[A11 + 1],
369 &
v[A11 + 2], &
v[A12 + 0], &
v[A12 + 1], &
v[A12 + 2],
371 &
v[A20 + 0], &
v[A20 + 1], &
v[A20 + 2], &
v[A21 + 0], &
v[A21 + 1],
372 &
v[A21 + 2], &
v[A22 + 0], &
v[A22 + 1], &
v[A22 + 2]
451 #endif //__ESHELBIAN_PLASTICITY_HPP__
VectorDouble jacobianAtPts
std::vector< BcDisp > BcDispVec
FTensor::Tensor2< double, 3, 3 > DTensor2
MatrixDouble leviKirchhoffdLogStreatchAtPts
Data on single entity (This is passed as argument to DataOperator::doWork)
BcRot(std::string name, std::vector< double > &attr, Range &faces)
MatrixDouble logStretch2H1AtPts
MatrixPtr getDivSigmaAtPts()
MatrixPtr getSmallWH1AtPts()
std::vector< TractionBc > TractionBcVec
PhysicalEquations(const int size_active, const int size_dependent)
MatrixDouble approxSigmaAtPts
std::vector< double > activeVariables
MatrixPtr getLargeXH1AtPts()
VectorBoundedArray< double, 3 > VectorDouble3
VectorPtr getJacobianAtPts()
virtual VolUserDataOperator * returnOpSpatialPhysical_du_du(std::string row_field, std::string col_field, boost::shared_ptr< DataAtIntegrationPts > data_ptr, const double alpha)
MatrixPtr getSmallWL2DotDotAtPts()
MatrixPtr getBigG0AtPts()
MatrixPtr getGradLogStretchDotTensorAtPts()
FTensor::Tensor0< FTensor::PackPtr< double *, 1 > > DTensor0Ptr
virtual OpJacobian * returnOpJacobian(const int tag, const bool eval_rhs, const bool eval_lhs, boost::shared_ptr< DataAtIntegrationPts > data_ptr, boost::shared_ptr< PhysicalEquations > physics_ptr)=0
MatrixDouble rotAxisDotAtPts
FTensor::Tensor2< FTensor::PackPtr< double *, 1 >, 3, 3 > DTensor2Ptr
MatrixPtr getRotAxisDotAtPts()
MatrixDouble stretchTensorAtPts
virtual VolUserDataOperator * returnOpSpatialPhysical(const std::string &field_name, boost::shared_ptr< DataAtIntegrationPts > data_ptr, const double alpha_u)
PetscErrorCode MoFEMErrorCode
MoFEM/PETSc error code.
UBlasMatrix< double > MatrixDouble
MatrixDouble matDeviatorD
virtual ~PhysicalEquations()=default
PipelineManager::ElementsAndOpsByDim< FE_DIM >::FaceSideEle FaceSideEle
std::vector< BcRot > BcRotVec
MatrixDouble logStretchTotalTensorAtPts
MatrixPtr getLeviKirchhoffAtPts()
MatrixPtr getStretchTensorAtPts()
PipelineManager::ElementsAndOpsByDim< SPACE_DIM >::FaceSideEle EleOnSide
FTensor::Tensor3< double, 3, 3, 3 > DTensor3
MatrixPtr getRotAxisAtPts()
MatrixPtr getApproxSigmaAtPts()
MatrixPtr getRotAxisGradDotAtPts()
MatrixDouble rotAxisAtPts
VectorBoundedArray< int, 3 > VectorInt3
boost::shared_ptr< MatrixDouble > MatrixPtr
MatrixDouble contactL2AtPts
MatrixPtr getVarPiolaPts()
MatrixDouble adjointPdstretchAtPts
MatrixDouble logStretchDotTensorAtPts
MatrixPtr getDivVarPiolaPts()
EntitiesFieldData::EntData EntData
MatrixDouble gradLogStretchDotTensorAtPts
MatrixDouble rotAxis0AtPts
MatrixDouble varLogStreach
MatrixPtr getVarLogStreachPts()
MatrixPtr getMatInvDPtr()
MatrixDouble approxPAtPts
MatrixDouble leviKirchhoffdOmegaAtPts
MatrixDouble adjointPdUdOmegaAtPts
virtual VolUserDataOperator * returnOpSetScale(boost::shared_ptr< double > scale_ptr, boost::shared_ptr< PhysicalEquations > physics_ptr)
boost::shared_ptr< PhysicalEquations > physicsPtr
std::vector< Range > TractionFreeBc
FTensor::Tensor2< adouble, 3, 3 > ATensor2
~CGGUserPolynomialBase()=default
MatrixDouble leviKirchhoffAtPts
MoFEMErrorCode query_interface(boost::typeindex::type_index type_index, BaseFunctionUnknownInterface **iface) const
MatrixDouble logStretchTensorAtPts
boost::shared_ptr< VectorDouble > VectorPtr
std::vector< double > dependentVariablesPiolaDirevatives
static DTensor3Ptr get_vecTensor3(std::vector< double > &v, const int nba)
BcDisp(std::string name, std::vector< double > &attr, Range &faces)
MoFEMErrorCode getValueHdivForCGGBubble(MatrixDouble &pts)
MatrixDouble tractionAtPts
static DTensor2Ptr get_VecTensor2(std::vector< double > &v)
virtual VolUserDataOperator * returnOpCalculateStretchFromStress(boost::shared_ptr< DataAtIntegrationPts > data_ptr, boost::shared_ptr< PhysicalEquations > physics_ptr)
MatrixPtr getMatAxiatorDPtr()
MatrixPtr getLogStretchTensorAtPts()
FaceElementForcesAndSourcesCore::UserDataOperator FaceUserDataOperator
constexpr auto field_name
MatrixPtr getLogStretchDotTensorAtPts()
MatrixPtr getMatDeviatorDPtr()
FTensor::Tensor1< adouble, 3 > ATensor1
const double v
phase velocity of light in medium (cm/ns)
MatrixDouble wL2DotDotAtPts
MoFEMErrorCode getValue(MatrixDouble &pts, boost::shared_ptr< BaseFunctionCtx > ctx_ptr)
MatrixPtr getRotAxis0AtPts()
boost::shared_ptr< CachePhi > cachePhiPtr
MatrixDouble diffStretchTensorAtPts
MatrixDouble hdOmegaAtPts
TractionBc(std::string name, std::vector< double > &attr, Range &faces)
MatrixDouble rotAxisGradDotAtPts
ForcesAndSourcesCore::UserDataOperator UserDataOperator
UBlasVector< int > VectorInt
static DTensor0Ptr get_VecTensor0(std::vector< double > &v)
MatrixDouble divSigmaAtPts
MatrixPtr getSmallWGradH1AtPts()
MatrixDouble leviKirchhoffPAtPts
MatrixPtr getSmallWL2DotAtPts()
VectorDouble detStretchTensorAtPts
FTensor::Tensor1< double, 3 > DTensor1
UBlasVector< double > VectorDouble
virtual VolUserDataOperator * returnOpCalculateEnergy(boost::shared_ptr< DataAtIntegrationPts > data_ptr, boost::shared_ptr< double > total_energy_ptr)
MatrixDouble detStretchTensorAtPts_du
MatrixDouble wGradH1AtPts
MatrixPtr getVarRotAxisPts()
MatrixPtr getApproxPAtPts()
virtual VolUserDataOperator * returnOpCalculateVarStretchFromStress(boost::shared_ptr< DataAtIntegrationPts > data_ptr, boost::shared_ptr< PhysicalEquations > physics_ptr)
MatrixPtr getSmallWL2AtPts()
FTensor::Tensor3< adouble, 3, 3, 3 > ATensor3
std::vector< double > dependentVariablesPiola
PhysicalEquations()=delete
virtual MoFEMErrorCode recordTape(const int tag, DTensor2Ptr *t_h)=0
MatrixDouble adjointPdUdPAtPts
boost::tuple< int, int, MatrixDouble > CachePhi
CGGUserPolynomialBase(boost::shared_ptr< CachePhi > cache_phi=nullptr)
MatrixDouble hdLogStretchAtPts
MatrixPtr getContactL2AtPts()
MatrixDouble adjointPdUAtPts
FTensor::Tensor3< FTensor::PackPtr< double *, 1 >, 3, 3, 3 > DTensor3Ptr