https://mooseframework.inl.gov
MooseVariableDataBase.h
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://mooseframework.inl.gov
3 //*
4 //* All rights reserved, see COPYRIGHT for full restrictions
5 //* https://github.com/idaholab/moose/blob/master/COPYRIGHT
6 //*
7 //* Licensed under LGPL 2.1, please see LICENSE for details
8 //* https://www.gnu.org/licenses/lgpl-2.1.html
9 
10 #pragma once
11 
12 #include "MooseArray.h"
13 #include "MooseTypes.h"
14 
15 #include "libmesh/tensor_tools.h"
16 #include "libmesh/vector_value.h"
17 #include "libmesh/tensor_value.h"
18 #include "libmesh/type_n_tensor.h"
19 #include "libmesh/enum_fe_family.h"
20 
21 #include <vector>
22 
23 template <typename>
24 class MooseVariableField;
25 class SubProblem;
26 class SystemBase;
27 namespace libMesh
28 {
29 class DofMap;
30 }
31 
32 template <typename OutputType>
34 {
35 public:
36  // type for gradient, second and divergence of template class OutputType
40 
41  // shortcut for types storing values on quadrature points
44 
45  // DoF value type for the template class OutputType
50 
52  SystemBase & sys,
53  THREAD_ID tid);
54 
55  virtual ~MooseVariableDataBase() = default;
56 
60  virtual bool isNodal() const = 0;
61 
65  virtual bool hasDoFsOnNodes() const = 0;
66 
70  virtual libMesh::FEContinuity getContinuity() const = 0;
71 
76  const FieldVariableValue & sln(Moose::SolutionState state) const;
77 
83 
88  unsigned int oldestSolutionStateRequested() const;
89 
93  void setNodalValue(const OutputType & value, unsigned int idx = 0);
94 
99 
104 
108  void prepareIC();
109 
111 
112  const DofValues & dofValues() const;
113  const DofValues & dofValuesOld() const;
114  const DofValues & dofValuesOlder() const;
115  const DofValues & dofValuesPreviousNL() const;
116 
118 
119  const OutputType & nodalValue(Moose::SolutionState state) const;
121 
123 
124  const FieldVariableValue & vectorTagValue(TagID tag) const;
125  const FieldVariableGradient & vectorTagGradient(TagID tag) const;
126  const FieldVariableValue & matrixTagValue(TagID tag) const;
127  const DofValues & nodalVectorTagValue(TagID tag) const;
128  const DofValues & nodalMatrixTagValue(TagID tag) const;
129  const DofValues & vectorTagDofValue(TagID tag) const;
130  const DofValues & vectorTagDofValue(Moose::SolutionState state) const;
131 
137  void setActiveTags(const std::set<TagID> & vtags);
138 
142  void prepareAux() { _has_dof_values = false; }
143 
147  void sizeMatrixTagData();
148 
149 protected:
153  virtual const MooseVariableField<OutputType> & var() const { return _var; }
154 
158  void insertSolutionTag(TagID tag_id);
159 
163  void needSolutionState(unsigned int state);
164 
168  void fetchDofValues();
169  void zeroSizeDofValues();
171  unsigned int n,
172  MooseArray<RealEigenVector> & dof_values) const;
173  void assignNodalValue();
174 
180  template <typename ReturnType, typename Functor>
181  const ReturnType & stateToTagHelper(Moose::SolutionState state, Functor functor);
182 
186  void resizeVectorTagData(TagID tag);
187 
191 
194 
197 
200 
202  unsigned int _count;
203 
207 
209  unsigned int _max_state;
210 
213 
216 
219 
222 
224  std::vector<dof_id_type> _dof_indices;
225 
226  mutable std::vector<bool> _need_vector_tag_dof_u;
227  mutable std::vector<bool> _need_matrix_tag_dof_u;
228 
229  // Dof values of tagged vectors
230  std::vector<DofValues> _vector_tags_dof_u;
231  // Dof values of the diagonal of tagged matrices
232  std::vector<DofValues> _matrix_tags_dof_u;
233 
234  std::vector<FieldVariableValue> _vector_tag_u;
235  mutable std::vector<bool> _need_vector_tag_u;
236  std::vector<FieldVariableGradient> _vector_tag_grad;
237  mutable std::vector<bool> _need_vector_tag_grad;
238  std::vector<FieldVariableValue> _matrix_tag_u;
239  mutable std::vector<bool> _need_matrix_tag_u;
240 
242  OutputType _nodal_value;
243  OutputType _nodal_value_old;
244  OutputType _nodal_value_older;
246 
251 
253  mutable bool _need_u_dot;
254  mutable bool _need_u_dotdot;
255  mutable bool _need_u_dot_old;
256  mutable bool _need_u_dotdot_old;
257  mutable bool _need_du_dot_du;
258  mutable bool _need_du_dotdot_du;
259 
261  mutable bool _need_grad_dot;
262  mutable bool _need_grad_dotdot;
263 
265  mutable bool _need_dof_values_dot;
269  mutable bool _need_dof_du_dot_du;
271 
285 
287  OutputType _nodal_value_dot;
294 
296  std::set<TagID> _required_vector_tags;
297 
299  std::set<TagID> _solution_tags;
300 
301 private:
304 };
305 
306 template <>
308 
309 template <>
311 
312 template <typename OutputType>
313 void
315 {
316  _required_vector_tags = _solution_tags;
317  for (const auto tag : vtags)
318  _required_vector_tags.insert(tag);
319 
320  if (!_required_vector_tags.empty())
321  {
322  const auto largest_tag_id = *_required_vector_tags.rbegin();
323  if (largest_tag_id >= _need_vector_tag_dof_u.size())
324  resizeVectorTagData(largest_tag_id);
325  }
326 }
327 
328 template <typename OutputType>
329 void
331 {
332  _solution_tags.insert(tag_id);
333  _required_vector_tags.insert(tag_id);
334 }
bool _need_grad_dot
gradient dot flags
const libMesh::DofMap & _dof_map
The degree of freedom map from libMesh.
MooseArray< DofValue > DofValues
std::vector< DofValues > _matrix_tags_dof_u
unsigned int TagID
Definition: MooseTypes.h:238
void resizeVectorTagData(TagID tag)
resize the vector tag need flags and data containers to accomodate this tag index ...
const FieldVariableValue & matrixTagValue(TagID tag) const
void prepareIC()
prepare the initial condition
std::vector< FieldVariableValue > _matrix_tag_u
Class for stuff related to variables.
const ReturnType & stateToTagHelper(Moose::SolutionState state, Functor functor)
Helper method that converts a SolutionState argument into a corresponding tag ID, potentially request...
void sizeMatrixTagData()
size matrix tag data
void prepareAux()
Clear aux state.
const FieldVariableGradient & vectorTagGradient(TagID tag) const
OutputType type
Definition: MooseTypes.h:297
const DofValues & nodalVectorTagValue(TagID tag) const
const MooseArray< OutputType > & nodalValueArray(Moose::SolutionState state) const
std::vector< bool > _need_vector_tag_u
MooseArray< OutputGradient > FieldVariableGradient
DofValues _dof_values_dotdot_old
the previous time step&#39;s solution value second time derivative
virtual ~MooseVariableDataBase()=default
void getArrayDofValues(const libMesh::NumericVector< libMesh::Number > &sol, unsigned int n, MooseArray< RealEigenVector > &dof_values) const
The following methods are specializations for using the libMesh::Parallel::packed_range_* routines fo...
const SubProblem & _subproblem
The subproblem which we can query for information related to tagged vectors and matrices.
void setActiveTags(const std::set< TagID > &vtags)
Set the active vector tags.
Base class for a system (of equations)
Definition: SystemBase.h:84
Moose::ADType< DofValue >::type ADDofValue
std::vector< bool > _need_vector_tag_grad
const DofValues & vectorTagDofValue(TagID tag) const
libMesh::TensorTools::DecrementRank< OutputType >::type OutputDivergence
std::vector< bool > _need_vector_tag_dof_u
MooseArray< libMesh::Number > _dof_du_dot_du
derivatives of the solution value time derivative with respect to the degrees of freedom ...
void add(libMesh::NumericVector< libMesh::Number > &residual)
Add the current local DOF values to the input vector.
OutputType _nodal_value
Nodal values.
void setNodalValue(const OutputType &value, unsigned int idx=0)
Set nodal value.
MooseArray< libMesh::Number > _dof_du_dotdot_du
derivatives of the solution value second time derivative with respect to the degrees of freedom ...
std::set< TagID > _solution_tags
The set of solution tags we need to evaluate.
void insert(libMesh::NumericVector< libMesh::Number > &residual)
Set the current local DOF values to the input vector.
const FieldVariableGradient & gradSln(Moose::SolutionState state) const
Local solution gradient getter.
FunctorEnvelope< T > Functor
DofValues _dof_values_dotdot
second time derivative of the solution values
MooseArray< OutputType > _nodal_value_array
Nodal values as MooseArrays for use with AuxKernels.
virtual const MooseVariableField< OutputType > & var() const
Moose::DOFType< OutputType >::type DofValue
TagID _older_solution_tag
The vector tag ID corresponding to the older solution vector.
const OutputType & nodalValue(Moose::SolutionState state) const
std::set< TagID > _required_vector_tags
The set of vector tags (residual + solution) we need to evaluate.
const DofValues & nodalMatrixTagValue(TagID tag) const
void insertSolutionTag(TagID tag_id)
insert a solution tag into our tag containers
bool _has_dof_values
Whether we currently have degree of freedom values stored in our local containers (corresponding to t...
std::vector< DofValues > _vector_tags_dof_u
OutputType _nodal_value_dotdot
nodal values of u_dotdot
MooseArray< OutputType > FieldVariableValue
MooseVariableDataBase(const MooseVariableField< OutputType > &var, SystemBase &sys, THREAD_ID tid)
TagID _solution_tag
The vector tag ID corresponding to the solution vector.
const DofValues & dofValuesOlder() const
OutputType _nodal_value_dot_old
nodal values of u_dot_old
DofValues _dof_values_dot
time derivative of the solution values
MooseArray< OutputType > _nodal_value_old_array
std::vector< bool > _need_matrix_tag_u
OutputType _nodal_value_dotdot_old
nodal values of u_dotdot_old
libMesh::TensorTools::IncrementRank< OutputType >::type OutputGradient
const FieldVariableValue & vectorTagValue(TagID tag) const
virtual bool isNodal() const =0
TagID _old_solution_tag
The vector tag ID corresponding to the old solution vector.
void fetchDofValues()
Helper methods for assigning dof values from their corresponding solution values. ...
virtual libMesh::FEContinuity getContinuity() const =0
Return the variable continuity.
Generic class for solving transient nonlinear problems.
Definition: SubProblem.h:78
std::vector< bool > _need_matrix_tag_dof_u
const DofValues & dofValuesPreviousNL() const
OutputType _nodal_value_dot
nodal values of u_dot
SolutionState
Definition: MooseTypes.h:261
std::vector< FieldVariableGradient > _vector_tag_grad
SystemBase & _sys
The MOOSE system which ultimately holds the vectors and matrices relevant to this variable data...
MooseArray< ADDofValue > ADDofValues
unsigned int _count
Number of components of the associated variable.
const FieldVariableValue & sln(Moose::SolutionState state) const
Local solution getter.
TagID _previous_nl_solution_tag
The vector tag ID corresponding to the previous nonlinear iteration&#39;s solution vector.
bool _need_dof_values_dot
local solution flags
const THREAD_ID _tid
The thread ID that this object is on.
MooseArray< OutputType > _nodal_value_older_array
libMesh::TensorTools::IncrementRank< OutputGradient >::type OutputSecond
void needSolutionState(unsigned int state)
Request that we have at least state number of older solution states/vectors.
DofValues _dof_values_dot_old
the previous time step&#39;s solution value time derivative
std::vector< FieldVariableValue > _vector_tag_u
const DofValues & dofValuesOld() const
std::vector< dof_id_type > _dof_indices
The dof indices for the current element.
const MooseVariableField< OutputType > & _var
A const reference to the owning MooseVariableField object.
unsigned int _max_state
The maximum number of older solution states our variable needs.
virtual bool hasDoFsOnNodes() const =0
Whether this data is associated with a variable that has DoFs on nodes.
unsigned int oldestSolutionStateRequested() const
The oldest solution state that is requested for this variable (0 = current, 1 = old, 2 = older, etc).
unsigned int THREAD_ID
Definition: MooseTypes.h:237
const DofValues & dofValues() const