VirtualFluids 0.2.0
Parallel CFD LBM Solver
Loading...
Searching...
No Matches
FileWriter.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//
33//=======================================================================================
34#ifndef FILE_WRITER_H
35#define FILE_WRITER_H
36
37#include <map>
38#include <memory>
39#include <string>
40#include <vector>
41
42#include "DataWriter.h"
43
44namespace vf::gpu {
45
46class Parameter;
47class CudaMemoryManager;
48
49class FileWriter : public DataWriter
50{
51public:
52 void writeInit(std::shared_ptr<Parameter> para, std::shared_ptr<CudaMemoryManager> cudaMemoryManager) override;
53 void writeTimestep(std::shared_ptr<Parameter> para, unsigned int timestep) override;
54
55private:
56 void writeTimestep(std::shared_ptr<Parameter> para, unsigned int timestep, int level) override;
57 std::vector<std::string> writeUnstructuredGridLT(std::shared_ptr<Parameter> para, int level,
58 std::vector<std::string>& fname);
59 std::vector<std::string> writeUnstructuredGridMeanLT(std::shared_ptr<Parameter> para, int level,
60 std::vector<std::string>& fname);
61
62 std::string writeCollectionFile(std::shared_ptr<Parameter> para, unsigned int timestep);
63
64 std::string writeCollectionFileMean(std::shared_ptr<Parameter> para, unsigned int timestep);
65
66 std::string writePvdCollectionFileForTimeSeries(const Parameter& para);
67
68 std::vector<std::string> getNodeDataNames(std::shared_ptr<Parameter> para);
69 std::vector<std::string> getMeanNodeDataNames(std::shared_ptr<Parameter> para);
70
71 std::vector<std::string> fileNamesForCollectionFile;
72 std::vector<std::string> fileNamesForCollectionFileMean;
73
74 std::map<uint, std::vector<std::string>>
75 fileNamesForCollectionFileTimeSeries; // key: timeStep, value: fileNames for timeStep
76};
77
78}
79
80#endif
81
void writeTimestep(std::shared_ptr< Parameter > para, unsigned int timestep) override
void writeInit(std::shared_ptr< Parameter > para, std::shared_ptr< CudaMemoryManager > cudaMemoryManager) override
Class for LBM-parameter management.
Definition Parameter.h:359