ASPECT
include
aspect
material_model
equation_of_state
multicomponent_incompressible.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2011 - 2023 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_equation_of_state_multicomponent_incompressible_h
22
#define _aspect_material_model_equation_of_state_multicomponent_incompressible_h
23
24
#include <
aspect/material_model/interface.h
>
25
#include <
aspect/simulator_access.h
>
26
#include <
aspect/material_model/equation_of_state/interface.h
>
27
28
29
namespace
aspect
30
{
31
namespace
MaterialModel
32
{
33
namespace
EquationOfState
34
{
35
using namespace
dealii
;
36
53
template
<
int
dim>
54
class
MulticomponentIncompressible
:
public
::aspect::SimulatorAccess
<dim>
55
{
56
public
:
62
void
evaluate(
const
MaterialModel::MaterialModelInputs<dim>
&in,
63
const
unsigned
int
input_index,
64
MaterialModel::EquationOfStateOutputs<dim>
&out)
const
;
65
74
bool
is_compressible ()
const
;
75
82
static
83
void
84
declare_parameters
(ParameterHandler &prm,
85
const
double
default_thermal_expansion = 3.5e-5);
86
94
void
95
parse_parameters (ParameterHandler &prm,
96
const
std::unique_ptr<std::vector<unsigned int>> &expected_n_phases_per_composition =
nullptr
);
97
98
private
:
103
std::vector<double>
densities
;
104
109
double
reference_T
;
110
115
std::vector<double>
thermal_expansivities
;
116
121
std::vector<double>
specific_heats
;
122
};
123
}
124
}
125
}
126
127
#endif
interface.h
aspect::MaterialModel::EquationOfState::MulticomponentIncompressible::specific_heats
std::vector< double > specific_heats
Definition:
multicomponent_incompressible.h:121
aspect::MaterialModel::declare_parameters
void declare_parameters(ParameterHandler &prm)
aspect::MaterialModel::EquationOfState::MulticomponentIncompressible::reference_T
double reference_T
Definition:
multicomponent_incompressible.h:109
aspect::MaterialModel::EquationOfState::MulticomponentIncompressible::thermal_expansivities
std::vector< double > thermal_expansivities
Definition:
multicomponent_incompressible.h:115
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect::MaterialModel::EquationOfStateOutputs
Definition:
utilities.h:47
aspect
Definition:
compat.h:59
aspect::MaterialModel::EquationOfState::MulticomponentIncompressible
Definition:
multicomponent_incompressible.h:54
aspect::MaterialModel::MaterialModelInputs
Definition:
interface.h:245
interface.h
dealii
Definition:
compat.h:42
aspect::MaterialModel::EquationOfState::MulticomponentIncompressible::densities
std::vector< double > densities
Definition:
multicomponent_incompressible.h:103