ASPECT
include
aspect
initial_composition
function.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2011 - 2021 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_function_h
23
#define _aspect_initial_composition_function_h
24
25
#include <
aspect/initial_composition/interface.h
>
26
#include <
aspect/simulator_access.h
>
27
#include <
aspect/utilities.h
>
28
29
#include <deal.II/base/parsed_function.h>
30
31
namespace
aspect
32
{
33
namespace
InitialComposition
34
{
41
template
<
int
dim>
42
class
Function
:
public
Interface
<dim>,
43
public
SimulatorAccess
<dim>
44
{
45
public
:
50
double
initial_composition
(
const
Point<dim> &position,
const
unsigned
int
n_comp)
const override
;
51
58
static
59
void
60
declare_parameters
(ParameterHandler &prm);
61
68
void
69
parse_parameters
(ParameterHandler &prm)
override
;
70
71
private
:
75
std::unique_ptr<Functions::ParsedFunction<dim>>
function
;
76
81
Utilities::Coordinates::CoordinateSystem
coordinate_system
;
82
};
83
}
84
}
85
86
87
#endif
aspect::InitialComposition::Function::declare_parameters
static void declare_parameters(ParameterHandler &prm)
aspect::Utilities::Coordinates::CoordinateSystem
CoordinateSystem
Definition:
coordinate_systems.h:56
utilities.h
aspect::InitialComposition::Interface
Definition:
simulator_access.h:104
aspect::InitialComposition::Function::initial_composition
double initial_composition(const Point< dim > &position, const unsigned int n_comp) const override
interface.h
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:46
aspect
Definition:
compat.h:59
aspect::InitialComposition::Function::parse_parameters
void parse_parameters(ParameterHandler &prm) override
aspect::InitialComposition::Function::coordinate_system
Utilities::Coordinates::CoordinateSystem coordinate_system
Definition:
function.h:81
aspect::InitialComposition::Function
Definition:
function.h:42