www.mooseframework.org
NewmarkVelAux.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 
10 #include "NewmarkVelAux.h"
11 
12 registerMooseObject("TensorMechanicsApp", NewmarkVelAux);
13 
15 
16 InputParameters
18 {
19  InputParameters params = AuxKernel::validParams();
20  params.addClassDescription("Calculates the current velocity using Newmark method.");
21  params.addRequiredCoupledVar("acceleration", "acceleration variable");
22  params.addRequiredParam<Real>("gamma", "gamma parameter for Newmark method");
23  return params;
24 }
25 
26 NewmarkVelAux::NewmarkVelAux(const InputParameters & parameters)
27  : AuxKernel(parameters),
28  _accel_old(coupledValueOld("acceleration")),
29  _accel(coupledValue("acceleration")),
30  _gamma(getParam<Real>("gamma"))
31 {
32 }
33 
34 Real
36 {
37  Real vel_old = _u_old[_qp];
38  if (!isNodal())
39  mooseError("must run on a nodal variable");
40  // Calculates Velocity using Newmark time integration scheme
41  return vel_old + (_dt * (1 - _gamma)) * _accel_old[_qp] + _gamma * _dt * _accel[_qp];
42 }
defineLegacyParams
defineLegacyParams(NewmarkVelAux)
NewmarkVelAux::validParams
static InputParameters validParams()
Definition: NewmarkVelAux.C:17
registerMooseObject
registerMooseObject("TensorMechanicsApp", NewmarkVelAux)
NewmarkVelAux::_accel_old
const VariableValue & _accel_old
Definition: NewmarkVelAux.h:34
NewmarkVelAux
Definition: NewmarkVelAux.h:19
validParams
InputParameters validParams()
NewmarkVelAux.h
NewmarkVelAux::_accel
const VariableValue & _accel
Definition: NewmarkVelAux.h:35
NewmarkVelAux::NewmarkVelAux
NewmarkVelAux(const InputParameters &parameters)
Calcualtes velocity using Newmark time integration scheme.
Definition: NewmarkVelAux.C:26
NewmarkVelAux::_gamma
Real _gamma
Definition: NewmarkVelAux.h:36
NewmarkVelAux::computeValue
virtual Real computeValue()
Definition: NewmarkVelAux.C:35