Finite Volume Solver
prototype
A framework to build finite volume solvers for the AG Klein at the Freie Universität Berlin.
include
fub
AMReX
multi_block
MultiBlockKineticSourceTerm.hpp
Go to the documentation of this file.
1
// Copyright (c) 2019 Maikel Nadolski
2
//
3
// Permission is hereby granted, free of charge, to any person obtaining a copy
4
// of this software and associated documentation files (the "Software"), to deal
5
// in the Software without restriction, including without limitation the rights
6
// to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
7
// copies of the Software, and to permit persons to whom the Software is
8
// furnished to do so, subject to the following conditions:
9
//
10
// The above copyright notice and this permission notice shall be included in
11
// all copies or substantial portions of the Software.
12
//
13
// THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
14
// IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
15
// FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
16
// AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
17
// LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
18
// OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
19
// SOFTWARE.
20
21
#ifndef FUB_AMREX_MULTI_BLOCK_KINETIC_SOURCE_TERM_HPP
22
#define FUB_AMREX_MULTI_BLOCK_KINETIC_SOURCE_TERM_HPP
23
24
#include "
fub/AMReX/multi_block/MultiBlockIntegratorContext.hpp
"
25
#include "
fub/equations/ideal_gas_mix/KineticSourceTerm.hpp
"
26
27
#include <vector>
28
29
namespace
fub::amrex
{
30
31
/// This class manages multiple kinetic source terms which are associated to
32
/// independend one-dimensional domains
33
class
MultiBlockKineticSouceTerm
:
private
ideal_gas::KineticSourceTerm
<1> {
34
public
:
35
static
constexpr
int
Rank
= 1;
36
37
using
ideal_gas::KineticSourceTerm<1>::KineticSourceTerm
;
38
using
ideal_gas::KineticSourceTerm<1>::ComputeStableDt
;
39
40
/// \brief Integrates the source term for each tube in the specified context
41
[[nodiscard]]
Result<void, TimeStepTooLarge>
42
AdvanceLevel
(
MultiBlockIntegratorContext
& context,
int
level,
Duration
dt,
43
const ::amrex::IntVect& ngrow = ::amrex::IntVect(0));
44
};
45
46
}
// namespace fub::amrex
47
48
#endif
KineticSourceTerm.hpp
MultiBlockIntegratorContext.hpp
fub::amrex::MultiBlockIntegratorContext
Definition:
MultiBlockIntegratorContext.hpp:35
fub::amrex::MultiBlockKineticSouceTerm
This class manages multiple kinetic source terms which are associated to independend one-dimensional ...
Definition:
MultiBlockKineticSourceTerm.hpp:33
fub::amrex::MultiBlockKineticSouceTerm::Rank
static constexpr int Rank
Definition:
MultiBlockKineticSourceTerm.hpp:35
fub::amrex::MultiBlockKineticSouceTerm::AdvanceLevel
Result< void, TimeStepTooLarge > AdvanceLevel(MultiBlockIntegratorContext &context, int level, Duration dt, const ::amrex::IntVect &ngrow=::amrex::IntVect(0))
Integrates the source term for each tube in the specified context.
fub::ideal_gas::KineticSourceTerm
Definition:
KineticSourceTerm.hpp:36
fub::amrex
The amrex namespace.
Definition:
AverageState.hpp:33
fub::Duration
std::chrono::duration< double > Duration
Definition:
Duration.hpp:31
fub::Result
boost::outcome_v2::result< T, E > Result
Definition:
outcome.hpp:32
Generated on Fri Feb 12 2021 07:45:54 for Finite Volume Solver by
1.9.1