ASPECT
include
aspect
initial_composition
slab_model.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2023 - 2024 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
22
#ifndef _aspect_initial_composition_slab_model_h
23
#define _aspect_initial_composition_slab_model_h
24
25
#include <
aspect/initial_composition/interface.h
>
26
27
#include <
aspect/simulator_access.h
>
28
#include <
aspect/structured_data.h
>
29
30
31
namespace
aspect
32
{
33
namespace
InitialComposition
34
{
35
using namespace
dealii
;
36
49
template
<
int
dim>
50
class
SlabModel
:
public
Interface
<dim>,
public
aspect::SimulatorAccess
<dim>
51
{
52
public
:
57
void
58
initialize
()
override
;
59
64
double
65
initial_composition (
const
Point<dim> &position,
66
const
unsigned
int
n_comp)
const override
;
67
71
static
72
void
73
declare_parameters
(ParameterHandler &prm);
74
78
void
79
parse_parameters (ParameterHandler &prm)
override
;
80
85
const
Utilities::AsciiDataBoundary<dim>
&get_slab_boundary()
const
;
86
87
private
:
92
Utilities::AsciiDataBoundary<dim>
slab_boundary
;
93
97
types::boundary_id
surface_boundary_id
;
98
103
unsigned
int
slab_index
;
104
};
105
}
106
}
107
108
109
#endif
aspect::Utilities::AsciiDataBoundary
Definition:
structured_data.h:372
aspect::InitialComposition::Interface
Definition:
simulator_access.h:106
structured_data.h
aspect::AdiabaticConditions::declare_parameters
void declare_parameters(ParameterHandler &prm)
interface.h
simulator_access.h
aspect::InitialComposition::SlabModel::slab_index
unsigned int slab_index
Definition:
slab_model.h:103
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect
Definition:
compat.h:59
aspect::InitialComposition::SlabModel
Definition:
slab_model.h:50
aspect::Particle::Property::initialize
Definition:
interface.h:306
aspect::InitialComposition::SlabModel::slab_boundary
Utilities::AsciiDataBoundary< dim > slab_boundary
Definition:
slab_model.h:92
dealii
Definition:
compat.h:42
aspect::InitialComposition::SlabModel::surface_boundary_id
types::boundary_id surface_boundary_id
Definition:
slab_model.h:97