www.mooseframework.org
NodalAuxVariableUserObjectBasePD.C
Go to the documentation of this file.
1 //* This file is part of the MOOSE framework
2 //* https://www.mooseframework.org
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 
11 #include "AuxiliarySystem.h"
12 #include "PeridynamicsMesh.h"
13 #include "MooseVariable.h"
14 
15 template <>
16 InputParameters
18 {
19  InputParameters params = validParams<ElementUserObjectBasePD>();
20  params.addClassDescription("Base class for computing value for nodal AuxVariable from elemental "
21  "information in a peridynamic model");
22 
23  params.addRequiredCoupledVar("variable", "Name of AuxVariable this userobject is acting on");
24 
25  return params;
26 }
27 
29  const InputParameters & parameters)
30  : ElementUserObjectBasePD(parameters), _var(getVar("variable", 0))
31 {
32 }
33 
34 void
36 {
37  std::vector<std::string> zero_vars;
38  zero_vars.push_back(_var->name());
39  _aux.zeroVariables(zero_vars);
40 }
41 
42 void
44 {
45  for (unsigned int i = 0; i < 2; ++i)
46  {
47  dof_id_type dof = _current_elem->node_ptr(i)->dof_number(_aux.number(), _var->number(), 0);
48 
49  computeValue(i, dof);
50  }
51 }
52 
53 void
55 {
56  _aux_sln.close();
57 }
ElementUserObjectBasePD::_aux
AuxiliarySystem & _aux
Reference to auxiliary system.
Definition: ElementUserObjectBasePD.h:33
NodalAuxVariableUserObjectBasePD.h
validParams< ElementUserObjectBasePD >
InputParameters validParams< ElementUserObjectBasePD >()
Definition: ElementUserObjectBasePD.C:16
validParams< NodalAuxVariableUserObjectBasePD >
InputParameters validParams< NodalAuxVariableUserObjectBasePD >()
Definition: NodalAuxVariableUserObjectBasePD.C:17
NodalAuxVariableUserObjectBasePD::execute
virtual void execute() override
Definition: NodalAuxVariableUserObjectBasePD.C:43
NodalAuxVariableUserObjectBasePD::finalize
virtual void finalize() override
Definition: NodalAuxVariableUserObjectBasePD.C:54
PeridynamicsMesh.h
NodalAuxVariableUserObjectBasePD::NodalAuxVariableUserObjectBasePD
NodalAuxVariableUserObjectBasePD(const InputParameters &parameters)
Definition: NodalAuxVariableUserObjectBasePD.C:28
NodalAuxVariableUserObjectBasePD::computeValue
virtual void computeValue(unsigned int id, dof_id_type dof)=0
Function to assemble elemental quantities to nodal AuxVariable at a material point.
NodalAuxVariableUserObjectBasePD::_var
MooseVariable * _var
Pointer to the aux variable this userobject operates on.
Definition: NodalAuxVariableUserObjectBasePD.h:43
ElementUserObjectBasePD
Base element userobject class for peridynamics.
Definition: ElementUserObjectBasePD.h:23
NodalAuxVariableUserObjectBasePD::initialize
virtual void initialize() override
Definition: NodalAuxVariableUserObjectBasePD.C:35
ElementUserObjectBasePD::_aux_sln
NumericVector< Number > & _aux_sln
Solution vector for aux variables.
Definition: ElementUserObjectBasePD.h:36