ASPECT
include
aspect
material_model
replace_lithosphere_viscosity.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2014 - 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
#ifndef _aspect_material_model_replace_lithosphere_viscosity_h
22
#define _aspect_material_model_replace_lithosphere_viscosity_h
23
24
#include <
aspect/material_model/interface.h
>
25
#include <
aspect/simulator_access.h
>
26
#include <
aspect/utilities.h
>
27
#include <
aspect/initial_temperature/lithosphere_mask.h
>
28
29
namespace
aspect
30
{
31
namespace
MaterialModel
32
{
33
using namespace
dealii
;
34
44
template
<
int
dim>
45
class
ReplaceLithosphereViscosity
:
public
MaterialModel::Interface
<dim>,
public
::aspect::SimulatorAccess
<dim>
46
{
47
public
:
48
52
void
initialize
()
override
;
53
58
void
59
evaluate (
const
typename
Interface<dim>::MaterialModelInputs
&in,
60
typename
Interface<dim>::MaterialModelOutputs
&out)
const override
;
61
65
static
void
66
declare_parameters
(ParameterHandler &prm);
67
71
void
72
parse_parameters (ParameterHandler &prm)
override
;
73
78
bool
is_compressible ()
const override
;
79
80
void
81
create_additional_named_outputs (
MaterialModel::MaterialModelOutputs<dim>
&out)
const override
;
82
83
private
:
84
88
double
lithosphere_viscosity
;
89
90
94
std::unique_ptr<MaterialModel::Interface<dim>>
base_model
;
95
96
97
InitialTemperature::LABDepth::LABDepthLookup<dim>
lab_depth_lookup
;
98
};
99
}
100
}
101
102
#endif
aspect::InitialTemperature::LABDepth::LABDepthLookup
Definition:
lithosphere_mask.h:39
aspect::MaterialModel::ReplaceLithosphereViscosity::lithosphere_viscosity
double lithosphere_viscosity
Definition:
replace_lithosphere_viscosity.h:88
interface.h
aspect::MaterialModel::Interface
Definition:
simulator_access.h:65
utilities.h
lithosphere_mask.h
aspect::MaterialModel::declare_parameters
void declare_parameters(ParameterHandler &prm)
aspect::MaterialModel::ReplaceLithosphereViscosity::base_model
std::unique_ptr< MaterialModel::Interface< dim > > base_model
Definition:
replace_lithosphere_viscosity.h:94
aspect::MaterialModel::ReplaceLithosphereViscosity
Definition:
replace_lithosphere_viscosity.h:45
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect
Definition:
compat.h:59
aspect::MaterialModel::MaterialModelInputs
Definition:
interface.h:245
aspect::Particle::Property::initialize
Definition:
interface.h:306
aspect::MaterialModel::MaterialModelOutputs
Definition:
interface.h:480
aspect::MaterialModel::ReplaceLithosphereViscosity::lab_depth_lookup
InitialTemperature::LABDepth::LABDepthLookup< dim > lab_depth_lookup
Definition:
replace_lithosphere_viscosity.h:97
dealii
Definition:
compat.h:42