www.mooseframework.org
ComputeVolumetricEigenstrain.h
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 #pragma once
11 
12 #include "ComputeEigenstrainBase.h"
13 #include "DerivativeMaterialInterface.h"
14 
16 
17 template <>
19 
26 class ComputeVolumetricEigenstrain : public DerivativeMaterialInterface<ComputeEigenstrainBase>
27 {
28 public:
29  static InputParameters validParams();
30 
31  ComputeVolumetricEigenstrain(const InputParameters & parameters);
32 
33 protected:
34  virtual void initialSetup();
35  virtual void computeQpEigenstrain();
36 
38  const unsigned int _num_args;
39 
41  const std::vector<MaterialPropertyName> _volumetric_material_names;
43  std::vector<const MaterialProperty<Real> *> _volumetric_materials;
44 
46  std::vector<std::vector<const MaterialProperty<Real> *>> _dvolumetric_materials;
48  std::vector<std::vector<std::vector<const MaterialProperty<Real> *>>> _d2volumetric_materials;
49 
51  std::vector<MaterialProperty<RankTwoTensor> *> _delastic_strain;
53  std::vector<std::vector<MaterialProperty<RankTwoTensor> *>> _d2elastic_strain;
54 };
ComputeVolumetricEigenstrain::_num_args
const unsigned int _num_args
number of variables the material depends on
Definition: ComputeVolumetricEigenstrain.h:38
ComputeVolumetricEigenstrain
ComputeVolumetricEigenstrain computes an eigenstrain that is defined by a set of scalar material prop...
Definition: ComputeVolumetricEigenstrain.h:26
ComputeVolumetricEigenstrain::_volumetric_materials
std::vector< const MaterialProperty< Real > * > _volumetric_materials
The material properties that define volumetric change.
Definition: ComputeVolumetricEigenstrain.h:43
ComputeVolumetricEigenstrain::computeQpEigenstrain
virtual void computeQpEigenstrain()
Definition: ComputeVolumetricEigenstrain.C:108
validParams< ComputeVolumetricEigenstrain >
InputParameters validParams< ComputeVolumetricEigenstrain >()
ComputeVolumetricEigenstrain::ComputeVolumetricEigenstrain
ComputeVolumetricEigenstrain(const InputParameters &parameters)
Definition: ComputeVolumetricEigenstrain.C:31
ComputeVolumetricEigenstrain::_dvolumetric_materials
std::vector< std::vector< const MaterialProperty< Real > * > > _dvolumetric_materials
first derivatives of the volumetric materials with respect to the args
Definition: ComputeVolumetricEigenstrain.h:46
ComputeVolumetricEigenstrain::_d2elastic_strain
std::vector< std::vector< MaterialProperty< RankTwoTensor > * > > _d2elastic_strain
second derivatives of the elastic strain with respect to the args
Definition: ComputeVolumetricEigenstrain.h:53
ComputeVolumetricEigenstrain::_delastic_strain
std::vector< MaterialProperty< RankTwoTensor > * > _delastic_strain
first derivatives of the elastic strain with respect to the args
Definition: ComputeVolumetricEigenstrain.h:51
ComputeVolumetricEigenstrain::validParams
static InputParameters validParams()
Definition: ComputeVolumetricEigenstrain.C:18
ComputeVolumetricEigenstrain::initialSetup
virtual void initialSetup()
Definition: ComputeVolumetricEigenstrain.C:82
ComputeVolumetricEigenstrain::_d2volumetric_materials
std::vector< std::vector< std::vector< const MaterialProperty< Real > * > > > _d2volumetric_materials
second derivatives of the volumetric materials with respect to the args
Definition: ComputeVolumetricEigenstrain.h:48
ComputeEigenstrainBase.h
ComputeVolumetricEigenstrain::_volumetric_material_names
const std::vector< MaterialPropertyName > _volumetric_material_names
Names of the material properties that define volumetric change.
Definition: ComputeVolumetricEigenstrain.h:41