v0.16.0
Loading...
Searching...
No Matches
MatOps.hpp
Go to the documentation of this file.
1/**
2 * \file MatOps.hpp
3 * \example mofem/src/materials/MatOps.hpp
4 *
5 * @copyright Copyright (c) 2023
6 */
7
8#ifndef __MAT_OPS_HPP__
9#define __MAT_OPS_HPP__
10
11namespace MatOps {
12
13// One valid tag-info type for addTagDGProjectionOps(...).
14// Equivalent to std::tuple<std::string, Tag, int>.
15struct StateTag {
16 std::string name;
17 Tag tag = 0;
19};
20
21using StateTags = std::vector<StateTag>;
22using DataDictionary = std::map<std::string, std::string>;
23
25
26 static int atTagName(std::string name);
27 static int setTagName(std::string name, int tag = -1);
28 static std::string getTagName(int tag);
29
30protected:
31 static int getTagByName(std::string name);
32 static inline std::map<std::string, int> tagNameVsTag;
33};
34
35/** \name MatOps Data Interface */
36/**@{*/
37struct MatOpsData : public boost::enable_shared_from_this<MatOpsData> {
38 virtual ~MatOpsData() = default;
39
40 using MatrixPtr = boost::shared_ptr<MatrixDouble>;
41 using StateMatrixPtr = boost::shared_ptr<MatrixAdaptor>;
42
43 virtual std::pair<bool, MatrixPtr>
44 insertCommonData(const std::string &name,
45 const MatrixDouble &data = MatrixDouble(),
46 int shift = 0) = 0;
47
48 virtual std::pair<bool, MatrixPtr>
49 insertActiveData(const std::string &name,
50 const MatrixDouble &data = MatrixDouble(),
51 int shift = 0) = 0;
52
53 virtual std::pair<bool, MatrixPtr>
54 insertDependentData(const std::string &name,
55 const MatrixDouble &data = MatrixDouble(),
56 int shift = 0) = 0;
57
58 virtual std::pair<bool, MatrixPtr>
59 insertDependentDerivativesData(const std::string &name,
60 const MatrixDouble &data = MatrixDouble(),
61 int shift = 0) = 0;
62
63 virtual MatrixPtr getCommonDataPtr(const std::string &name) = 0;
64 virtual MatrixPtr getActiveDataPtr(const std::string &name) = 0;
65 virtual MatrixPtr getDependentDataPtr(const std::string &name) = 0;
66 virtual MatrixPtr getDependentDerivativesDataPtr(const std::string &name) = 0;
67 virtual StateMatrixPtr getStateDataPtr(const std::string &name,
68 EntityHandle ent, int gg) = 0;
69 virtual StateTags getStateTags() const = 0;
70
71 virtual MoFEMErrorCode bindStateTag(MoFEM::Interface &m_field,
72 const std::string &tag_name,
73 int num_components) = 0;
74 virtual MoFEMErrorCode setupStateData() = 0;
75
76 virtual MoFEMErrorCode
77 setActiveContinuousVector(std::vector<double> &active_variables) = 0;
78 virtual MoFEMErrorCode
79 setDependentContinuousVector(std::vector<double> &dependent_variables) = 0;
81 std::vector<double> &dependent_variables_derivatives) = 0;
82
83 virtual MoFEMErrorCode
84 getActiveContinuousVector(const std::vector<double> &active_variables) = 0;
85 virtual MoFEMErrorCode getDependentContinuousVector(
86 const std::vector<double> &dependent_variables) = 0;
88 const std::vector<double> &dependent_variables_derivatives) = 0;
89};
90
91
92/**@}*/
93
94/** \name Physical Equation Interface */
95/**@{*/
97 static MoFEMErrorCode
98 evaluateVariable(boost::shared_ptr<MatOpsData> mat_ops_data_ptr,
99 int tag, EntityHandle entity, int gg);
100 static MoFEMErrorCode
101 evaluateDerivatives(boost::shared_ptr<MatOpsData> mat_ops_data_ptr,
102 int tag, EntityHandle entity, int gg);
103
104private:
105 inline static std::vector<double> activeVariables;
106 inline static std::vector<double> dependentVariables;
107 inline static std::vector<double> dependentVariablesDerivatives;
108 inline static std::vector<double *> jacPtrVec;
109};
110
112
115 boost::shared_ptr<MatOpsData> mat_ops_data_ptr, int tag,
116 boost::shared_ptr<std::map<int, Range>> tag_vs_range_ptr = nullptr)
117 : matOpsDataPtr(mat_ops_data_ptr), tAg(tag),
118 tagVsRangePtr(tag_vs_range_ptr) {}
119 virtual ~PhysicalEquations() = default;
120
121 virtual MoFEMErrorCode
122 getOptions(MoFEM::Interface *m_field_ptr = nullptr) = 0;
123 virtual MoFEMErrorCode setParams(FEMethod *fe_ptr, int gg) = 0;
124 virtual MoFEMErrorCode recordTape() = 0;
125
126 virtual ForcesAndSourcesCore::UserDataOperator *
127 createOp(boost::shared_ptr<PhysicalEquations> physical_ptr, bool eval_stress,
128 bool eval_tangent, bool update) = 0;
129
130 using HookFunction = std::function<MoFEMErrorCode(
131 boost::shared_ptr<MatOpsData>, int, EntityHandle, int)>;
132
136
137 virtual MoFEMErrorCode evaluateVariable(int tag, EntityHandle entity, int gg) {
138 return hookEvaluateVariable(this->matOpsDataPtr, tag, entity, gg);
139 }
140
141 virtual MoFEMErrorCode evaluateDerivatives(int tag, EntityHandle entity,
142 int gg) {
143 return hookEvaluateDerivatives(matOpsDataPtr, tag, entity, gg);
144 }
145
146 virtual MoFEMErrorCode updateState(int tag, EntityHandle entity, int gg) {
147 return hookUpdateState(this->matOpsDataPtr, tag, entity, gg);
148 }
149
150 int tAg;
151 boost::shared_ptr<std::map<int, Range>> tagVsRangePtr;
152 std::vector<std::pair<Range, std::vector<double>>> paramVecByRange;
153
154 boost::shared_ptr<MatOpsData> matOpsDataPtr;
155};
156
157/**@}*/
158
159/** \name Data Factory */
160/**@{*/
161boost::shared_ptr<MatOpsData> createMatOpsDataPtr();
162boost::shared_ptr<MatOpsData> createMatOpsDataPtr(
163 boost::weak_ptr<MatOpsData>,
164 DataDictionary common_data_dictionary = {},
165 DataDictionary state_data_dictionary = {});
166/**@}*/
167
168/** \name Generic Operator Factory */
169/**@{*/
176
177struct MODEL {
178 MODEL() = delete;
179};
180
181template <class MODEL, int MODEL_TYPE>
182boost::shared_ptr<PhysicalEquations>
183createMatOpsPhysicalEquationsPtr(boost::shared_ptr<MatOpsData> mat_ops_data_ptr,
184 int tag);
185
186template <class MODEL, int MODEL_TYPE> struct OpMaterialFactory {
188};
189/**@}*/
190
191} // namespace MatOps
192
193
194#endif // __MAT_OPS_HPP__
std::map< std::string, std::string > DataDictionary
Definition MatOps.hpp:22
@ MODEL_AXISYMMETRIC
Definition MatOps.hpp:174
@ MODEL_3D
Definition MatOps.hpp:171
@ MODEL_2D_PLANE_STRESS
Definition MatOps.hpp:173
@ MODEL_2D_PLANE_STRAIN
Definition MatOps.hpp:172
std::vector< StateTag > StateTags
Definition MatOps.hpp:21
boost::shared_ptr< PhysicalEquations > createMatOpsPhysicalEquationsPtr(boost::shared_ptr< MatOpsData > mat_ops_data_ptr, int tag)
boost::shared_ptr< MatOpsData > createMatOpsDataPtr()
Definition MatOps.cpp:671
static MoFEMErrorCode evaluateVariable(boost::shared_ptr< MatOpsData > mat_ops_data_ptr, int tag, EntityHandle entity, int gg)
Definition MatOps.cpp:685
static std::vector< double > dependentVariablesDerivatives
Definition MatOps.hpp:107
static std::vector< double > dependentVariables
Definition MatOps.hpp:106
static MoFEMErrorCode evaluateDerivatives(boost::shared_ptr< MatOpsData > mat_ops_data_ptr, int tag, EntityHandle entity, int gg)
Definition MatOps.cpp:705
static std::vector< double > activeVariables
Definition MatOps.hpp:105
static std::vector< double * > jacPtrVec
Definition MatOps.hpp:108
MODEL()=delete
virtual MoFEMErrorCode setActiveContinuousVector(std::vector< double > &active_variables)=0
virtual MoFEMErrorCode getDependentDerivativesContinuousVector(const std::vector< double > &dependent_variables_derivatives)=0
virtual MoFEMErrorCode setDependentDerivativesContinuousVector(std::vector< double > &dependent_variables_derivatives)=0
virtual MatrixPtr getActiveDataPtr(const std::string &name)=0
virtual std::pair< bool, MatrixPtr > insertDependentData(const std::string &name, const MatrixDouble &data=MatrixDouble(), int shift=0)=0
virtual MoFEMErrorCode setupStateData()=0
virtual std::pair< bool, MatrixPtr > insertActiveData(const std::string &name, const MatrixDouble &data=MatrixDouble(), int shift=0)=0
boost::shared_ptr< MatrixAdaptor > StateMatrixPtr
Definition MatOps.hpp:41
virtual MoFEMErrorCode bindStateTag(MoFEM::Interface &m_field, const std::string &tag_name, int num_components)=0
virtual ~MatOpsData()=default
virtual MoFEMErrorCode getActiveContinuousVector(const std::vector< double > &active_variables)=0
virtual std::pair< bool, MatrixPtr > insertCommonData(const std::string &name, const MatrixDouble &data=MatrixDouble(), int shift=0)=0
boost::shared_ptr< MatrixDouble > MatrixPtr
Definition MatOps.hpp:40
virtual MatrixPtr getCommonDataPtr(const std::string &name)=0
virtual StateTags getStateTags() const =0
virtual StateMatrixPtr getStateDataPtr(const std::string &name, EntityHandle ent, int gg)=0
virtual MatrixPtr getDependentDataPtr(const std::string &name)=0
virtual MoFEMErrorCode setDependentContinuousVector(std::vector< double > &dependent_variables)=0
virtual MatrixPtr getDependentDerivativesDataPtr(const std::string &name)=0
virtual std::pair< bool, MatrixPtr > insertDependentDerivativesData(const std::string &name, const MatrixDouble &data=MatrixDouble(), int shift=0)=0
virtual MoFEMErrorCode getDependentContinuousVector(const std::vector< double > &dependent_variables)=0
static int setTagName(std::string name, int tag=-1)
Definition MatOps.cpp:30
static std::string getTagName(int tag)
Definition MatOps.cpp:83
static int atTagName(std::string name)
Definition MatOps.cpp:26
static int getTagByName(std::string name)
Definition MatOps.cpp:73
static std::map< std::string, int > tagNameVsTag
Definition MatOps.hpp:32
PhysicalEquations(boost::shared_ptr< MatOpsData > mat_ops_data_ptr, int tag, boost::shared_ptr< std::map< int, Range > > tag_vs_range_ptr=nullptr)
Definition MatOps.hpp:114
virtual MoFEMErrorCode recordTape()=0
virtual ~PhysicalEquations()=default
virtual MoFEMErrorCode setParams(FEMethod *fe_ptr, int gg)=0
std::vector< std::pair< Range, std::vector< double > > > paramVecByRange
Definition MatOps.hpp:152
boost::shared_ptr< std::map< int, Range > > tagVsRangePtr
Definition MatOps.hpp:151
boost::shared_ptr< MatOpsData > matOpsDataPtr
Definition MatOps.hpp:154
virtual MoFEMErrorCode evaluateVariable(int tag, EntityHandle entity, int gg)
Definition MatOps.hpp:137
virtual MoFEMErrorCode evaluateDerivatives(int tag, EntityHandle entity, int gg)
Definition MatOps.hpp:141
virtual ForcesAndSourcesCore::UserDataOperator * createOp(boost::shared_ptr< PhysicalEquations > physical_ptr, bool eval_stress, bool eval_tangent, bool update)=0
HookFunction hookUpdateState
Definition MatOps.hpp:135
HookFunction hookEvaluateVariable
Definition MatOps.hpp:133
HookFunction hookEvaluateDerivatives
Definition MatOps.hpp:134
virtual MoFEMErrorCode getOptions(MoFEM::Interface *m_field_ptr=nullptr)=0
std::function< MoFEMErrorCode(boost::shared_ptr< MatOpsData >, int, EntityHandle, int)> HookFunction
Definition MatOps.hpp:131
virtual MoFEMErrorCode updateState(int tag, EntityHandle entity, int gg)
Definition MatOps.hpp:146
std::string name
Definition MatOps.hpp:16
Deprecated interface functions.