From 48165517fa4bfac675537a71ff3d7b735a247e0a Mon Sep 17 00:00:00 2001 From: Niklas Neher <73897120+LasNikas@users.noreply.github.com> Date: Thu, 26 Sep 2024 14:58:00 +0200 Subject: [PATCH] Fix moving boundaries (#603) * fix * typo * fix again * implement suggestions --- examples/fluid/accelerated_tank_2d.jl | 2 +- src/schemes/boundary/system.jl | 18 +++++++++++++----- 2 files changed, 14 insertions(+), 6 deletions(-) diff --git a/examples/fluid/accelerated_tank_2d.jl b/examples/fluid/accelerated_tank_2d.jl index efaf91cd4..dbbecfc7e 100644 --- a/examples/fluid/accelerated_tank_2d.jl +++ b/examples/fluid/accelerated_tank_2d.jl @@ -17,4 +17,4 @@ boundary_movement = BoundaryMovement(movement_function, is_moving) trixi_include(@__MODULE__, joinpath(examples_dir(), "fluid", "hydrostatic_water_column_2d.jl"), fluid_particle_spacing=fluid_particle_spacing, movement=boundary_movement, - tspan=(0.0, 1.0), system_acceleration=(0.0, 0.0)) + tspan=(0.0, 1.0), system_acceleration=(0.0, 0.0)); diff --git a/src/schemes/boundary/system.jl b/src/schemes/boundary/system.jl index 8f181ce7e..a3f47f611 100644 --- a/src/schemes/boundary/system.jl +++ b/src/schemes/boundary/system.jl @@ -156,9 +156,10 @@ end create_cache_boundary(::Nothing, initial_condition) = (;) function create_cache_boundary(::BoundaryMovement, initial_condition) + initial_coordinates = copy(initial_condition.coordinates) velocity = zero(initial_condition.velocity) acceleration = zero(initial_condition.velocity) - return (; velocity, acceleration) + return (; velocity, acceleration, initial_coordinates) end function Base.show(io::IO, system::BoundarySPHSystem) @@ -194,10 +195,17 @@ timer_name(::Union{BoundarySPHSystem, BoundaryDEMSystem}) = "boundary" eltype(system.coordinates) end -# This does not account for moving boundaries, but it's only used to initialize the -# neighborhood search, anyway. -@inline function initial_coordinates(system::Union{BoundarySPHSystem, BoundaryDEMSystem}) - system.coordinates +@inline function initial_coordinates(system::BoundarySPHSystem) + initial_coordinates(system::BoundarySPHSystem, system.movement) +end + +@inline initial_coordinates(system::BoundaryDEMSystem) = system.coordinates + +@inline initial_coordinates(system::BoundarySPHSystem, ::Nothing) = system.coordinates + +# We need static initial coordinates as reference when system is moving +@inline function initial_coordinates(system::BoundarySPHSystem, movement) + return system.cache.initial_coordinates end function (movement::BoundaryMovement)(system, t)