ASPECT
include
aspect
material_model
averaging.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2011 - 2022 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_averaging_h
22
#define _aspect_material_model_averaging_h
23
24
#include <
aspect/material_model/interface.h
>
25
#include <
aspect/simulator_access.h
>
26
27
namespace
aspect
28
{
29
namespace
MaterialModel
30
{
31
using namespace
dealii
;
32
77
enum
AveragingOperation
78
{
79
none
,
80
arithmetic_average
,
81
harmonic_average
,
82
geometric_average
,
83
pick_largest
,
84
log_average
,
85
nwd_arithmetic_average
,
86
nwd_harmonic_average
,
87
nwd_geometric_average
88
};
89
96
template
<
int
dim>
97
class
Averaging
:
public
MaterialModel::Interface
<dim>,
public
::aspect::SimulatorAccess
<dim>
98
{
99
public
:
104
void
105
evaluate (
const
typename
Interface<dim>::MaterialModelInputs
&in,
106
typename
Interface<dim>::MaterialModelOutputs
&out)
const override
;
110
static
void
111
declare_parameters
(ParameterHandler &prm);
112
116
void
117
parse_parameters (ParameterHandler &prm)
override
;
118
123
bool
is_compressible ()
const override
;
124
125
126
127
private
:
128
134
AveragingOperation
135
parse_averaging_operation_name
(
const
std::string &s);
136
142
void
143
average
(
const
AveragingOperation
averaging_operation,
144
const
std::vector<Point<dim>> &position,
145
std::vector<double> &values_out)
const
;
150
double
bell_shape_limit
;
155
AveragingOperation
averaging_operation
;
159
std::unique_ptr<MaterialModel::Interface<dim>>
base_model
;
160
};
161
}
162
}
163
164
#endif
aspect::MaterialModel::Averaging::averaging_operation
AveragingOperation averaging_operation
Definition:
averaging.h:155
aspect::MaterialModel::Averaging::base_model
std::unique_ptr< MaterialModel::Interface< dim > > base_model
Definition:
averaging.h:159
interface.h
aspect::MaterialModel::Interface
Definition:
simulator_access.h:65
aspect::MaterialModel::pick_largest
Definition:
averaging.h:83
aspect::MaterialModel::AveragingOperation
AveragingOperation
Definition:
averaging.h:77
aspect::MaterialModel::declare_parameters
void declare_parameters(ParameterHandler &prm)
aspect::MaterialModel::arithmetic_average
Definition:
averaging.h:80
aspect::MaterialModel::MaterialAveraging::average
void average(const AveragingOperation operation, const typename DoFHandler< dim >::active_cell_iterator &cell, const Quadrature< dim > &quadrature_formula, const Mapping< dim > &mapping, MaterialModelOutputs< dim > &values_out)
aspect::MaterialModel::harmonic_average
Definition:
averaging.h:81
aspect::MaterialModel::MaterialAveraging::parse_averaging_operation_name
AveragingOperation parse_averaging_operation_name(const std::string &s)
aspect::MaterialModel::none
Definition:
averaging.h:79
aspect::MaterialModel::geometric_average
Definition:
averaging.h:82
aspect::MaterialModel::MaterialModelOutputs
Definition:
interface.h:470
aspect::MaterialModel::nwd_arithmetic_average
Definition:
averaging.h:85
aspect::MaterialModel::nwd_geometric_average
Definition:
averaging.h:87
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:44
aspect::MaterialModel::Averaging
Definition:
averaging.h:97
aspect
Definition:
coordinate_systems.h:24
aspect::MaterialModel::log_average
Definition:
averaging.h:84
aspect::MaterialModel::MaterialModelInputs
Definition:
interface.h:242
aspect::MaterialModel::Averaging::bell_shape_limit
double bell_shape_limit
Definition:
averaging.h:150
aspect::MaterialModel::nwd_harmonic_average
Definition:
averaging.h:86
dealii
Definition:
compat.h:42