VirtualFluids 0.2.0
Parallel CFD LBM Solver
Loading...
Searching...
No Matches
PhiTest.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 PHI_TEST_H
34#define PHI_TEST_H
35
37
38#include <memory>
39#include <vector>
40#include <iostream>
41
42class FFTCalculator;
45
46class PhiTest : public TestImp
47{
48public:
49 static std::shared_ptr<PhiTest> getNewInstance(std::shared_ptr<ColorConsoleOutput> colorOutput, double viscosity, std::shared_ptr<PhiTestParameterStruct> testPara, std::string dataToCalculate);
50
51 void update();
52 void addSimulation(std::shared_ptr<NumericalTestSimulation> sim, std::shared_ptr<SimulationInfo> simInfo, std::shared_ptr<PhiTestPostProcessingStrategy> postProStrategy);
53 void evaluate();
54
55 std::string getDataToCalculate();
56 std::vector<int> getLx();
57 std::vector<double> getPhiDiff();
58 double getOrderOfAccuracy();
59
60
61
62private:
63 PhiTest(std::shared_ptr<ColorConsoleOutput> colorOutput, double viscosity, std::shared_ptr<PhiTestParameterStruct> testPara, std::string dataToCalculate);
64 double calcOrderOfAccuracy(std::vector<double> data);
65 TestStatus checkTestPassed(double orderOfAccuracy);
66 std::vector<std::string> buildTestOutput();
67 std::vector<std::string> buildBasicTestOutput();
68 std::vector<std::string> buildErrorTestOutput();
69
70 unsigned int startStepCalculation, endStepCalculation;
71 std::vector<double> lx;
72 std::vector<double> phiDiff;
73 double orderOfAccuracy;
74 double minOrderOfAccuracy;
75 std::string dataToCalculate;
76
77 std::vector<std::shared_ptr<PhiTestPostProcessingStrategy> > postProStrategies;
78
79};
80#endif
81
std::shared_ptr< ColorConsoleOutput > colorOutput
Definition TestImp.h:72
std::string getDataToCalculate()
Definition PhiTest.cpp:75
static std::shared_ptr< PhiTest > getNewInstance(std::shared_ptr< ColorConsoleOutput > colorOutput, double viscosity, std::shared_ptr< PhiTestParameterStruct > testPara, std::string dataToCalculate)
Definition PhiTest.cpp:47
std::vector< int > getLx()
Definition PhiTest.cpp:80
void evaluate()
Definition PhiTest.cpp:52
void update()
Definition PhiTest.cpp:63
std::vector< double > getPhiDiff()
Definition PhiTest.cpp:88
double getOrderOfAccuracy()
Definition PhiTest.cpp:93
void addSimulation(std::shared_ptr< NumericalTestSimulation > sim, std::shared_ptr< SimulationInfo > simInfo, std::shared_ptr< PhiTestPostProcessingStrategy > postProStrategy)
Definition PhiTest.cpp:68
TestStatus
Definition TestStatus.h:36
std::shared_ptr< T > SPtr