VirtualFluids 0.2.0
Parallel CFD LBM Solver
Loading...
Searching...
No Matches
ChimeraTransformation.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 LBM_CHIMERA_H
34#define LBM_CHIMERA_H
35
36#include <basics/DataTypes.h>
37
39
40namespace vf::lbm
41{
42
50{
51 using namespace vf::basics::constant;
52
53 const real m2 = mfa + mfc;
54 const real m1 = mfc - mfa;
55 real m0 = m2 + mfb;
56
57 mfa = m0;
58 m0 *= inverseK;
59 m0 += c1o1;
60 mfb = (m1 * inverseK - m0 * vv) * K;
61 mfc = ((m2 - c2o1 * m1 * vv) * inverseK + v2 * m0) * K;
62}
63
71{
72 using namespace vf::basics::constant;
73
74 const real m0 = (((mfc - mfb) * c1o2 + mfb * vv) * inverseK + (mfa * inverseK + c1o1) * (v2 - vv) * c1o2) * K;
75 const real m1 = (((mfa - mfc) - c2o1 * mfb * vv) * inverseK + (mfa * inverseK + c1o1) * (-v2)) * K;
76
77 mfc = (((mfc + mfb) * c1o2 + mfb * vv) * inverseK + (mfa * inverseK + c1o1) * (v2 + vv) * c1o2) * K;
78 mfa = m0;
79 mfb = m1;
80}
81
89constexpr void forwardChimera(real &mfa, real &mfb, real &mfc, real vv, real v2)
90{
91 using namespace vf::basics::constant;
92
93 const real m1 = (mfa + mfc) + mfb;
94 const real m2 = mfc - mfa;
95
96 mfc = (mfc + mfa) + (v2 * m1 - c2o1 * vv * m2);
97 mfb = m2 - vv * m1;
98 mfa = m1;
99}
100
108constexpr void backwardChimera(real &mfa, real &mfb, real &mfc, real vv, real v2)
109{
110 using namespace vf::basics::constant;
111
112 const real ma = (mfc + mfa * (v2 - vv)) * c1o2 + mfb * (vv - c1o2);
113 const real mb = ((mfa - mfc) - mfa * v2) - c2o1 * mfb * vv;
114
115 mfc = (mfc + mfa * (v2 + vv)) * c1o2 + mfb * (vv + c1o2);
116 mfb = mb;
117 mfa = ma;
118}
119
121{
122 using namespace vf::basics::constant;
123
124 const real m2 = mfa + mfc;
125 const real m1 = mfc - mfa;
126 const real m0 = m2 + mfb;
127 mfa = m0;
128 //m0 += K;
129 mfb = (m1 - K * vv) - m0 * vv;
130 mfc = ((m2 - c2o1* m1 * vv) + v2 * K) + v2 * m0;
131 //m0 += K;
132 //mfb = m1 - m0 * vv;
133 //mfc = m2 - two* m1 * vv + v2 * m0;
134}
135
137{
138 using namespace vf::basics::constant;
139
140 const real m0 = (mfc - mfb)* c1o2 + mfb * (vv)+(mfa + K) * (v2 - vv) * c1o2;
141 const real m1 = (mfa - mfc) - c2o1* mfb * vv + (mfa + K) * (-v2);
142 mfc = (mfc + mfb)* c1o2 + mfb * (vv)+(mfa + K) * (v2 + vv) * c1o2;
143 mfa = m0;
144 mfb = m1;
145}
146
147}
148#endif
149
std::shared_ptr< T > SPtr
float real
Definition DataTypes.h:42
constexpr void backwardChimera(real &mfa, real &mfb, real &mfc, real vv, real v2)
backward chimera transformation backwardChimera Transformation from central moments to distributions ...
constexpr void forwardChimeraWithK(real &mfa, real &mfb, real &mfc, real vv, real v2, real K)
constexpr void backwardChimeraWithK(real &mfa, real &mfb, real &mfc, real vv, real v2, real K)
constexpr void forwardChimeraWithInverseK(real &mfa, real &mfb, real &mfc, real vv, real v2, real inverseK, real K)
forward chimera transformation forwardChimeraWithInverseK Transformation from distributions to centra...
constexpr void forwardChimera(real &mfa, real &mfb, real &mfc, real vv, real v2)
forward chimera transformation forwardChimera Transformation from distributions to central moments ac...
constexpr void backwardChimeraWithInverseK(real &mfa, real &mfb, real &mfc, real vv, real v2, real inverseK, real K)
backward chimera transformation backwardChimeraWithInverseK Transformation from central moments to di...