ASPECT
include
aspect
heating_model
shear_heating.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_heating_model_shear_heating_h
23
#define _aspect_heating_model_shear_heating_h
24
25
#include <
aspect/heating_model/interface.h
>
26
#include <
aspect/simulator_access.h
>
27
#include <
aspect/material_model/rheology/drucker_prager.h
>
28
29
namespace
aspect
30
{
31
namespace
HeatingModel
32
{
45
template
<
int
dim>
46
class
ShearHeating
:
public
Interface
<dim>,
public
::aspect::SimulatorAccess
<dim>
47
{
48
public
:
52
void
53
evaluate
(
const
MaterialModel::MaterialModelInputs<dim>
&material_model_inputs,
54
const
MaterialModel::MaterialModelOutputs<dim>
&material_model_outputs,
55
HeatingModel::HeatingModelOutputs
&heating_model_outputs)
const override
;
56
60
void
61
create_additional_material_model_outputs
(
MaterialModel::MaterialModelOutputs<dim>
&material_model_outputs)
const override
;
62
66
static
67
void
68
declare_parameters
(ParameterHandler &prm);
69
73
void
74
parse_parameters
(ParameterHandler &prm)
override
;
75
76
private
:
85
bool
limit_stress
;
86
double
cohesion
;
87
double
friction_angle
;
88
MaterialModel::Rheology::DruckerPrager<dim>
drucker_prager_plasticity
;
89
};
90
91
97
template
<
int
dim>
98
class
ShearHeatingOutputs
:
public
MaterialModel::NamedAdditionalMaterialOutputs
<dim>
99
{
100
public
:
101
ShearHeatingOutputs
(
const
unsigned
int
n_points);
102
103
std::vector<double> get_nth_output(
const
unsigned
int
idx)
const override
;
104
111
std::vector<double>
shear_heating_work_fractions
;
112
};
113
}
114
}
115
116
117
#endif
aspect::HeatingModel::ShearHeating::declare_parameters
static void declare_parameters(ParameterHandler &prm)
aspect::HeatingModel::ShearHeatingOutputs
Definition:
shear_heating.h:98
aspect::HeatingModel::ShearHeating::parse_parameters
void parse_parameters(ParameterHandler &prm) override
drucker_prager.h
aspect::HeatingModel::ShearHeating
Definition:
shear_heating.h:46
aspect::HeatingModel::ShearHeating::limit_stress
bool limit_stress
Definition:
shear_heating.h:85
aspect::MaterialModel::Rheology::DruckerPrager
Definition:
drucker_prager.h:63
aspect::HeatingModel::Interface
Definition:
interface.h:120
aspect::HeatingModel::ShearHeating::friction_angle
double friction_angle
Definition:
shear_heating.h:87
aspect::HeatingModel::ShearHeating::cohesion
double cohesion
Definition:
shear_heating.h:86
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:46
aspect::HeatingModel::ShearHeating::evaluate
void evaluate(const MaterialModel::MaterialModelInputs< dim > &material_model_inputs, const MaterialModel::MaterialModelOutputs< dim > &material_model_outputs, HeatingModel::HeatingModelOutputs &heating_model_outputs) const override
aspect::HeatingModel::ShearHeating::drucker_prager_plasticity
MaterialModel::Rheology::DruckerPrager< dim > drucker_prager_plasticity
Definition:
shear_heating.h:88
interface.h
aspect::MaterialModel::NamedAdditionalMaterialOutputs
Definition:
interface.h:872
aspect
Definition:
compat.h:59
aspect::HeatingModel::ShearHeatingOutputs::shear_heating_work_fractions
std::vector< double > shear_heating_work_fractions
Definition:
shear_heating.h:111
aspect::MaterialModel::MaterialModelInputs
Definition:
interface.h:243
aspect::MaterialModel::MaterialModelOutputs
Definition:
interface.h:478
aspect::HeatingModel::HeatingModelOutputs
Definition:
interface.h:54
aspect::HeatingModel::ShearHeating::create_additional_material_model_outputs
void create_additional_material_model_outputs(MaterialModel::MaterialModelOutputs< dim > &material_model_outputs) const override