Skip to content

Commit

Permalink
Fix and test LB Lees Edwards particle coupling
Browse files Browse the repository at this point in the history
  • Loading branch information
RudolfWeeber committed Jul 4, 2024
1 parent c89fce3 commit b95fd23
Show file tree
Hide file tree
Showing 4 changed files with 354 additions and 71 deletions.
34 changes: 29 additions & 5 deletions src/core/lb/particle_coupling.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -124,11 +124,10 @@ static void positions_in_halo_impl(Utils::Vector3d const &pos_folded,

if (box_geo.type() == BoxType::LEES_EDWARDS) {
auto le = box_geo.lees_edwards_bc();
auto normal_shift = (pos_shifted - pos_folded)[le.shear_plane_normal];
if (normal_shift > std::numeric_limits<double>::epsilon())
pos_shifted[le.shear_direction] += le.pos_offset;
if (normal_shift < -std::numeric_limits<double>::epsilon())
pos_shifted[le.shear_direction] -= le.pos_offset;
auto const folded_offset =
std::fmod(le.pos_offset, box_geo.length()[le.shear_direction]);
pos_shifted[le.shear_direction] +=
shift[le.shear_plane_normal] * folded_offset;
}

if (in_box(pos_shifted, halo_lower_corner, halo_upper_corner)) {
Expand Down Expand Up @@ -163,6 +162,26 @@ std::vector<Utils::Vector3d> positions_in_halo(Utils::Vector3d const &pos,
return res;
}

Utils::Vector3d
lees_edwards_vel_shift(const Utils::Vector3d &pos_shifted_by_box_l,
const Utils::Vector3d &orig_pos,
const BoxGeometry &box_geo) {
Utils::Vector3d vel_shift{{0., 0., 0.}};
if (box_geo.type() == BoxType::LEES_EDWARDS) {
auto le = box_geo.lees_edwards_bc();
auto normal_shift =
(pos_shifted_by_box_l - orig_pos)[le.shear_plane_normal];
// normal_shift is +,- box_l or 0 up to floating point errors
if (normal_shift > std::numeric_limits<double>::epsilon()) {
vel_shift[le.shear_direction] -= le.shear_velocity;
}
if (normal_shift < -std::numeric_limits<double>::epsilon()) {
vel_shift[le.shear_direction] += le.shear_velocity;
}
}
return vel_shift;
}

namespace LB {

Utils::Vector3d ParticleCoupling::get_noise_term(Particle const &p) const {
Expand Down Expand Up @@ -255,7 +274,12 @@ void ParticleCoupling::kernel(std::vector<Particle *> const &particles) {
Utils::Vector3d force_on_particle = {};
if (coupling_mode == particle_force) {
auto const &v_fluid = *it_interpolated_velocities;
#ifndef LEES_EDWARDS
auto const drag_force = lb_drag_force(p, m_thermostat.gamma, v_fluid);
#else
auto vel_correction = lees_edvards_vel_shift(m_box_geo.folded_position(p.pos()),*it_positions_force_coupling,m_box_geo);
auto const drag_force = lb_drag_force(p, m_thermostat.gamma, v_fluid-vel_correction);
#endif
auto const random_force = get_noise_term(p);
force_on_particle = drag_force + random_force;
++it_interpolated_velocities;
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -31,6 +31,16 @@
#include <stdexcept>
#include <utility>

namespace {
double python_modulo(double a, double b) {
double res = std::fmod(a, b);
if (res < 0)
return res + b;
else
return res;
}
} // namespace

namespace walberla {

/**
Expand Down Expand Up @@ -94,8 +104,6 @@ class InterpolateAndShiftAtBoundary {
auto const dir = m_shear_direction;
auto const dim = cell_idx_c(m_blocks->getNumberOfCells(*block, dir));
auto const length = numeric_cast<FloatType>(dim);
auto const weight =
std::abs(std::fmod(get_pos_offset() + length, FloatType{1}));

// setup slab
auto field = block->template getData<FieldType>(m_field_id);
Expand All @@ -111,24 +119,25 @@ class InterpolateAndShiftAtBoundary {
auto const prefactor =
((slab_dir == m_slab_max) ? FloatType{-1} : FloatType{1});
auto const offset = get_pos_offset() * prefactor;
auto const folded_offset = python_modulo(offset, length);
// 0<=folded_offset<length
auto const weight1 = 1 - std::fmod(folded_offset, FloatType{1});
auto const weight2 = std::fmod(folded_offset, FloatType{1});
for (auto const &&cell : ci) {
Cell source1 = cell;
Cell source2 = cell;
source1[dir] = cell_idx_c(std::floor(
static_cast<FloatType>(source1[dir]) + offset)) %
dim;
source1[dir] = cell_idx_c(static_cast<FloatType>(source1[dir]) + length);
source1[dir] = cell_idx_c(source1[dir] % dim);

source2[dir] =
cell_idx_c(std::ceil(static_cast<FloatType>(source2[dir]) + offset)) %
dim;
source2[dir] = cell_idx_c(static_cast<FloatType>(source2[dir]) + length);
source2[dir] = cell_idx_c(source2[dir] % dim);

for (uint_t f = 0; f < FieldType::F_SIZE; ++f) {
tmp_field->get(cell, f) = field->get(source1, f) * (1 - weight) +
field->get(source2, f) * weight;
int target_idx = cell[dir];
auto const source_pos = target_idx + folded_offset;
auto folded_source_pos = python_modulo(source_pos, length);
// 0<=folded_source_pos <length
source1[dir] = cell_idx_c(std::floor(folded_source_pos));
// 0<=source1[dir]<length, i.e. integer value sbetw. 0 and length-1 inclusive
source2[dir] = python_modulo(source1[dir]+1, length);
// ineger values between 0 and length -1 inclusive

for (uint_t q = 0; q < FieldType::F_SIZE; ++q) {
tmp_field->get(cell, q) =
field->get(source1, q) * weight1 + field->get(source2, q) * weight2;
}
tmp_field->get(cell, m_shear_direction) -= prefactor * shift;
}
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -535,13 +535,13 @@ class LBWalberlaImpl : public LBWalberlaBase {

void integrate_pull_scheme() {
auto const &blocks = get_lattice().get_blocks();
integrate_reset_force(blocks);
// Handle boundaries
integrate_boundaries(blocks);
// LB stream
integrate_stream(blocks);
// LB collide
integrate_collide(blocks);
integrate_reset_force(blocks);
// Refresh ghost layers
ghost_communication_pdfs();
}
Expand Down
Loading

0 comments on commit b95fd23

Please sign in to comment.