Finite Volume Solver
prototype
A framework to build finite volume solvers for the AG Klein at the Freie Universität Berlin.
include
fub
AMReX
cutcell
AxiSymmetricSourceTerm.hpp
Go to the documentation of this file.
1
// Copyright (c) 2020 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_AXI_SYMMETRIC_SOURCE_TERM_HPP
22
#define FUB_AMREX_AXI_SYMMETRIC_SOURCE_TERM_HPP
23
24
#include "
fub/AMReX/cutcell/IntegratorContext.hpp
"
25
#include "
fub/TimeStepError.hpp
"
26
#include "
fub/equations/IdealGasMix.hpp
"
27
#include "
fub/ext/outcome.hpp
"
28
29
namespace
fub::amrex
{
30
31
/// \ingroup LevelIntegrator
32
class
AxiSymmetricSourceTerm
{
33
public
:
34
static
constexpr
int
Rank
= 2;
35
36
AxiSymmetricSourceTerm
(
const
IdealGasMix<2>
& eq);
37
38
Duration
ComputeStableDt
(
int
level);
39
40
Result<void, TimeStepTooLarge>
41
AdvanceLevel
(
cutcell::IntegratorContext
& simulation_data,
int
level,
42
Duration
dt, const ::amrex::IntVect& = ::amrex::IntVect(0));
43
44
private
:
45
OmpLocal<IdealGasMix<2>
>
equation_
;
46
};
47
48
}
// namespace fub::amrex
49
50
#endif
IntegratorContext.hpp
IdealGasMix.hpp
TimeStepError.hpp
fub::IdealGasMix
Definition:
IdealGasMix.hpp:105
fub::OmpLocal
Definition:
omp.hpp:42
fub::amrex::AxiSymmetricSourceTerm
Definition:
AxiSymmetricSourceTerm.hpp:32
fub::amrex::AxiSymmetricSourceTerm::AxiSymmetricSourceTerm
AxiSymmetricSourceTerm(const IdealGasMix< 2 > &eq)
fub::amrex::AxiSymmetricSourceTerm::AdvanceLevel
Result< void, TimeStepTooLarge > AdvanceLevel(cutcell::IntegratorContext &simulation_data, int level, Duration dt, const ::amrex::IntVect &=::amrex::IntVect(0))
fub::amrex::AxiSymmetricSourceTerm::Rank
static constexpr int Rank
Definition:
AxiSymmetricSourceTerm.hpp:34
fub::amrex::AxiSymmetricSourceTerm::ComputeStableDt
Duration ComputeStableDt(int level)
fub::amrex::AxiSymmetricSourceTerm::equation_
OmpLocal< IdealGasMix< 2 > > equation_
Definition:
AxiSymmetricSourceTerm.hpp:45
fub::amrex::cutcell::IntegratorContext
This class manages data and the numerical method to perform cut cell simulations with the AMReX libra...
Definition:
AMReX/cutcell/IntegratorContext.hpp:46
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
outcome.hpp
Generated on Fri Feb 12 2021 07:45:54 for Finite Volume Solver by
1.9.1