ExaDG
Toggle main menu visibility
Loading...
Searching...
No Matches
include
exadg
compressible_navier_stokes
postprocessor
postprocessor.h
1
/* ______________________________________________________________________
2
*
3
* ExaDG - High-Order Discontinuous Galerkin for the Exa-Scale
4
*
5
* Copyright (C) 2021 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_COMPRESSIBLE_NAVIER_STOKES_POSTPROCESSOR_POSTPROCESSOR_H_
23
#define EXADG_COMPRESSIBLE_NAVIER_STOKES_POSTPROCESSOR_POSTPROCESSOR_H_
24
25
// ExaDG
26
#include <exadg/compressible_navier_stokes/postprocessor/output_generator.h>
27
#include <exadg/compressible_navier_stokes/postprocessor/pointwise_output_generator.h>
28
#include <exadg/compressible_navier_stokes/postprocessor/postprocessor_base.h>
29
#include <exadg/postprocessor/error_calculation.h>
30
#include <exadg/postprocessor/kinetic_energy_calculation.h>
31
#include <exadg/postprocessor/kinetic_energy_spectrum.h>
32
#include <exadg/postprocessor/lift_and_drag_calculation.h>
33
#include <exadg/postprocessor/pressure_difference_calculation.h>
34
35
namespace
ExaDG
36
{
37
namespace
CompNS
38
{
39
template
<
int
dim>
40
struct
PostProcessorData
41
{
42
OutputData
output_data;
43
PointwiseOutputData<dim>
pointwise_output_data;
44
ErrorCalculationData<dim>
error_data;
45
LiftAndDragData
lift_and_drag_data;
46
PressureDifferenceData<dim>
pressure_difference_data;
47
KineticEnergyData
kinetic_energy_data;
48
KineticEnergySpectrumData
kinetic_energy_spectrum_data;
49
};
50
51
template
<
int
dim,
typename
Number>
52
class
PostProcessor :
public
PostProcessorBase
<dim, Number>
53
{
54
public
:
55
typedef
dealii::LinearAlgebra::distributed::Vector<Number> VectorType;
56
57
PostProcessor(
PostProcessorData<dim>
const
& postprocessor_data, MPI_Comm
const
& comm);
58
59
// custom destructor computing convergence tables if desired
60
virtual
~PostProcessor();
61
62
void
63
setup(
Operator<dim, Number>
const
& pde_operator)
override
;
64
65
void
66
do_postprocessing(VectorType
const
& solution,
67
double
const
time,
68
types::time_step
const
time_step_number)
override
;
69
70
protected
:
71
SolutionField<dim, Number>
pressure;
72
SolutionField<dim, Number>
velocity;
73
SolutionField<dim, Number>
temperature;
74
SolutionField<dim, Number>
vorticity;
75
SolutionField<dim, Number>
divergence;
76
SolutionField<dim, Number>
shear_rate;
77
78
private
:
79
void
80
initialize_derived_fields();
81
82
void
83
invalidate_derived_fields();
84
85
MPI_Comm
const
mpi_comm;
86
87
PostProcessorData<dim>
pp_data;
88
89
dealii::ObserverPointer<Operator<dim, Number>
const
> navier_stokes_operator;
90
91
OutputGenerator<dim, Number>
output_generator;
92
PointwiseOutputGenerator<dim, Number>
pointwise_output_generator;
93
ErrorCalculator<dim, Number>
error_calculator;
94
LiftAndDragCalculator<dim, Number>
lift_and_drag_calculator;
95
PressureDifferenceCalculator<dim, Number>
pressure_difference_calculator;
96
KineticEnergyCalculator<dim, Number>
kinetic_energy_calculator;
97
KineticEnergySpectrumCalculator<dim, Number>
kinetic_energy_spectrum_calculator;
98
};
99
100
}
// namespace CompNS
101
}
// namespace ExaDG
102
103
#endif
/* EXADG_COMPRESSIBLE_NAVIER_STOKES_POSTPROCESSOR_POSTPROCESSOR_H_ */
ExaDG::CompNS::Operator
Definition
operator.h:48
ExaDG::CompNS::OutputGenerator
Definition
output_generator.h:89
ExaDG::CompNS::PointwiseOutputGenerator
Definition
pointwise_output_generator.h:50
ExaDG::CompNS::PostProcessorBase
Definition
postprocessor_base.h:60
ExaDG::ErrorCalculator
Definition
error_calculation.h:103
ExaDG::KineticEnergyCalculator
Definition
kinetic_energy_calculation.h:81
ExaDG::KineticEnergySpectrumCalculator
Definition
kinetic_energy_spectrum.h:113
ExaDG::LiftAndDragCalculator
Definition
lift_and_drag_calculation.h:79
ExaDG::PressureDifferenceCalculator
Definition
pressure_difference_calculation.h:69
ExaDG::SolutionField
Definition
solution_field.h:40
ExaDG
Definition
driver.cpp:33
ExaDG::CompNS::OutputData
Definition
output_generator.h:38
ExaDG::CompNS::PointwiseOutputData
Definition
pointwise_output_generator.h:37
ExaDG::CompNS::PostProcessorData
Definition
postprocessor.h:41
ExaDG::ErrorCalculationData
Definition
error_calculation.h:39
ExaDG::KineticEnergyData
Definition
kinetic_energy_calculation.h:37
ExaDG::KineticEnergySpectrumData
Definition
kinetic_energy_spectrum.h:40
ExaDG::LiftAndDragData
Definition
lift_and_drag_calculation.h:35
ExaDG::PressureDifferenceData
Definition
pressure_difference_calculation.h:40
Generated by
1.17.0