ASPECT
include
aspect
material_model
composition_reaction.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2011 - 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_composition_reaction_h
22
#define _aspect_material_model_composition_reaction_h
23
24
#include <
aspect/material_model/interface.h
>
25
#include <
aspect/material_model/equation_of_state/linearized_incompressible.h
>
26
#include <
aspect/simulator_access.h
>
27
28
namespace
aspect
29
{
30
namespace
MaterialModel
31
{
32
using namespace
dealii
;
33
45
template
<
int
dim>
46
class
CompositionReaction
:
public
MaterialModel::Interface
<dim>,
public
::aspect::SimulatorAccess
<dim>
47
{
48
public
:
52
void
evaluate(
const
MaterialModelInputs<dim>
&in,
53
MaterialModelOutputs<dim>
&out)
const override
;
54
68
bool
is_compressible ()
const override
;
80
static
81
void
82
declare_parameters
(ParameterHandler &prm);
83
87
void
88
parse_parameters (ParameterHandler &prm)
override
;
89
97
void
98
create_additional_named_outputs (
MaterialModel::MaterialModelOutputs<dim>
&out)
const override
;
99
100
101
private
:
102
double
reference_T
;
103
double
eta
;
104
double
composition_viscosity_prefactor_1
;
105
double
composition_viscosity_prefactor_2
;
106
double
thermal_viscosity_exponent
;
107
111
double
k_value
;
112
113
EquationOfState::LinearizedIncompressible<dim>
equation_of_state
;
114
119
double
reaction_depth
;
120
};
121
122
}
123
}
124
125
#endif
interface.h
aspect::MaterialModel::Interface
Definition:
simulator_access.h:65
aspect::MaterialModel::CompositionReaction::reaction_depth
double reaction_depth
Definition:
composition_reaction.h:119
aspect::MaterialModel::CompositionReaction::k_value
double k_value
Definition:
composition_reaction.h:111
aspect::MaterialModel::EquationOfState::LinearizedIncompressible
Definition:
linearized_incompressible.h:46
aspect::MaterialModel::declare_parameters
void declare_parameters(ParameterHandler &prm)
aspect::MaterialModel::CompositionReaction::thermal_viscosity_exponent
double thermal_viscosity_exponent
Definition:
composition_reaction.h:106
aspect::MaterialModel::CompositionReaction::composition_viscosity_prefactor_2
double composition_viscosity_prefactor_2
Definition:
composition_reaction.h:105
aspect::MaterialModel::CompositionReaction::eta
double eta
Definition:
composition_reaction.h:103
aspect::MaterialModel::CompositionReaction::composition_viscosity_prefactor_1
double composition_viscosity_prefactor_1
Definition:
composition_reaction.h:104
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect
Definition:
compat.h:59
aspect::MaterialModel::MaterialModelInputs
Definition:
interface.h:245
linearized_incompressible.h
aspect::MaterialModel::MaterialModelOutputs
Definition:
interface.h:480
dealii
Definition:
compat.h:42
aspect::MaterialModel::CompositionReaction::equation_of_state
EquationOfState::LinearizedIncompressible< dim > equation_of_state
Definition:
composition_reaction.h:113
aspect::MaterialModel::CompositionReaction
Definition:
composition_reaction.h:46
aspect::MaterialModel::CompositionReaction::reference_T
double reference_T
Definition:
composition_reaction.h:102