ASPECT
include
aspect
material_model
viscoelastic.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2014 - 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 doc/COPYING. If not see
18
<http://www.gnu.org/licenses/>.
19
*/
20
21
#ifndef _aspect_material_model_viscoelastic_h
22
#define _aspect_material_model_viscoelastic_h
23
24
#include <
aspect/material_model/interface.h
>
25
#include <
aspect/material_model/rheology/elasticity.h
>
26
#include <
aspect/simulator_access.h
>
27
#include <
aspect/material_model/equation_of_state/multicomponent_incompressible.h
>
28
29
namespace
aspect
30
{
31
namespace
MaterialModel
32
{
33
using namespace
dealii
;
34
147
template
<
int
dim>
148
class
Viscoelastic
:
public
MaterialModel::Interface
<dim>,
public
::aspect::SimulatorAccess
<dim>
149
{
150
public
:
155
void
evaluate(
const
MaterialModel::MaterialModelInputs<dim>
&in,
156
MaterialModel::MaterialModelOutputs<dim>
&out)
const override
;
157
166
bool
is_compressible ()
const override
;
179
static
180
void
181
declare_parameters
(ParameterHandler &prm);
182
186
void
187
parse_parameters (ParameterHandler &prm)
override
;
192
void
193
create_additional_named_outputs (
MaterialModel::MaterialModelOutputs<dim>
&out)
const override
;
194
195
196
private
:
200
MaterialUtilities::CompositionalAveragingOperation
viscosity_averaging
;
201
202
EquationOfState::MulticomponentIncompressible<dim>
equation_of_state
;
203
207
std::vector<double>
viscosities
;
208
212
std::vector<double>
thermal_conductivities
;
213
214
Rheology::Elasticity<dim>
elastic_rheology
;
215
};
216
217
}
218
}
219
220
#endif
interface.h
aspect::MaterialModel::Interface
Definition:
simulator_access.h:65
aspect::MaterialModel::MaterialUtilities::CompositionalAveragingOperation
CompositionalAveragingOperation
Definition:
utilities.h:404
aspect::MaterialModel::Viscoelastic
Definition:
viscoelastic.h:148
aspect::MaterialModel::Viscoelastic::viscosities
std::vector< double > viscosities
Definition:
viscoelastic.h:207
aspect::MaterialModel::declare_parameters
void declare_parameters(ParameterHandler &prm)
multicomponent_incompressible.h
aspect::MaterialModel::Viscoelastic::viscosity_averaging
MaterialUtilities::CompositionalAveragingOperation viscosity_averaging
Definition:
viscoelastic.h:200
elasticity.h
aspect::MaterialModel::Viscoelastic::elastic_rheology
Rheology::Elasticity< dim > elastic_rheology
Definition:
viscoelastic.h:214
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect::MaterialModel::Viscoelastic::thermal_conductivities
std::vector< double > thermal_conductivities
Definition:
viscoelastic.h:212
aspect
Definition:
compat.h:59
aspect::MaterialModel::EquationOfState::MulticomponentIncompressible
Definition:
multicomponent_incompressible.h:54
aspect::MaterialModel::MaterialModelInputs
Definition:
interface.h:245
aspect::MaterialModel::MaterialModelOutputs
Definition:
interface.h:480
aspect::MaterialModel::Viscoelastic::equation_of_state
EquationOfState::MulticomponentIncompressible< dim > equation_of_state
Definition:
viscoelastic.h:202
aspect::MaterialModel::Rheology::Elasticity
Definition:
elasticity.h:62
dealii
Definition:
compat.h:42