libMesh::VariableGroup Class Reference

#include <variable.h>

Inheritance diagram for libMesh::VariableGroup:

Public Member Functions

 VariableGroup (System *sys, const std::vector< std::string > &var_names, const unsigned int var_number, const unsigned int first_scalar_num, const FEType &var_type)
 
 VariableGroup (System *sys, const std::vector< std::string > &var_names, const unsigned int var_number, const unsigned int first_scalar_num, const FEType &var_type, const std::set< subdomain_id_type > &var_active_subdomains)
 
unsigned int n_variables () const
 
Variable variable (unsigned int v) const
 
Variable operator() (unsigned int v) const
 
const std::string & name (unsigned int v) const
 
unsigned int number (unsigned int v) const
 
unsigned int first_scalar_number (unsigned int v) const
 
void append (const std::string &var_name)
 
unsigned int number () const
 
Systemsystem () const
 
const std::string & name () const
 
unsigned int number () const
 
unsigned int first_scalar_number () const
 
const FETypetype () const
 
unsigned int n_components () const
 
bool active_on_subdomain (subdomain_id_type sid) const
 
bool implicitly_active () const
 
const std::set< subdomain_id_type > & active_subdomains () const
 

Protected Attributes

std::vector< std::string > _names
 
System_sys
 
std::string _name
 
std::set< subdomain_id_type_active_subdomains
 
unsigned int _number
 
unsigned int _first_scalar_number
 
FEType _type
 

Detailed Description

This class defines a logically grouped set of variables in the system. VariableGroup is appropriate for representing several unknowns in the problem that are all approximated with the same finite element approximation family and (optionally) a list of subdomains to which the variables are restricted.

Definition at line 172 of file variable.h.

Constructor & Destructor Documentation

◆ VariableGroup() [1/2]

libMesh::VariableGroup::VariableGroup ( System sys,
const std::vector< std::string > &  var_names,
const unsigned int  var_number,
const unsigned int  first_scalar_num,
const FEType var_type 
)
inline

Constructor. Omits the subdomain mapping, hence this constructor creates a variable which is active on all subdomains.

Definition at line 180 of file variable.h.

184  :
185  Variable (sys,
186  "var_group",
187  var_number,
188  first_scalar_num,
189  var_type),
190  _names(var_names)
191  {}
Variable(System *sys, const std::string &var_name, const unsigned int var_number, const unsigned int first_scalar_num, const FEType &var_type)
Definition: variable.h:58
std::vector< std::string > _names
Definition: variable.h:283

◆ VariableGroup() [2/2]

libMesh::VariableGroup::VariableGroup ( System sys,
const std::vector< std::string > &  var_names,
const unsigned int  var_number,
const unsigned int  first_scalar_num,
const FEType var_type,
const std::set< subdomain_id_type > &  var_active_subdomains 
)
inline

Constructor. Takes a set which contains the subdomain indices for which this variable is active.

Definition at line 198 of file variable.h.

203  :
204 
205  Variable (sys,
206  "var_group",
207  var_number,
208  first_scalar_num,
209  var_type,
210  var_active_subdomains),
211  _names(var_names)
212  {}
Variable(System *sys, const std::string &var_name, const unsigned int var_number, const unsigned int first_scalar_num, const FEType &var_type)
Definition: variable.h:58
std::vector< std::string > _names
Definition: variable.h:283

Member Function Documentation

◆ active_on_subdomain()

◆ active_subdomains()

const std::set<subdomain_id_type>& libMesh::Variable::active_subdomains ( ) const
inlineinherited
Returns
The set of subdomain ids this variable lives on.

Definition at line 150 of file variable.h.

References libMesh::Variable::_active_subdomains.

Referenced by libMesh::DifferentiableSystem::add_second_order_dot_vars(), libMesh::EquationSystems::get_vars_active_subdomains(), variable(), and libMesh::System::write_header().

151  { return _active_subdomains; }
std::set< subdomain_id_type > _active_subdomains
Definition: variable.h:156

◆ append()

void libMesh::VariableGroup::append ( const std::string &  var_name)
inline

Appends a variable to the group. Really only can be used by System in a very limited window of opportunity - after the user specifies variables but before the system is initialized.

Definition at line 279 of file variable.h.

References _names.

Referenced by libMesh::System::add_variable().

280  { _names.push_back (var_name); }
std::vector< std::string > _names
Definition: variable.h:283

◆ first_scalar_number() [1/2]

unsigned int libMesh::Variable::first_scalar_number ( ) const
inlineinherited
Returns
The index of the first scalar component of this variable in the system.

Definition at line 113 of file variable.h.

References libMesh::Variable::_first_scalar_number.

Referenced by libMesh::System::n_components(), and variable().

114  { return _first_scalar_number; }
unsigned int _first_scalar_number
Definition: variable.h:158

◆ first_scalar_number() [2/2]

unsigned int libMesh::VariableGroup::first_scalar_number ( unsigned int  v) const
inline
Returns
The index of the first scalar component of this variable in the system.

Definition at line 268 of file variable.h.

References libMesh::Variable::_first_scalar_number, and n_variables().

269  {
270  libmesh_assert_less (v, this->n_variables());
271  return _first_scalar_number+v;
272  }
unsigned int _first_scalar_number
Definition: variable.h:158
unsigned int n_variables() const
Definition: variable.h:217

◆ implicitly_active()

bool libMesh::Variable::implicitly_active ( ) const
inlineinherited
Returns
true if this variable is active on all subdomains because it has no specified activity map. This can be used to perform more efficient computations in some places.

Definition at line 144 of file variable.h.

References libMesh::Variable::_active_subdomains.

145  { return _active_subdomains.empty(); }
std::set< subdomain_id_type > _active_subdomains
Definition: variable.h:156

◆ n_components()

unsigned int libMesh::Variable::n_components ( ) const
inlineinherited
Returns
The number of components of this variable.

Definition at line 125 of file variable.h.

References libMesh::Variable::_type, libMesh::FEType::family, libMesh::OrderWrapper::get_order(), libMesh::FEType::order, libMesh::SCALAR, and libMesh::Variable::type().

Referenced by libMesh::System::n_components().

126  { return type().family == SCALAR ? _type.order.get_order() : 1; }
FEFamily family
Definition: fe_type.h:204
OrderWrapper order
Definition: fe_type.h:198
int get_order() const
Definition: fe_type.h:78
const FEType & type() const
Definition: variable.h:119

◆ n_variables()

unsigned int libMesh::VariableGroup::n_variables ( ) const
inline

◆ name() [1/2]

const std::string& libMesh::Variable::name ( ) const
inlineinherited
Returns
The user-specified name of the variable.

Definition at line 100 of file variable.h.

References libMesh::Variable::_name.

Referenced by libMesh::DifferentiableSystem::add_second_order_dot_vars(), DMlibMeshSetSystem_libMesh(), and variable().

101  { return _name; }
std::string _name
Definition: variable.h:155

◆ name() [2/2]

const std::string& libMesh::VariableGroup::name ( unsigned int  v) const
inline
Returns
The user-specified name of the variable.

Definition at line 246 of file variable.h.

References _names, and n_variables().

Referenced by libMesh::System::get_info().

247  {
248  libmesh_assert_less (v, this->n_variables());
249  return _names[v];
250  }
unsigned int n_variables() const
Definition: variable.h:217
std::vector< std::string > _names
Definition: variable.h:283

◆ number() [1/3]

unsigned int libMesh::Variable::number ( ) const
inlineinherited
Returns
The rank of this variable in the system.

Definition at line 106 of file variable.h.

References libMesh::Variable::_number.

Referenced by variable().

107  { return _number; }
unsigned int _number
Definition: variable.h:157

◆ number() [2/3]

unsigned int libMesh::VariableGroup::number ( unsigned int  v) const
inline
Returns
The rank of this variable in the system.

Definition at line 255 of file variable.h.

References libMesh::Variable::_number, and n_variables().

Referenced by libMesh::DofMap::dof_indices(), and libMesh::DofMap::old_dof_indices().

256  {
257  libmesh_assert_less (v, this->n_variables());
258  return _number + v;
259  }
unsigned int n_variables() const
Definition: variable.h:217
unsigned int _number
Definition: variable.h:157

◆ number() [3/3]

unsigned int libMesh::Variable::number
inline
Returns
The rank of this variable in the system.

Definition at line 106 of file variable.h.

107  { return _number; }
unsigned int _number
Definition: variable.h:157

◆ operator()()

Variable libMesh::VariableGroup::operator() ( unsigned int  v) const
inline

Support vg(v).

Returns
A Variable for v.

Definition at line 240 of file variable.h.

References variable().

241  { return this->variable(v); }
Variable variable(unsigned int v) const
Definition: variable.h:224

◆ system()

System* libMesh::Variable::system ( ) const
inlineinherited
Returns
A pointer to the System this Variable is part of.

Definition at line 92 of file variable.h.

References libMesh::Variable::_sys.

Referenced by variable().

93  {
94  return _sys;
95  }
System * _sys
Definition: variable.h:154

◆ type()

◆ variable()

Variable libMesh::VariableGroup::variable ( unsigned int  v) const
inline
Returns
A Variable object constructed for an individual member of our group.

Definition at line 224 of file variable.h.

References libMesh::Variable::active_subdomains(), libMesh::Variable::first_scalar_number(), n_variables(), libMesh::Variable::name(), libMesh::Variable::number(), libMesh::Variable::system(), libMesh::Variable::type(), and libMesh::Variable::Variable().

Referenced by operator()().

225  {
226  libmesh_assert_less (v, this->n_variables());
227  return Variable (this->system(),
228  this->name(v),
229  this->number(v),
230  this->first_scalar_number(v),
231  this->type(),
232  this->active_subdomains());
233  }
Variable(System *sys, const std::string &var_name, const unsigned int var_number, const unsigned int first_scalar_num, const FEType &var_type)
Definition: variable.h:58
unsigned int first_scalar_number() const
Definition: variable.h:113
const std::set< subdomain_id_type > & active_subdomains() const
Definition: variable.h:150
unsigned int n_variables() const
Definition: variable.h:217
System * system() const
Definition: variable.h:92
const std::string & name() const
Definition: variable.h:100
unsigned int number() const
Definition: variable.h:106
const FEType & type() const
Definition: variable.h:119

Member Data Documentation

◆ _active_subdomains

std::set<subdomain_id_type> libMesh::Variable::_active_subdomains
protectedinherited

◆ _first_scalar_number

unsigned int libMesh::Variable::_first_scalar_number
protectedinherited

Definition at line 158 of file variable.h.

Referenced by libMesh::Variable::first_scalar_number(), and first_scalar_number().

◆ _name

std::string libMesh::Variable::_name
protectedinherited

Definition at line 155 of file variable.h.

Referenced by libMesh::Variable::name().

◆ _names

std::vector<std::string> libMesh::VariableGroup::_names
protected

Definition at line 283 of file variable.h.

Referenced by append(), n_variables(), and name().

◆ _number

unsigned int libMesh::Variable::_number
protectedinherited

Definition at line 157 of file variable.h.

Referenced by libMesh::Variable::number(), and number().

◆ _sys

System* libMesh::Variable::_sys
protectedinherited

Definition at line 154 of file variable.h.

Referenced by libMesh::Variable::system().

◆ _type

FEType libMesh::Variable::_type
protectedinherited

Definition at line 159 of file variable.h.

Referenced by libMesh::Variable::n_components(), and libMesh::Variable::type().


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