ASPECT
include
aspect
time_stepping
repeat_on_nonlinear_fail.h
Go to the documentation of this file.
1
/*
2
Copyright (C) 2018 - 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
22
#ifndef _aspect_time_stepping_repeat_on_nonlinear_fail_h
23
#define _aspect_time_stepping_repeat_on_nonlinear_fail_h
24
25
#include <
aspect/time_stepping/interface.h
>
26
27
namespace
aspect
28
{
29
namespace
TimeStepping
30
{
31
using namespace
dealii
;
32
45
template
<
int
dim>
46
class
RepeatOnNonlinearFail
:
public
Interface
<dim>,
public
SimulatorAccess
<dim>
47
{
48
public
:
52
RepeatOnNonlinearFail
();
53
57
double
58
execute()
override
;
59
64
void
nonlinear_solver_has_failed()
const
;
65
69
std::pair<Reaction, double>
70
determine_reaction(
const
TimeStepInfo
&info)
override
;
71
72
static
73
void
74
declare_parameters
(ParameterHandler &prm);
75
76
void
77
parse_parameters (ParameterHandler &prm)
override
;
78
79
private
:
84
double
cut_back_factor
;
85
90
mutable
bool
nonlinear_solver_just_failed
;
91
95
unsigned
int
maximum_number_of_repeats
;
96
100
unsigned
int
current_number_of_repeats
;
101
};
102
}
103
}
104
105
106
#endif
aspect::TimeStepping::RepeatOnNonlinearFail::maximum_number_of_repeats
unsigned int maximum_number_of_repeats
Definition:
repeat_on_nonlinear_fail.h:95
interface.h
aspect::TimeStepping::TimeStepInfo
Definition:
interface.h:71
aspect::TimeStepping::RepeatOnNonlinearFail::current_number_of_repeats
unsigned int current_number_of_repeats
Definition:
repeat_on_nonlinear_fail.h:100
aspect::AdiabaticConditions::declare_parameters
void declare_parameters(ParameterHandler &prm)
aspect::TimeStepping::RepeatOnNonlinearFail
Definition:
repeat_on_nonlinear_fail.h:46
aspect::TimeStepping::RepeatOnNonlinearFail::nonlinear_solver_just_failed
bool nonlinear_solver_just_failed
Definition:
repeat_on_nonlinear_fail.h:90
aspect::TimeStepping::Interface
Definition:
interface.h:92
aspect::SimulatorAccess
Definition:
plugins.h:45
aspect
Definition:
compat.h:59
aspect::TimeStepping::RepeatOnNonlinearFail::cut_back_factor
double cut_back_factor
Definition:
repeat_on_nonlinear_fail.h:84
dealii
Definition:
compat.h:42