From c690d6c6b06102527eaca890ad7661fd1dab5605 Mon Sep 17 00:00:00 2001 From: Adrian Kummerlaender Date: Wed, 17 Oct 2018 12:49:16 +0200 Subject: Add basic Poiseuille example i.e. channel without obstacles. This will be usable for further validation. --- CMakeLists.txt | 10 +++++++ poiseuille.cc | 91 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 2 files changed, 101 insertions(+) create mode 100644 poiseuille.cc diff --git a/CMakeLists.txt b/CMakeLists.txt index bf8dc7b..e1def57 100644 --- a/CMakeLists.txt +++ b/CMakeLists.txt @@ -56,3 +56,13 @@ target_link_libraries( channel boltzbub ) + +add_executable( + poiseuille + poiseuille.cc +) + +target_link_libraries( + poiseuille + boltzbub +) diff --git a/poiseuille.cc b/poiseuille.cc new file mode 100644 index 0000000..7afb1ae --- /dev/null +++ b/poiseuille.cc @@ -0,0 +1,91 @@ +#include +#include +#include + +#include "lbm.h" +#include "boundary_conditions.h" + +constexpr std::size_t dimY = 40; +constexpr std::size_t dimX = 5*dimY; + +constexpr double uInflow = 0.02; +constexpr double reynolds = 10; + +constexpr double tau = 3. * uInflow * (dimX-1) / reynolds + 0.5; +constexpr double omega = 1. / tau; + +DataCellBuffer pop(dimX, dimY); +FluidBuffer fluid(dimX, dimY); + +void init() { + for ( std::size_t x = 0; x < dimX; ++x ) { + for ( std::size_t y = 0; y < dimY; ++y ) { + fluid.density(x,y) = 1.0; + fluid.velocity(x,y) = { 0.0, 0.0 }; + + static_cast(pop.curr(x,y)).equilibrize( + fluid.density(x,y), fluid.velocity(x,y)); + static_cast(pop.prev(x,y)).equilibrize( + fluid.density(x,y), fluid.velocity(x,y)); + } + } +} + +void computeLbmStep() { + pop.swap(); + + for ( std::size_t x = 0; x < dimX; ++x ) { + for ( std::size_t y = 0; y < dimY; ++y ) { + streamFluidCell(pop, x, y); + } + } + + for ( std::size_t x = 0; x < dimX; ++x ) { + computeWallCell(pop, {x, 0 }, { 0, 1}); + computeWallCell(pop, {x, dimY-1}, { 0,-1}); + } + + for ( std::size_t y = 1; y < dimY-1; ++y ) { + const double localU = -4. * uInflow / (dimY*dimY) * y * (double(y)-dimY); + computeMovingWallCell(pop, {0,y}, {1,0}, {localU,0}); + } + + for ( std::size_t x = 0; x < dimX; ++x ) { + for ( std::size_t y = 0; y < dimY; ++y ) { + Cell& cell = static_cast(pop.curr(x,y)); + + // bulk density + fluid.density(x,y) = cell.sum(); + + // outflow density condition + if ( x == dimX-1 && y > 0 && y < dimY-1 ) { + fluid.density(x,y) = 1.0; + } + + fluid.velocity(x,y) = cell.velocity(fluid.density(x,y)); + + collideFluidCell(omega, pop, fluid, x, y); + } + } +} + +int main() { + init(); + + std::cout << "Re: " << reynolds << std::endl; + std::cout << "uInflow: " << uInflow << std::endl; + std::cout << "tau: " << tau << std::endl; + std::cout << "omega: " << omega << std::endl; + + for ( std::size_t t = 0; t <= 10000; ++t ) { + computeLbmStep(); + + if ( t % 1000 == 0 ) { + std::cout << "."; + std::cout.flush(); + fluid.writeAsVTK("result/data_t" + std::to_string(t) + ".vtk"); + } + } + + std::cout << std::endl; +} -- cgit v1.2.3