www.mooseframework.org
ElasticEnergyMaterial.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 "DerivativeFunctionMaterialBase.h"
13 
14 // Forward Declaration
16 template <typename>
19 template <typename>
22 
23 template <>
24 InputParameters validParams<ElasticEnergyMaterial>();
25 
29 class ElasticEnergyMaterial : public DerivativeFunctionMaterialBase
30 {
31 public:
32  ElasticEnergyMaterial(const InputParameters & parameters);
33 
34  virtual void initialSetup() override;
35 
36 protected:
37  virtual Real computeF() override;
38  virtual Real computeDF(unsigned int i_var) override;
39  virtual Real computeD2F(unsigned int i_var, unsigned int j_var) override;
40 
41  const std::string _base_name;
42 
44  const MaterialProperty<RankTwoTensor> & _stress;
45  // std::vector<const MaterialProperty<RankTwoTensor> *> _dstress;
46  // std::vector<std::vector<const MaterialProperty<RankTwoTensor> *> > _d2stress;
47 
49  const MaterialProperty<RankFourTensor> & _elasticity_tensor;
50  std::vector<const MaterialProperty<RankFourTensor> *> _delasticity_tensor;
51  std::vector<std::vector<const MaterialProperty<RankFourTensor> *>> _d2elasticity_tensor;
53 
55  const MaterialProperty<RankTwoTensor> & _strain;
56  std::vector<const MaterialProperty<RankTwoTensor> *> _dstrain;
57  std::vector<std::vector<const MaterialProperty<RankTwoTensor> *>> _d2strain;
59 };
60 
ElasticEnergyMaterial::computeD2F
virtual Real computeD2F(unsigned int i_var, unsigned int j_var) override
Definition: ElasticEnergyMaterial.C:89
ElasticEnergyMaterial::ElasticEnergyMaterial
ElasticEnergyMaterial(const InputParameters &parameters)
Definition: ElasticEnergyMaterial.C:31
ElasticEnergyMaterial::_stress
const MaterialProperty< RankTwoTensor > & _stress
Stress tensor.
Definition: ElasticEnergyMaterial.h:44
ElasticEnergyMaterial::_strain
const MaterialProperty< RankTwoTensor > & _strain
Strain and derivatives.
Definition: ElasticEnergyMaterial.h:55
ElasticEnergyMaterial::_d2strain
std::vector< std::vector< const MaterialProperty< RankTwoTensor > * > > _d2strain
Definition: ElasticEnergyMaterial.h:57
RankFourTensor
RankFourTensorTempl< Real > RankFourTensor
Definition: ElasticEnergyMaterial.h:20
ElasticEnergyMaterial::_dstrain
std::vector< const MaterialProperty< RankTwoTensor > * > _dstrain
Definition: ElasticEnergyMaterial.h:56
ElasticEnergyMaterial::_delasticity_tensor
std::vector< const MaterialProperty< RankFourTensor > * > _delasticity_tensor
Definition: ElasticEnergyMaterial.h:50
RankFourTensorTempl
Definition: ACGrGrElasticDrivingForce.h:20
ElasticEnergyMaterial::_d2elasticity_tensor
std::vector< std::vector< const MaterialProperty< RankFourTensor > * > > _d2elasticity_tensor
Definition: ElasticEnergyMaterial.h:51
validParams< ElasticEnergyMaterial >
InputParameters validParams< ElasticEnergyMaterial >()
Definition: ElasticEnergyMaterial.C:18
ElasticEnergyMaterial::_elasticity_tensor
const MaterialProperty< RankFourTensor > & _elasticity_tensor
Elasticity tensor derivatives.
Definition: ElasticEnergyMaterial.h:49
RankTwoTensorTempl
Definition: ACGrGrElasticDrivingForce.h:17
ElasticEnergyMaterial::computeDF
virtual Real computeDF(unsigned int i_var) override
Definition: ElasticEnergyMaterial.C:79
ElasticEnergyMaterial::initialSetup
virtual void initialSetup() override
Definition: ElasticEnergyMaterial.C:66
ElasticEnergyMaterial::computeF
virtual Real computeF() override
Definition: ElasticEnergyMaterial.C:73
ElasticEnergyMaterial::_base_name
const std::string _base_name
Definition: ElasticEnergyMaterial.h:41
ElasticEnergyMaterial
Material class to compute the elastic free energy and its derivatives.
Definition: ElasticEnergyMaterial.h:29
RankTwoTensor
RankTwoTensorTempl< Real > RankTwoTensor
Definition: ElasticEnergyMaterial.h:17