ASPECT
include
aspect
heating_model
latent_heat_melt.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2015 - 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
22
#ifndef _aspect_heating_model_latent_heat_melt_h
23
#define _aspect_heating_model_latent_heat_melt_h
24
25
#include <
aspect/heating_model/interface.h
>
26
#include <
aspect/simulator_access.h
>
27
28
namespace
aspect
29
{
30
namespace
HeatingModel
31
{
43
template
<
int
dim>
44
class
LatentHeatMelt
:
public
Interface
<dim>,
public
::aspect::SimulatorAccess
<dim>
45
{
46
public
:
50
void
51
evaluate
(
const
MaterialModel::MaterialModelInputs<dim>
&material_model_inputs,
52
const
MaterialModel::MaterialModelOutputs<dim>
&material_model_outputs,
53
HeatingModel::HeatingModelOutputs
&heating_model_outputs)
const override
;
54
62
static
63
void
64
declare_parameters
(ParameterHandler &prm);
65
69
void
70
parse_parameters
(ParameterHandler &prm)
override
;
71
76
virtual
77
void
78
create_additional_material_model_outputs
(
MaterialModel::MaterialModelOutputs<dim>
&outputs)
const override
;
79
80
private
:
81
// entropy change upon melting
82
double
melting_entropy_change
;
83
bool
retrieve_entropy_change_from_material_model
;
84
};
85
}
86
}
87
88
89
#endif
aspect::HeatingModel::LatentHeatMelt::retrieve_entropy_change_from_material_model
bool retrieve_entropy_change_from_material_model
Definition:
latent_heat_melt.h:83
aspect::HeatingModel::LatentHeatMelt::declare_parameters
static void declare_parameters(ParameterHandler &prm)
aspect::HeatingModel::Interface
Definition:
interface.h:120
aspect::HeatingModel::LatentHeatMelt::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::LatentHeatMelt
Definition:
latent_heat_melt.h:44
simulator_access.h
aspect::SimulatorAccess
Definition:
plugins.h:45
interface.h
aspect
Definition:
compat.h:59
aspect::MaterialModel::MaterialModelInputs
Definition:
interface.h:243
aspect::MaterialModel::MaterialModelOutputs
Definition:
interface.h:478
aspect::HeatingModel::LatentHeatMelt::parse_parameters
void parse_parameters(ParameterHandler &prm) override
aspect::HeatingModel::HeatingModelOutputs
Definition:
interface.h:54
aspect::HeatingModel::LatentHeatMelt::create_additional_material_model_outputs
virtual void create_additional_material_model_outputs(MaterialModel::MaterialModelOutputs< dim > &outputs) const override
aspect::HeatingModel::LatentHeatMelt::melting_entropy_change
double melting_entropy_change
Definition:
latent_heat_melt.h:82