VirtualFluids 0.2.0
Parallel CFD LBM Solver
Loading...
Searching...
No Matches
L2NormTestBetweenKernels.h
Go to the documentation of this file.
1//=======================================================================================
2// ____ ____ __ ______ __________ __ __ __ __
3// \ \ | | | | | _ \ |___ ___| | | | | / \ | |
4// \ \ | | | | | |_) | | | | | | | / \ | |
5// \ \ | | | | | _ / | | | | | | / /\ \ | |
6// \ \ | | | | | | \ \ | | | \__/ | / ____ \ | |____
7// \ \ | | |__| |__| \__\ |__| \________/ /__/ \__\ |_______|
8// \ \ | | ________________________________________________________________
9// \ \ | | | ______________________________________________________________|
10// \ \| | | | __ __ __ __ ______ _______
11// \ | | |_____ | | | | | | | | | _ \ / _____)
12// \ | | _____| | | | | | | | | | | \ \ \_______
13// \ | | | | |_____ | \_/ | | | | |_/ / _____ |
14// \ _____| |__| |________| \_______/ |__| |______/ (_______/
15//
16// This file is part of VirtualFluids. VirtualFluids is free software: you can
17// redistribute it and/or modify it under the terms of the GNU General Public
18// License as published by the Free Software Foundation, either version 3 of
19// the License, or (at your option) any later version.
20//
21// VirtualFluids is distributed in the hope that it will be useful, but WITHOUT
22// ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
23// FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License
24// for more details.
25//
26// SPDX-License-Identifier: GPL-3.0-or-later
27// SPDX-FileCopyrightText: Copyright © VirtualFluids Project contributors, see AUTHORS.md in root folder
28//
32//=======================================================================================
33#ifndef L2_NORM_TEST_BETWEEN_KERNELS_H
34#define L2_NORM_TEST_BETWEEN_KERNELS_H
35
37
38#include <memory>
39
45
47{
48public:
49 static std::shared_ptr<L2NormTestBetweenKernels> getNewInstance(std::shared_ptr<ColorConsoleOutput> colorOutput, std::string dataToCalculate, unsigned int timeStep, std::string normalizeWith, std::shared_ptr<L2NormCalculatorFactory> factory);
50
51 void update();
52 void evaluate();
53 std::string getLogFileOutput();
54 std::string getErrorLogFileOutput();
55 double getBasicL2Result();
56
57 void setBasicSimulation(std::shared_ptr<NumericalTestSimulation> sim, std::shared_ptr<SimulationInfo> simInfo, std::shared_ptr<L2NormBetweenKernelPostProcessingStrategy> postProcessingStrategy);
58 void setDivergentKernelSimulation(std::shared_ptr<NumericalTestSimulation> sim, std::shared_ptr<SimulationInfo> simInfo, std::shared_ptr<L2NormBetweenKernelPostProcessingStrategy> postProcessingStrategy);
59
60private:
61 L2NormTestBetweenKernels(std::shared_ptr<ColorConsoleOutput> colorOutput, std::string dataToCalculate, unsigned int timeStep, std::string normalizeWith, std::shared_ptr<L2NormCalculatorFactory> factory);
62 int calcTimeStepInResults(unsigned int timeStep);
63 std::vector<std::string> buildTestOutput();
64 std::vector<std::string> buildBasicTestOutput();
65 std::vector<std::string> buildErrorTestOutput();
66
67 unsigned int timeStep;
68 std::string dataToCalculate;
69 std::shared_ptr<NumericalTestSimulation> basicSim;
70 std::shared_ptr<SimulationInfo> basicSimInfo;
71 std::shared_ptr<SimulationResults> basicSimResults;
72 std::shared_ptr<L2NormBetweenKernelPostProcessingStrategy> basicPostProcessingStrategy;
73 double basicL2Result;
74 std::shared_ptr<NumericalTestSimulation> divergentSim;
75 std::shared_ptr<SimulationInfo> divergentSimInfo;
76 std::shared_ptr<SimulationResults> divergentSimResults;
77 std::shared_ptr<L2NormBetweenKernelPostProcessingStrategy> divergentPostProcessingStrategy;
78 double divergentL2Result;
79 std::shared_ptr<L2NormCalculator> l2Normcalculator;
80 std::string normalizeData;
81 double resultL2ToBasicKernel;
82};
83#endif
std::shared_ptr< ColorConsoleOutput > colorOutput
Definition TestImp.h:72
void setBasicSimulation(std::shared_ptr< NumericalTestSimulation > sim, std::shared_ptr< SimulationInfo > simInfo, std::shared_ptr< L2NormBetweenKernelPostProcessingStrategy > postProcessingStrategy)
void setDivergentKernelSimulation(std::shared_ptr< NumericalTestSimulation > sim, std::shared_ptr< SimulationInfo > simInfo, std::shared_ptr< L2NormBetweenKernelPostProcessingStrategy > postProcessingStrategy)
static std::shared_ptr< L2NormTestBetweenKernels > getNewInstance(std::shared_ptr< ColorConsoleOutput > colorOutput, std::string dataToCalculate, unsigned int timeStep, std::string normalizeWith, std::shared_ptr< L2NormCalculatorFactory > factory)
std::shared_ptr< T > SPtr