ASPECT
include
aspect
boundary_traction
initial_lithostatic_pressure.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
22
#ifndef _aspect_boundary_traction_initial_lithospheric_pressure_h
23
#define _aspect_boundary_traction_initial_lithospheric_pressure_h
24
25
#include <
aspect/boundary_traction/interface.h
>
26
#include <
aspect/simulator_access.h
>
27
28
29
namespace
aspect
30
{
31
namespace
BoundaryTraction
32
{
33
using namespace
dealii
;
34
41
template
<
int
dim>
42
class
InitialLithostaticPressure
:
public
Interface
<dim>,
public
SimulatorAccess
<dim>
43
{
44
public
:
45
52
void
initialize
()
override
;
53
54
60
Tensor<1,dim>
61
boundary_traction (
const
types::boundary_id boundary_indicator,
62
const
Point<dim> &position,
63
const
Tensor<1,dim> &normal_vector)
const override
;
64
65
69
static
70
void
71
declare_parameters
(ParameterHandler &prm);
72
73
77
void
78
parse_parameters (ParameterHandler &prm)
override
;
79
80
private
:
81
85
unsigned
int
n_points
;
86
90
double
delta_z
;
91
92
/*
93
* The user-specified point where to calculate the pressure profile.
94
* The vertical coordinate/radius is ignored.
95
*/
96
Point<dim>
representative_point
;
97
101
std::vector<double>
pressure
;
102
107
double
interpolate_pressure (
const
Point<dim> &p)
const
;
108
112
types::boundary_id
bottom_boundary_id
;
113
120
bool
prescribe_constant_pressure_at_bottom_boundary
;
121
};
122
}
123
}
124
125
126
#endif
aspect::BoundaryTraction::InitialLithostaticPressure::representative_point
Point< dim > representative_point
Definition:
initial_lithostatic_pressure.h:96
aspect::BoundaryTraction::InitialLithostaticPressure::prescribe_constant_pressure_at_bottom_boundary
bool prescribe_constant_pressure_at_bottom_boundary
Definition:
initial_lithostatic_pressure.h:120
aspect::BoundaryTraction::declare_parameters
void declare_parameters(ParameterHandler &prm)
interface.h
aspect::BoundaryTraction::InitialLithostaticPressure::delta_z
double delta_z
Definition:
initial_lithostatic_pressure.h:90
aspect::BoundaryTraction::InitialLithostaticPressure::pressure
std::vector< double > pressure
Definition:
initial_lithostatic_pressure.h:101
aspect::BoundaryTraction::InitialLithostaticPressure::n_points
unsigned int n_points
Definition:
initial_lithostatic_pressure.h:85
aspect::BoundaryTraction::InitialLithostaticPressure::bottom_boundary_id
types::boundary_id bottom_boundary_id
Definition:
initial_lithostatic_pressure.h:112
aspect::BoundaryTraction::Interface
Definition:
simulator_access.h:94
aspect::BoundaryTraction::InitialLithostaticPressure
Definition:
initial_lithostatic_pressure.h:42
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect
Definition:
compat.h:59
aspect::Particle::Property::initialize
Definition:
interface.h:306
dealii
Definition:
compat.h:42