VirtualFluids 0.2.0
Parallel CFD LBM Solver
Loading...
Searching...
No Matches
LogFileInformationTaylorGreenVortexUz.cpp
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//=======================================================================================
34
36
37std::shared_ptr<LogFileInformationTaylorGreenUz> LogFileInformationTaylorGreenUz::getNewInstance(std::shared_ptr<TaylorGreenVortexUzParameterStruct> simParaStruct, std::vector<std::shared_ptr<GridInformationStruct> > gridInfoStruct)
38{
39 return std::shared_ptr<LogFileInformationTaylorGreenUz>(new LogFileInformationTaylorGreenUz(simParaStruct, gridInfoStruct));
40}
41
43{
44 makeCenterHead("TaylorGreenVortex V0 Information");
45 oss << "SimulationName=TaylorGreenVortexUz" << std::endl;
46 oss << "Lx=\"";
47 for (int i = 0; i < lx.size(); i++) {
48 oss << lx.at(i);
49 if (i < lx.size() - 1)
50 oss << " ";
51 else
52 oss << "\"" << std::endl << std::endl;
53 }
54
55 for (int i = 0; i < lz.size(); i++) {
56 oss << "l0_" << lx.at(i) << "=" << l0 << std::endl;
57 oss << "uz_" << lx.at(i) << "=" << uz / (lz.at(i) / l0) << std::endl;
58 oss << "Amplitude_" << lx.at(i) << "=" << amplitude / (lz.at(i) / l0) << std::endl;
59 oss << std::endl;
60 }
61
62 return oss.str();
63}
64
66{
67 std::vector<std::string> myFilePath;
68 myFilePath.push_back("TaylorGreenVortexUz");
69 std::ostringstream oss;
70 oss << "uz_" << uz << "_Amplitude_" << amplitude;
71 myFilePath.push_back(oss.str());
72 return myFilePath;
73}
74
75LogFileInformationTaylorGreenUz::LogFileInformationTaylorGreenUz(std::shared_ptr<TaylorGreenVortexUzParameterStruct> simParaStruct, std::vector<std::shared_ptr<GridInformationStruct> > gridInfoStruct)
76{
77 this->uz = simParaStruct->uz;
78 this->amplitude = simParaStruct->amplitude;
79 this->l0 = simParaStruct->l0;
80
81 for (int i = 0; i < gridInfoStruct.size(); i++)
82 lz.push_back(gridInfoStruct.at(i)->lz);
83 for (int i = 0; i < gridInfoStruct.size(); i++)
84 lx.push_back(gridInfoStruct.at(i)->lx);
85}
86
static std::shared_ptr< LogFileInformationTaylorGreenUz > getNewInstance(std::shared_ptr< TaylorGreenVortexUzParameterStruct > simParaStruct, std::vector< std::shared_ptr< GridInformationStruct > > gridInfoStruct)
void makeCenterHead(std::string head)
std::shared_ptr< T > SPtr