www.mooseframework.org
DiscreteNucleationForce.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 "DiscreteNucleationMap.h"
12 
14 
15 template <>
16 InputParameters
18 {
19  InputParameters params = validParams<Kernel>();
20  params.addClassDescription(
21  "Term for inserting grain nuclei or phases in non-conserved order parameter fields");
22  params.addRequiredParam<UserObjectName>("map", "DiscreteNucleationMap user object");
23  params.addParam<Real>("no_nucleus_value", 0.0, "Variable value indicating no nucleus is present");
24  params.addParam<Real>(
25  "nucleus_value", 1.0, "Variable value indicating the presence of a nucleus");
26  return params;
27 }
28 
29 DiscreteNucleationForce::DiscreteNucleationForce(const InputParameters & params)
30  : Kernel(params),
31  _map(getUserObject<DiscreteNucleationMap>("map")),
32  _v0(getParam<Real>("no_nucleus_value")),
33  _v1(getParam<Real>("nucleus_value"))
34 {
35 }
36 
37 void
39 {
40  // check if a nucleation event list is available for the current element
41  _nucleus = &_map.nuclei(_current_elem);
42 }
43 
44 Real
46 {
47  return -((*_nucleus)[_qp] * (_v1 - _v0) + _v0) * _test[_i][_qp];
48 }
DiscreteNucleationMap
This UserObject maintains a per QP map that indicates if a nucleus is present or not.
Definition: DiscreteNucleationMap.h:25
registerMooseObject
registerMooseObject("PhaseFieldApp", DiscreteNucleationForce)
DiscreteNucleationForce::precalculateResidual
void precalculateResidual() override
Definition: DiscreteNucleationForce.C:38
DiscreteNucleationMap.h
DiscreteNucleationForce
Free energy penalty contribution to force the nucleation of subresolution particles.
Definition: DiscreteNucleationForce.h:24
DiscreteNucleationForce::_v1
const Real _v1
Definition: DiscreteNucleationForce.h:41
DiscreteNucleationForce::_nucleus
const std::vector< Real > * _nucleus
nucleus data for the current element
Definition: DiscreteNucleationForce.h:37
DiscreteNucleationForce::_map
const DiscreteNucleationMap & _map
UserObject providing a map of currently active nuclei.
Definition: DiscreteNucleationForce.h:34
DiscreteNucleationForce::DiscreteNucleationForce
DiscreteNucleationForce(const InputParameters &params)
Definition: DiscreteNucleationForce.C:29
DiscreteNucleationMap::nuclei
const std::vector< Real > & nuclei(const Elem *) const
Definition: DiscreteNucleationMap.C:128
DiscreteNucleationForce::computeQpResidual
Real computeQpResidual() override
Definition: DiscreteNucleationForce.C:45
validParams< DiscreteNucleationForce >
InputParameters validParams< DiscreteNucleationForce >()
Definition: DiscreteNucleationForce.C:17
DiscreteNucleationForce::_v0
const Real _v0
Bounds for the returned values.
Definition: DiscreteNucleationForce.h:40
DiscreteNucleationForce.h