Skip to content

Commit

Permalink
use OrdinaryDiffEqTsit5.jl everywhere
Browse files Browse the repository at this point in the history
  • Loading branch information
JoshuaLampert committed Dec 2, 2024
1 parent 7db41d9 commit de43c35
Show file tree
Hide file tree
Showing 42 changed files with 74 additions and 50 deletions.
16 changes: 14 additions & 2 deletions README.md
Original file line number Diff line number Diff line change
Expand Up @@ -26,34 +26,45 @@ A more detailed documentation can be found [online](https://JoshuaLampert.github

If you have not yet installed Julia, then you first need to [download Julia](https://julialang.org/downloads/). Please [follow the instructions for your operating system](https://julialang.org/downloads/platform/).
DispersiveShallowWater.jl works with Julia v1.9 and newer. DispersiveShallowWater.jl is a registered Julia package. Therefore, you can install it by executing the following commands from the Julia REPL

```julia
julia> using Pkg

julia> Pkg.add(["DispersiveShallowWater", "OrdinaryDiffEq", "Plots"])
julia> Pkg.add(["DispersiveShallowWater", "OrdinaryDiffEqTsit5", "Plots"])
```
In addition, this installs the packages [OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl) used for time-integration and [Plots.jl](https://github.com/JuliaPlots/Plots.jl) to visualize the results.

In addition, this installs the packages OrdinaryDiffEqTsit5.jl from [OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl)
used for time-integration and [Plots.jl](https://github.com/JuliaPlots/Plots.jl) to visualize the results. If you want to use
other time integration methods than `Tsit5`, you can install the respective subpackage or OrdinaryDiffEq.jl, which will install
every available solver.
If you want to use other SBP operators than the default operators that DispersiveShallowWater.jl uses, then you also need [SummationByPartsOperators.jl](https://github.com/ranocha/SummationByPartsOperators.jl),
which can be installed running

```julia
julia> Pkg.add("SummationByPartsOperators")
```

## Usage

In the Julia REPL, first load the package DispersiveShallowWater.jl

```julia
julia> using DispersiveShallowWater
```

You can run a basic simulation that solves the BBM-BBM equations by executing

```julia
julia> include(default_example());
```

The result can be visualized by using the package Plots.jl

```julia
julia> using Plots
julia> plot(semi => sol)
```

The command `plot` expects a `Pair` consisting of a `Semidiscretization` and an `ODESolution`. The visualization can also be customized, see the [documentation](https://JoshuaLampert.github.io/DispersiveShallowWater.jl/stable/overview#visualize_results)
for more details. Other examples can be found in the subdirectory [examples/](https://github.com/JoshuaLampert/DispersiveShallowWater.jl/tree/main/examples).
A list of all examples is returned by running `get_examples()`. You can pass the filename of one of the examples or your own simulation file to `include` in order to run it,
Expand All @@ -62,6 +73,7 @@ e.g., `include(joinpath(examples_dir(), "svaerd_kalisch_1d", "svaerd_kalisch_1d_
## Referencing

You can directly refer to DispersiveShallowWater.jl as

```bibtex
@misc{lampert2023dispersive,
title={{D}ispersive{S}hallow{W}ater.jl: {S}tructure-preserving numerical
Expand Down
4 changes: 2 additions & 2 deletions benchmark/Project.toml
Original file line number Diff line number Diff line change
@@ -1,9 +1,9 @@
[deps]
BenchmarkTools = "6e4b80f9-dd63-53aa-95a3-0cdb28fa8baf"
OrdinaryDiffEq = "1dea7af3-3e70-54e6-95c3-0bf5283fa5ed"
OrdinaryDiffEqTsit5 = "b1df2697-797e-41e3-8120-5422d3b24e4a"
SummationByPartsOperators = "9f78cca6-572e-554e-b819-917d2f1cf240"

[compat]
BenchmarkTools = "1"
OrdinaryDiffEq = "6.49.1"
OrdinaryDiffEqTsit5 = "1"
SummationByPartsOperators = "0.5.63"
4 changes: 2 additions & 2 deletions docs/Project.toml
Original file line number Diff line number Diff line change
@@ -1,15 +1,15 @@
[deps]
Changelog = "5217a498-cd5d-4ec6-b8c2-9b85a09b6e3e"
Documenter = "e30172f5-a6a5-5a46-863b-614d45cd2de4"
OrdinaryDiffEq = "1dea7af3-3e70-54e6-95c3-0bf5283fa5ed"
OrdinaryDiffEqTsit5 = "b1df2697-797e-41e3-8120-5422d3b24e4a"
Plots = "91a5bcdd-55d7-5caf-9e0b-520d859cae80"
SummationByPartsOperators = "9f78cca6-572e-554e-b819-917d2f1cf240"
TrixiBase = "9a0f1c46-06d5-4909-a5a3-ce25d3fa3284"

[compat]
Changelog = "1"
Documenter = "1"
OrdinaryDiffEq = "6.49.1"
OrdinaryDiffEqTsit5 = "1"
Plots = "1.9"
SummationByPartsOperators = "0.5.41"
TrixiBase = "0.1.1"
2 changes: 1 addition & 1 deletion docs/src/development.md
Original file line number Diff line number Diff line change
Expand Up @@ -19,7 +19,7 @@ cd DispersiveShallowWater
mkdir run
cd run
julia --project=. -e 'using Pkg; Pkg.develop(PackageSpec(path=".."))' # Install local DispersiveShallowWater.jl clone
julia --project=. -e 'using Pkg; Pkg.add(["OrdinaryDiffEq", "Plots", "SummationByPartsOperators"])' # Install additional packages
julia --project=. -e 'using Pkg; Pkg.add(["OrdinaryDiffEqTsit5", "Plots", "SummationByPartsOperators"])' # Install additional packages
```

If you use other packages for executing DispersiveShallowWater.jl, you can add them to the project in the `run`
Expand Down
16 changes: 14 additions & 2 deletions docs/src/index.md
Original file line number Diff line number Diff line change
Expand Up @@ -25,34 +25,45 @@ Fully discrete entropy-conservative methods can be obtained by using the [relaxa

If you have not yet installed Julia, then you first need to [download Julia](https://julialang.org/downloads/). Please [follow the instructions for your operating system](https://julialang.org/downloads/platform/).
DispersiveShallowWater.jl works with Julia v1.9 and newer. DispersiveShallowWater.jl is a registered Julia package. Therefore, you can install it by executing the following commands from the Julia REPL

```julia
julia> using Pkg

julia> Pkg.add(["DispersiveShallowWater", "OrdinaryDiffEq", "Plots"])
julia> Pkg.add(["DispersiveShallowWater", "OrdinaryDiffEqTsit5", "Plots"])
```
In addition, this installs the packages [OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl) used for time-integration and [Plots.jl](https://github.com/JuliaPlots/Plots.jl) to visualize the results.

In addition, this installs the packages OrdinaryDiffEqTsit5.jl from [OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl)
used for time-integration and [Plots.jl](https://github.com/JuliaPlots/Plots.jl) to visualize the results. If you want to use
other time integration methods than `Tsit5`, you can install the respective subpackage or OrdinaryDiffEq.jl, which will install
every available solver.
If you want to use other SBP operators than the default operators that DispersiveShallowWater.jl uses, then you also need [SummationByPartsOperators.jl](https://github.com/ranocha/SummationByPartsOperators.jl),
which can be installed running

```julia
julia> Pkg.add("SummationByPartsOperators")
```

## Usage

In the Julia REPL, first load the package DispersiveShallowWater.jl

```julia
julia> using DispersiveShallowWater
```

You can run a basic simulation that solves the BBM-BBM equations by executing

```julia
julia> include(default_example());
```

The result can be visualized by using the package Plots.jl

```julia
julia> using Plots
julia> plot(semi => sol)
```

The command `plot` expects a `Pair` consisting of a [`Semidiscretization`](@ref) and an `ODESolution`. The visualization can also be customized, see the [documentation](@ref visualize_results)
for more details. Other examples can be found in the subdirectory [examples/](https://github.com/JoshuaLampert/DispersiveShallowWater.jl/tree/main/examples).
A list of all examples is returned by running [`get_examples()`](@ref). You can pass the filename of one of the examples or your own simulation file to `include` in order to run it,
Expand All @@ -61,6 +72,7 @@ e.g., `include(joinpath(examples_dir(), "svaerd_kalisch_1d", "svaerd_kalisch_1d_
## Referencing

You can directly refer to DispersiveShallowWater.jl as

```bibtex
@misc{lampert2023dispersive,
title={{D}ispersive{S}hallow{W}ater.jl: {S}tructure-preserving numerical
Expand Down
8 changes: 4 additions & 4 deletions docs/src/overview.md
Original file line number Diff line number Diff line change
Expand Up @@ -27,7 +27,7 @@ In order to conduct a numerical simulation with DispersiveShallowWater.jl, we pe
First, we load the necessary libraries:

```@example overview
using DispersiveShallowWater, OrdinaryDiffEq
using DispersiveShallowWater, OrdinaryDiffEqTsit5
```

## Define physical setup
Expand Down Expand Up @@ -106,7 +106,9 @@ is a nonlinear invariant and should be constant over time as well. During the si

Finally, the `ode` can be `solve`d using the interface from [OrdinaryDiffEq.jl](https://github.com/SciML/OrdinaryDiffEq.jl). This means, we can specify a time-stepping
scheme we want to use the tolerances for the adaptive time-stepping and the time values, where the solution values should be saved. In this case, we use the adaptive
explicit Runge-Kutta method `Tsit5` by Tsitouras of order 5(4). Here, we save the solution at 100 equidistant points.
explicit Runge-Kutta method `Tsit5` by Tsitouras of order 5(4), which is implemented in the subpackage OrdinaryDiffEqTsit5.jl. If you want to use other time-stepping
schemes, you can install the respective subpackage or the whole package OrdinaryDiffEq.jl, which will install every available solver.
Here, we save the solution at 100 equidistant points.

```@example overview
tspan = (0.0, 25.0)
Expand Down Expand Up @@ -214,7 +216,6 @@ nothing # hide

![analysis callback relaxation](analysis_callback_relaxation.png)


## [Customize solver](@id customize_solver)

In the semidiscretization created above, we used the default SBP operators, which are periodic finite difference operators. Using different SBP operators for the
Expand Down Expand Up @@ -307,4 +308,3 @@ and [plot_examples.jl](https://github.com/JoshuaLampert/2023-master-thesis/blob/
Ranocha, Sayyari, Dalcin, Parsani, Ketcheson (2020):
Relaxation Runge–Kutta Methods: Fully-Discrete Explicit Entropy-Stable Schemes for the Compressible Euler and Navier–Stokes Equations
[DOI: 10.1137/19M1263480](https://doi.org/10.1137/19M1263480)

2 changes: 1 addition & 1 deletion examples/bbm_1d/bbm_1d_basic.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_1d/bbm_1d_fourier.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: fourier_derivative_operator

Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_1d/bbm_1d_hamiltonian_relaxation.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_1d/bbm_1d_manufactured.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_1d/bbm_1d_relaxation.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_basic.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_basic_reflecting.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: MattssonNordström2004, derivative_operator

Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_dg.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using SummationByPartsOperators: legendre_derivative_operator,
UniformPeriodicMesh1D,
couple_discontinuously
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_dingemans.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_fourier.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: fourier_derivative_operator

Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_manufactured.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_relaxation.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_upwind_relaxation.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: upwind_operators, periodic_derivative_operator
using SparseArrays: sparse
Expand Down
2 changes: 1 addition & 1 deletion examples/bbm_bbm_1d/bbm_bbm_1d_well_balanced.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: periodic_derivative_operator
using SparseArrays: sparse
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
# equations in standard and hyperbolic form
# [arXiv: 2408.02665](https://arxiv.org/abs/2408.02665)

using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: fourier_derivative_operator

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
Expand Up @@ -6,7 +6,7 @@
# equations in standard and hyperbolic form
# [arXiv: 2408.02665](https://arxiv.org/abs/2408.02665)

using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: upwind_operators, periodic_derivative_operator

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: fourier_derivative_operator

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: fourier_derivative_operator

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: upwind_operators, periodic_derivative_operator
using SparseArrays: sparse
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: upwind_operators, periodic_derivative_operator

Expand Down
2 changes: 1 addition & 1 deletion examples/svaerd_kalisch_1d/svaerd_kalisch_1d_dingemans.jl
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: legendre_derivative_operator, UniformPeriodicMesh1D,
couple_continuously, legendre_second_derivative_operator
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: fourier_derivative_operator

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater
using SummationByPartsOperators: upwind_operators, periodic_derivative_operator

Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Original file line number Diff line number Diff line change
@@ -1,4 +1,4 @@
using OrdinaryDiffEq
using OrdinaryDiffEqTsit5
using DispersiveShallowWater

###############################################################################
Expand Down
Loading

0 comments on commit de43c35

Please sign in to comment.