ExaDG
Toggle main menu visibility
Loading...
Searching...
No Matches
include
exadg
acoustic_conservation_equations
spatial_discretization
interface.h
1
/* ______________________________________________________________________
2
*
3
* ExaDG - High-Order Discontinuous Galerkin for the Exa-Scale
4
*
5
* Copyright (C) 2023 by the ExaDG authors
6
*
7
* This program is free software: you can redistribute it and/or modify
8
* it under the terms of the GNU General Public License as published by
9
* the Free Software Foundation, either version 3 of the License, or
10
* (at your option) any later version.
11
*
12
* This program is distributed in the hope that it will be useful,
13
* but WITHOUT ANY WARRANTY; without even the implied warranty of
14
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
15
* GNU General Public License for more details.
16
*
17
* You should have received a copy of the GNU General Public License
18
* along with this program. If not, see <https://www.gnu.org/licenses/>.
19
* ______________________________________________________________________
20
*/
21
22
#ifndef EXADG_ACOUSTIC_CONSERVATION_EQUATIONS_SPATIAL_DISCRETIZATION_INTERFACE_H_
23
#define EXADG_ACOUSTIC_CONSERVATION_EQUATIONS_SPATIAL_DISCRETIZATION_INTERFACE_H_
24
25
// deal.II
26
#include <deal.II/lac/la_parallel_block_vector.h>
27
28
namespace
ExaDG
29
{
30
namespace
Acoustics
31
{
32
namespace
Interface
33
{
34
template
<
typename
Number>
35
class
SpatialOperator
36
{
37
public
:
38
using
VectorType = dealii::LinearAlgebra::distributed::Vector<Number>;
39
using
BlockVectorType = dealii::LinearAlgebra::distributed::BlockVector<Number>;
40
41
virtual
~SpatialOperator
() =
default
;
42
43
44
// time integration: initialize dof vector
45
virtual
void
46
initialize_dof_vector(BlockVectorType & dst)
const
= 0;
47
48
// time integration: prescribe initial conditions
49
virtual
void
50
prescribe_initial_conditions(BlockVectorType & src,
double
const
evaluation_time)
const
= 0;
51
52
// time integration: evaluate
53
virtual
void
54
evaluate(BlockVectorType & dst, BlockVectorType
const
& src,
double
const
time)
const
= 0;
55
56
// required for restart functionality
57
virtual
void
58
serialize_vectors(std::vector<BlockVectorType const *>
const
& block_vectors)
const
= 0;
59
60
virtual
void
61
deserialize_vectors(std::vector<BlockVectorType *>
const
& block_vectors)
const
= 0;
62
63
virtual
double
64
calculate_time_step_cfl()
const
= 0;
65
};
66
67
}
// namespace Interface
68
}
// namespace Acoustics
69
}
// namespace ExaDG
70
71
#endif
/* EXADG_ACOUSTIC_CONSERVATION_EQUATIONS_SPATIAL_DISCRETIZATION_INTERFACE_H_ */
ExaDG::Acoustics::Interface::SpatialOperator
Definition
interface.h:36
ExaDG
Definition
driver.cpp:33
Generated by
1.17.0