ASPECT
include
aspect
material_model
drucker_prager.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2015 - 2022 by the authors of the ASPECT code.
3
4
This file is part of ASPECT.
5
6
ASPECT is free software; you can redistribute it and/or modify
7
it under the terms of the GNU General Public License as published by
8
the Free Software Foundation; either version 2, or (at your option)
9
any later version.
10
11
ASPECT is distributed in the hope that it will be useful,
12
but WITHOUT ANY WARRANTY; without even the implied warranty of
13
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
14
GNU General Public License for more details.
15
16
You should have received a copy of the GNU General Public License
17
along with ASPECT; see the file LICENSE. If not see
18
<http://www.gnu.org/licenses/>.
19
*/
20
21
#ifndef _aspect_material_model_drucker_prager_h
22
#define _aspect_material_model_drucker_prager_h
23
24
#include <
aspect/material_model/interface.h
>
25
#include <
aspect/material_model/rheology/drucker_prager.h
>
26
#include <
aspect/material_model/equation_of_state/linearized_incompressible.h
>
27
#include <
aspect/simulator_access.h
>
28
29
namespace
aspect
30
{
31
namespace
MaterialModel
32
{
33
using namespace
dealii
;
34
80
template
<
int
dim>
81
class
DruckerPrager
:
public
MaterialModel::Interface
<dim>,
public
::aspect::SimulatorAccess
<dim>
82
{
83
public
:
88
void
evaluate(
const
MaterialModel::MaterialModelInputs<dim>
&in,
89
MaterialModel::MaterialModelOutputs<dim>
&out)
const override
;
90
108
bool
is_compressible ()
const override
;
120
static
121
void
122
declare_parameters
(ParameterHandler &prm);
123
127
void
128
parse_parameters (ParameterHandler &prm)
override
;
133
private
:
134
135
double
reference_T
;
136
double
thermal_conductivities
;
137
138
EquationOfState::LinearizedIncompressible<dim>
equation_of_state
;
139
140
/*
141
* Objects for computing plastic stresses, viscosities, and additional outputs
142
*/
143
Rheology::DruckerPrager<dim>
drucker_prager_plasticity
;
144
148
double
angle_of_internal_friction
;
149
153
double
cohesion
;
154
158
double
minimum_viscosity
;
159
double
maximum_viscosity
;
160
164
double
reference_strain_rate
;
165
};
166
167
}
168
}
169
170
#endif
interface.h
aspect::MaterialModel::Interface
Definition:
simulator_access.h:65
drucker_prager.h
aspect::MaterialModel::DruckerPrager::thermal_conductivities
double thermal_conductivities
Definition:
drucker_prager.h:136
aspect::MaterialModel::Rheology::DruckerPrager
Definition:
drucker_prager.h:65
aspect::MaterialModel::EquationOfState::LinearizedIncompressible
Definition:
linearized_incompressible.h:46
aspect::MaterialModel::DruckerPrager::drucker_prager_plasticity
Rheology::DruckerPrager< dim > drucker_prager_plasticity
Definition:
drucker_prager.h:143
aspect::MaterialModel::declare_parameters
void declare_parameters(ParameterHandler &prm)
aspect::MaterialModel::DruckerPrager::reference_T
double reference_T
Definition:
drucker_prager.h:135
aspect::MaterialModel::DruckerPrager::reference_strain_rate
double reference_strain_rate
Definition:
drucker_prager.h:164
aspect::MaterialModel::DruckerPrager
Definition:
drucker_prager.h:81
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect
Definition:
compat.h:59
aspect::MaterialModel::MaterialModelInputs
Definition:
interface.h:245
aspect::MaterialModel::DruckerPrager::minimum_viscosity
double minimum_viscosity
Definition:
drucker_prager.h:158
linearized_incompressible.h
aspect::MaterialModel::DruckerPrager::angle_of_internal_friction
double angle_of_internal_friction
Definition:
drucker_prager.h:148
aspect::MaterialModel::DruckerPrager::cohesion
double cohesion
Definition:
drucker_prager.h:153
aspect::MaterialModel::MaterialModelOutputs
Definition:
interface.h:480
aspect::MaterialModel::DruckerPrager::maximum_viscosity
double maximum_viscosity
Definition:
drucker_prager.h:159
aspect::MaterialModel::DruckerPrager::equation_of_state
EquationOfState::LinearizedIncompressible< dim > equation_of_state
Definition:
drucker_prager.h:138
dealii
Definition:
compat.h:42