Skip to content
New issue

Have a question about this project? Sign up for a free GitHub account to open an issue and contact its maintainers and the community.

By clicking “Sign up for GitHub”, you agree to our terms of service and privacy statement. We’ll occasionally send you account related emails.

Already on GitHub? Sign in to your account

implement Serre-Green-Naghdi equations for flat bathymetry #127

Merged
merged 38 commits into from
Aug 15, 2024
Merged
Show file tree
Hide file tree
Changes from 33 commits
Commits
Show all changes
38 commits
Select commit Hold shift + click to select a range
6bc35e6
implement Serre-Green-Naghdi equations for flat bathymetry
ranocha Aug 7, 2024
0499a18
fix typos
ranocha Aug 7, 2024
e6981f6
format
ranocha Aug 7, 2024
7b2ae28
update SummationByPartsOperators compat in tests
ranocha Aug 7, 2024
c6824e7
run tests in CI
ranocha Aug 7, 2024
c245c78
fix stuff gone wrong when formatting
ranocha Aug 8, 2024
3662333
Apply suggestions from code review
ranocha Aug 9, 2024
eff30f3
Apply suggestions from code review
ranocha Aug 9, 2024
221e310
format
ranocha Aug 9, 2024
c49c80f
use Fourier and add comments
ranocha Aug 9, 2024
6a36eda
Merge branch 'main' into hr/serre_green_naghdi
ranocha Aug 9, 2024
85a26de
add upwind version
ranocha Aug 9, 2024
02b4b75
unit tests
ranocha Aug 9, 2024
ea350d6
fix typo
ranocha Aug 9, 2024
dca91a1
AbstractShallowWaterEquations
ranocha Aug 13, 2024
7060a9d
add relaxation example
ranocha Aug 13, 2024
f703935
docstring for energy_total_modified for SGN
ranocha Aug 13, 2024
9964c0c
remove obsolete specializations
ranocha Aug 13, 2024
7572b53
format
ranocha Aug 13, 2024
a1316be
fix docstrings
ranocha Aug 13, 2024
012303f
allow nothing for D2
ranocha Aug 13, 2024
72caf65
store bathymetry in q
ranocha Aug 13, 2024
519902c
document bathymetry
ranocha Aug 13, 2024
0e9cb44
fix unit tests
ranocha Aug 13, 2024
3ba8d2a
unit tests for energy_total_modified
ranocha Aug 14, 2024
9a0ceca
fix type instability of allocate_coefficients
ranocha Aug 14, 2024
dab44c5
another unit test for energy_total_modified
ranocha Aug 14, 2024
0e256a5
Apply suggestions from code review
ranocha Aug 14, 2024
89cddab
consistency adaptations for SvaerdKalischEquations1D
ranocha Aug 14, 2024
ceba71c
additional tests for type stability
ranocha Aug 14, 2024
c269bb6
format
ranocha Aug 14, 2024
6de4649
fix
ranocha Aug 14, 2024
1413af8
more unit tests
ranocha Aug 14, 2024
3052b77
Apply suggestions from code review
ranocha Aug 14, 2024
3f0dbfa
dispatch RHS on bathymetry
ranocha Aug 14, 2024
53a172d
stricter test tolerance
ranocha Aug 14, 2024
0bfbeea
make allocs tests stricter
ranocha Aug 15, 2024
ad71305
fix docstring
ranocha Aug 15, 2024
File filter

Filter by extension

Filter by extension

Conversations
Failed to load comments.
Loading
Jump to
Jump to file
Failed to load files.
Loading
Diff view
Diff view
2 changes: 1 addition & 1 deletion Project.toml
Original file line number Diff line number Diff line change
Expand Up @@ -37,7 +37,7 @@ SciMLBase = "2.11"
SimpleUnPack = "1.1"
SparseArrays = "1"
StaticArrays = "1"
SummationByPartsOperators = "0.5.52"
SummationByPartsOperators = "0.5.63"
TimerOutputs = "0.5.7"
TrixiBase = "0.1.3"
julia = "1.9"
5 changes: 3 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -10,10 +10,11 @@
[![DOI](https://zenodo.org/badge/635090135.svg)](https://zenodo.org/doi/10.5281/zenodo.10034636)

**DispersiveShallowWater.jl** is a [Julia](https://julialang.org/) package that implements structure-preserving numerical methods for dispersive shallow water models.
To date, it provides provably conservative, entropy-conserving and well-balanced numerical schemes for two dispersive shallow water models:
To date, it provides provably conservative, entropy-conserving and well-balanced numerical schemes for some dispersive shallow water models:

* the [BBM-BBM equations with varying bottom topography](https://iopscience.iop.org/article/10.1088/1361-6544/ac3c29),
* the [dispersive shallow water model proposed by Magnus Svärd and Henrik Kalisch](https://arxiv.org/abs/2302.09924).
* the [dispersive shallow water model proposed by Magnus Svärd and Henrik Kalisch](https://arxiv.org/abs/2302.09924),
* the [Serre-Green-Naghdi equations](https://arxiv.org/abs/2408.02665).

The semidiscretizations are based on summation by parts (SBP) operators, which are implemented in [SummationByPartsOperators.jl](https://github.com/ranocha/SummationByPartsOperators.jl/).
In order to obtain fully discrete schemes, the time integration methods from [OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl) are used to solve the resulting ordinary differential equations.
Expand Down
40 changes: 40 additions & 0 deletions examples/serre_green_naghdi_1d/serre_green_naghdi_soliton.jl
Original file line number Diff line number Diff line change
@@ -0,0 +1,40 @@
using OrdinaryDiffEq
using DispersiveShallowWater

###############################################################################
# Semidiscretization of the Serre-Green-Naghdi equations

equations = SerreGreenNaghdiEquations1D(gravity_constant = 9.81)

# initial_condition_convergence_test needs periodic boundary conditions
initial_condition = initial_condition_convergence_test
boundary_conditions = boundary_condition_periodic

# create homogeneous mesh
coordinates_min = -50.0
coordinates_max = 50.0
N = 512
mesh = Mesh1D(coordinates_min, coordinates_max, N)

# create solver with periodic SBP operators of accuracy order 4
accuracy_order = 4
solver = Solver(mesh, accuracy_order)

# semidiscretization holds all the necessary data structures for the spatial discretization
semi = Semidiscretization(mesh, equations, initial_condition, solver,
boundary_conditions = boundary_conditions)

###############################################################################
# Create `ODEProblem` and run the simulation
tspan = (0.0, (xmax(mesh) - xmin(mesh)) / sqrt(1.2 * equations.gravity)) # one period
ode = semidiscretize(semi, tspan)
summary_callback = SummaryCallback()
analysis_callback = AnalysisCallback(semi; interval = 100,
extra_analysis_errors = (:conservation_error,),
extra_analysis_integrals = (waterheight_total,
entropy_modified))
callbacks = CallbackSet(analysis_callback, summary_callback)

saveat = range(tspan..., length = 100)
sol = solve(ode, Tsit5(), abstol = 1e-7, reltol = 1e-7,
save_everystep = false, callback = callbacks, saveat = saveat)
Original file line number Diff line number Diff line change
@@ -0,0 +1,41 @@
using OrdinaryDiffEq
using DispersiveShallowWater
using SummationByPartsOperators: fourier_derivative_operator

###############################################################################
# Semidiscretization of the Serre-Green-Naghdi equations

equations = SerreGreenNaghdiEquations1D(gravity_constant = 9.81)

# initial_condition_convergence_test needs periodic boundary conditions
initial_condition = initial_condition_convergence_test
boundary_conditions = boundary_condition_periodic

# create homogeneous mesh
coordinates_min = -50.0
coordinates_max = 50.0
N = 128
mesh = Mesh1D(coordinates_min, coordinates_max, N)

# create solver with Fourier pseudospectral collocation method
D1 = fourier_derivative_operator(xmin(mesh), xmax(mesh), nnodes(mesh))
solver = Solver(D1, nothing)

# semidiscretization holds all the necessary data structures for the spatial discretization
semi = Semidiscretization(mesh, equations, initial_condition, solver,
boundary_conditions = boundary_conditions)

###############################################################################
# Create `ODEProblem` and run the simulation
tspan = (0.0, (xmax(mesh) - xmin(mesh)) / sqrt(1.2 * equations.gravity)) # one period
ode = semidiscretize(semi, tspan)
summary_callback = SummaryCallback()
analysis_callback = AnalysisCallback(semi; interval = 100,
extra_analysis_errors = (:conservation_error,),
extra_analysis_integrals = (waterheight_total,
entropy_modified))
callbacks = CallbackSet(analysis_callback, summary_callback)

saveat = range(tspan..., length = 100)
sol = solve(ode, Tsit5(), abstol = 1e-7, reltol = 1e-7,
save_everystep = false, callback = callbacks, saveat = saveat)
Original file line number Diff line number Diff line change
@@ -0,0 +1,43 @@
using OrdinaryDiffEq
using DispersiveShallowWater
using SummationByPartsOperators: fourier_derivative_operator

###############################################################################
# Semidiscretization of the Serre-Green-Naghdi equations

equations = SerreGreenNaghdiEquations1D(gravity_constant = 9.81)

# initial_condition_convergence_test needs periodic boundary conditions
initial_condition = initial_condition_convergence_test
boundary_conditions = boundary_condition_periodic

# create homogeneous mesh
coordinates_min = -50.0
coordinates_max = 50.0
N = 128
mesh = Mesh1D(coordinates_min, coordinates_max, N)

# create solver with Fourier pseudospectral collocation method
D1 = fourier_derivative_operator(xmin(mesh), xmax(mesh), nnodes(mesh))
solver = Solver(D1, nothing)

# semidiscretization holds all the necessary data structures for the spatial discretization
semi = Semidiscretization(mesh, equations, initial_condition, solver,
boundary_conditions = boundary_conditions)

###############################################################################
# Create `ODEProblem` and run the simulation
tspan = (0.0, (xmax(mesh) - xmin(mesh)) / sqrt(1.2 * equations.gravity)) # one period
ode = semidiscretize(semi, tspan)
summary_callback = SummaryCallback()
analysis_callback = AnalysisCallback(semi; interval = 100,
extra_analysis_errors = (:conservation_error,),
extra_analysis_integrals = (waterheight_total,
entropy_modified))
relaxation_callback = RelaxationCallback(invariant = entropy_modified)
# Always put relaxation_callback before analysis_callback to guarantee conservation of the invariant
callbacks = CallbackSet(relaxation_callback, analysis_callback, summary_callback)

saveat = range(tspan..., length = 100)
sol = solve(ode, Tsit5(), abstol = 1e-7, reltol = 1e-7,
save_everystep = false, callback = callbacks, saveat = saveat)
Original file line number Diff line number Diff line change
@@ -0,0 +1,48 @@
using OrdinaryDiffEq
using DispersiveShallowWater
using SummationByPartsOperators: upwind_operators, periodic_derivative_operator
using SparseArrays: sparse

###############################################################################
# Semidiscretization of the Serre-Green-Naghdi equations

equations = SerreGreenNaghdiEquations1D(gravity_constant = 9.81)

# initial_condition_convergence_test needs periodic boundary conditions
initial_condition = initial_condition_convergence_test
boundary_conditions = boundary_condition_periodic

# create homogeneous mesh
coordinates_min = -50.0
coordinates_max = 50.0
N = 512
mesh = Mesh1D(coordinates_min, coordinates_max, N)

# create solver with periodic upwind SBP operators of accuracy order 4
# (note that only central-type with even order are used)
accuracy_order = 4
D1 = upwind_operators(periodic_derivative_operator;
derivative_order = 1,
accuracy_order = accuracy_order - 1,
xmin = xmin(mesh), xmax = xmax(mesh),
N = nnodes(mesh))
solver = Solver(D1, nothing)

# semidiscretization holds all the necessary data structures for the spatial discretization
semi = Semidiscretization(mesh, equations, initial_condition, solver,
boundary_conditions = boundary_conditions)

###############################################################################
# Create `ODEProblem` and run the simulation
tspan = (0.0, (xmax(mesh) - xmin(mesh)) / sqrt(1.2 * equations.gravity)) # one period
ode = semidiscretize(semi, tspan)
summary_callback = SummaryCallback()
analysis_callback = AnalysisCallback(semi; interval = 100,
extra_analysis_errors = (:conservation_error,),
extra_analysis_integrals = (waterheight_total,
entropy_modified))
callbacks = CallbackSet(analysis_callback, summary_callback)

saveat = range(tspan..., length = 100)
sol = solve(ode, Tsit5(), abstol = 1e-7, reltol = 1e-7,
save_everystep = false, callback = callbacks, saveat = saveat)
25 changes: 18 additions & 7 deletions src/DispersiveShallowWater.jl
Original file line number Diff line number Diff line change
Expand Up @@ -17,14 +17,17 @@ import SciMLBase: u_modified!

@reexport using StaticArrays: SVector
using SimpleUnPack: @unpack
using SparseArrays: sparse
using SummationByPartsOperators: AbstractDerivativeOperator,
using SparseArrays: sparse, issparse
using SummationByPartsOperators: SummationByPartsOperators,
AbstractDerivativeOperator,
PeriodicDerivativeOperator, PeriodicUpwindOperators,
UniformPeriodicCoupledOperator,
DerivativeOperator, UpwindOperators,
UniformCoupledOperator,
FourierDerivativeOperator,
periodic_derivative_operator,
derivative_order, integrate, mass_matrix
derivative_order, integrate, mass_matrix,
scale_by_mass_matrix!
import SummationByPartsOperators: grid, xmin, xmax
using TimerOutputs: TimerOutputs, print_timer, reset_timer!
@reexport using TrixiBase: trixi_include
Expand All @@ -41,11 +44,17 @@ include("util.jl")

export examples_dir, get_examples, default_example, convergence_test

export BBMBBMEquations1D, BBMBBMVariableEquations1D, SvärdKalischEquations1D,
SvaerdKalischEquations1D
export AbstractShallowWaterEquations,
BBMBBMEquations1D, BBMBBMVariableEquations1D,
SvärdKalischEquations1D, SvaerdKalischEquations1D,
SerreGreenNaghdiEquations1D

export prim2prim, prim2cons, cons2prim, waterheight_total, waterheight,
velocity, momentum, discharge, energy_total, entropy, lake_at_rest_error,
export prim2prim, prim2cons, cons2prim,
waterheight_total, waterheight,
velocity, momentum, discharge,
gravity_constant,
bathymetry, still_water_surface,
energy_total, entropy, lake_at_rest_error,
energy_total_modified, entropy_modified

export Mesh1D, xmin, xmax, nnodes
Expand All @@ -56,6 +65,8 @@ export Semidiscretization, semidiscretize, grid

export boundary_condition_periodic, boundary_condition_reflecting

export bathymetry_flat

export initial_condition_convergence_test,
initial_condition_manufactured, source_terms_manufactured,
initial_condition_manufactured_reflecting, source_terms_manufactured_reflecting,
Expand Down
7 changes: 5 additions & 2 deletions src/callbacks_step/analysis.jl
Original file line number Diff line number Diff line change
Expand Up @@ -116,7 +116,7 @@ end

"""
errors(analysis_callback)
Return the computed errors for each timestep as a named tuple.
The shape of each entry is (nvariables, ntimesteps).
"""
Expand Down Expand Up @@ -330,7 +330,10 @@ function analyze(quantity, q, t, semi::Semidiscretization)
integrate_quantity(q -> quantity(q, semi.equations), q, semi)
end

# modified entropy from Svärd-Kalisch equations need to take the whole vector `u` for every point in space
# The modified entropy/energy of the Svärd-Kalisch and
# Serre-Green-Naghdi equations
# takes the whole `q` for every point in space since it requires
# the derivative of the velocity `v_x`.
JoshuaLampert marked this conversation as resolved.
Show resolved Hide resolved
function analyze(quantity::Union{typeof(energy_total_modified), typeof(entropy_modified)},
q, t, semi::Semidiscretization)
integrate_quantity(quantity, q, semi)
Expand Down
9 changes: 1 addition & 8 deletions src/equations/bbm_bbm_1d.jl
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
@doc raw"""
BBMBBMEquations1D(gravity, D, eta0 = 0.0)
BBMBBMEquations1D(; gravity_constant, D = 1.0, eta0 = 0.0)
BBM-BBM (Benjamin–Bona–Mahony) system in one spatial dimension. The equations are given by
```math
Expand Down Expand Up @@ -292,11 +292,4 @@ end
return waterheight_total(q, equations) - bathymetry(q, equations)
end

@inline function energy_total(q, equations::BBMBBMEquations1D)
eta, v = q
D = still_waterdepth(q, equations)
e = 0.5 * (equations.gravity * eta^2 + (D + eta - equations.eta0) * v^2)
return e
end

@inline entropy(q, equations::BBMBBMEquations1D) = energy_total(q, equations)
8 changes: 1 addition & 7 deletions src/equations/bbm_bbm_variable_bathymetry_1d.jl
Original file line number Diff line number Diff line change
@@ -1,5 +1,5 @@
@doc raw"""
BBMBBMVariableEquations1D(gravity, eta0 = 1.0)
BBMBBMVariableEquations1D(; gravity_constant, eta0 = 0.0)
BBM-BBM (Benjamin–Bona–Mahony) system in one spatial dimension with spatially varying bathymetry. The equations are given by
```math
Expand Down Expand Up @@ -378,12 +378,6 @@ end
return waterheight_total(q, equations) - bathymetry(q, equations)
end

@inline function energy_total(q, equations::BBMBBMVariableEquations1D)
eta, v, D = q
e = 0.5 * (equations.gravity * eta^2 + (D + eta - equations.eta0) * v^2)
return e
end

@inline entropy(q, equations::BBMBBMVariableEquations1D) = energy_total(q, equations)

# Calculate the error for the "lake-at-rest" test case where eta should
Expand Down
Loading
Loading