www.mooseframework.org
GBWidthAnisotropy.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 "GBWidthAnisotropy.h"
11 
12 registerMooseObject("PhaseFieldApp", GBWidthAnisotropy);
13 
14 template <>
15 InputParameters
17 {
18  InputParameters params = validParams<GBAnisotropyBase>();
19  params.addRequiredParam<Real>("mu", "Prefactor of bulk free energy");
20  params.addRequiredParam<Real>("kappa",
21  "Prefactor of gradient free energies for all i-j interfaces");
22  return params;
23 }
24 
25 GBWidthAnisotropy::GBWidthAnisotropy(const InputParameters & parameters)
26  : GBAnisotropyBase(parameters), _mu(getParam<Real>("mu")), _kappa(getParam<Real>("kappa"))
27 {
28  _mu_qp = _mu;
29  Real g2 = 0.0;
30  Real f_interf = 0.0;
31  Real a = 0.0;
32  Real gamma = 0.0;
33  Real y = 0.0; // 1/gamma
34  Real yyy = 0.0;
35 
36  for (unsigned int m = 0; m < _op_num - 1; ++m)
37  for (unsigned int n = m + 1; n < _op_num; ++n)
38  {
39  // Convert units of mobility and energy
40  _sigma[m][n] *= _JtoeV * (_length_scale * _length_scale); // eV/nm^2
41 
43  _length_scale)); // Convert to nm^4/(eV*ns);
44  }
45 
46  for (unsigned int m = 0; m < _op_num - 1; ++m)
47  for (unsigned int n = m + 1; n < _op_num; ++n) // m<n
48  {
49  g2 = _sigma[m][n] * _sigma[m][n] / (_kappa * _mu_qp);
50  y = -5.288 * g2 * g2 * g2 * g2 - 0.09364 * g2 * g2 * g2 + 9.965 * g2 * g2 - 8.183 * g2 +
51  2.007;
52  gamma = 1 / y;
53  yyy = y * y * y;
54  f_interf = 0.05676 * yyy * yyy - 0.2924 * yyy * y * y + 0.6367 * yyy * y - 0.7749 * yyy +
55  0.6107 * y * y - 0.4324 * y + 0.2792;
56  a = std::sqrt(f_interf / g2);
57 
58  _kappa_gamma[m][n] = _kappa; // upper triangle stores the discrete set of kappa values
59  _kappa_gamma[n][m] = gamma; // lower triangle stores the discrete set of gamma values
60 
61  _a_g2[m][n] = a; // upper triangle stores "a" data.
62  _a_g2[n][m] = g2; // lower triangle stores "g2" data.
63  }
64 }
GBAnisotropyBase
Function[kappa, gamma, m, L] = parameters (sigma, mob, w_GB, sigma0) Parameter determination method i...
Definition: GBAnisotropyBase.h:25
GBAnisotropyBase::_sigma
std::vector< std::vector< Real > > _sigma
Definition: GBAnisotropyBase.h:47
GBAnisotropyBase::_time_scale
const Real _time_scale
Definition: GBAnisotropyBase.h:36
GBAnisotropyBase::_mob
std::vector< std::vector< Real > > _mob
Definition: GBAnisotropyBase.h:48
GBAnisotropyBase::_kappa_gamma
std::vector< std::vector< Real > > _kappa_gamma
Definition: GBAnisotropyBase.h:50
GBAnisotropyBase::_length_scale
const Real _length_scale
Definition: GBAnisotropyBase.h:35
GBWidthAnisotropy::GBWidthAnisotropy
GBWidthAnisotropy(const InputParameters &parameters)
Definition: GBWidthAnisotropy.C:25
GBAnisotropyBase::_JtoeV
const Real _JtoeV
Definition: GBAnisotropyBase.h:63
GBWidthAnisotropy.h
registerMooseObject
registerMooseObject("PhaseFieldApp", GBWidthAnisotropy)
GBWidthAnisotropy::_kappa
const Real _kappa
Definition: GBWidthAnisotropy.h:35
GBAnisotropyBase::_op_num
const unsigned int _op_num
Definition: GBAnisotropyBase.h:66
validParams< GBAnisotropyBase >
InputParameters validParams< GBAnisotropyBase >()
Definition: GBAnisotropyBase.C:17
GBAnisotropyBase::_a_g2
std::vector< std::vector< Real > > _a_g2
Definition: GBAnisotropyBase.h:51
GBWidthAnisotropy
Function[kappa, gamma, m, L] = parameters (sigma, mob, w_GB, sigma0) Parameter determination method i...
Definition: GBWidthAnisotropy.h:28
validParams< GBWidthAnisotropy >
InputParameters validParams< GBWidthAnisotropy >()
Definition: GBWidthAnisotropy.C:16
GBAnisotropyBase::_mu_qp
Real _mu_qp
Definition: GBAnisotropyBase.h:64
GBWidthAnisotropy::_mu
const Real _mu
Definition: GBWidthAnisotropy.h:34