VirtualFluids 0.2.0
Parallel CFD LBM Solver
Loading...
Searching...
No Matches
NumericalTestGridReader.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
38
39#define _USE_MATH_DEFINES
40#include <math.h>
41
42using namespace vf::gpu;
43
44std::shared_ptr<NumericalTestGridReader> NumericalTestGridReader::getNewInstance(std::shared_ptr<Parameter> para, std::shared_ptr<InitialCondition> initialCondition, std::shared_ptr<CudaMemoryManager> cudaManager)
45{
46 return std::shared_ptr<NumericalTestGridReader>(new NumericalTestGridReader(para, initialCondition, cudaManager));
47}
48
49void NumericalTestGridReader::setInitialNodeValues(uint numberOfNodes, int level) const
50{
51 initialCondition->init(level);
52 for (uint j = 0; j <= numberOfNodes; j++){
53 para->getParH(level)->velocityX[j] = initialCondition->getInitVX(j, level);
54 para->getParH(level)->velocityY[j] = initialCondition->getInitVY(j, level);
55 para->getParH(level)->velocityZ[j] = initialCondition->getInitVZ(j, level);
56 para->getParH(level)->rho[j] = initialCondition->getInitROH(j, level);
57 para->getParH(level)->pressure[j] = initialCondition->getInitPRESS(j, level);
58 }
59}
60
61NumericalTestGridReader::NumericalTestGridReader(std::shared_ptr<Parameter> para, std::shared_ptr<InitialCondition> initialCondition, std::shared_ptr<CudaMemoryManager> cudaManager) : GridReader(FILEFORMAT::BINARY, para, cudaManager), initialCondition(initialCondition)
62{
63
64}
std::shared_ptr< Parameter > para
virtual void setInitialNodeValues(uint numberOfNodes, int level) const override
static std::shared_ptr< NumericalTestGridReader > getNewInstance(std::shared_ptr< vf::gpu::Parameter > para, std::shared_ptr< InitialCondition > initialCondition, std::shared_ptr< vf::gpu::CudaMemoryManager > cudaManager)
std::shared_ptr< T > SPtr
unsigned int uint
Definition DataTypes.h:47