A small package including a one-dimensional well-balanced Shallow Water Equations solver.
Project description
Shallow Water Equations Solver
This package provides a well-balanced solver for the one-dimensional Saint-Venant equations, based on the principles outlined in this paper.
Usage
To utilize this package, you can call the `plotSWE`` function with the following parameters:
h, u = plotSWE(B, h0, u0, Nx, tEnd, timePoints, g=1, method='C')
Parameters:
- B (callable): Bottom topography function. This function defines the topographic profile and should take spatial coordinates as input and return the bottom elevation at those coordinates. In case of method 'A', should be an array of two callables, representing B and its derivative.
- h0 (array): Initial water height profile. This should be an array of length Nx, representing the initial water height at different spatial locations.
- u0 (array): Initial water velocity profile. Similar to h0, this should be an array of length Nx, representing the initial water velocity at different spatial locations.
- Nx (int): Number of spatial grid points.
- tEnd (float): End time of the simulation. The simulation starts at time t=0.
- timePoints (list): List of time points at which you want to visualize the results.
- g (float, optional): Gravitational constant. Default is 1.
- method (str, optional): Method selection ('A', 'B' or 'C'). Default is 'C'.
Returns:
- h (array): Array containing the water height profile at the final time point.
- u (array): Array containing the water velocity profile at the final time point.
Example:
from SWE_Solver import plotSWE
from math import sqrt
from scipy.special import erf
Nx = 100
B = lambda x: 1
f = lambda T: 1 + sqrt(3) / (1 - erf(-0.5 / 0.1)) * (erf((T - 0.5) / 0.1) - erf (-0.5 / 0.1))
h0 = [f(_/ (Nx-1)) for _ in range(Nx)]
u0 = [2.0 / h0[_] for _ in range(Nx)]
_ = plotSWE(B, h0, u0, Nx, tEnd=1.0, timePoints=[0.0, 0.1, 0.5, 1.0])
In this example, we're using a spatial grid with 100 points, running the simulation up to t=1
seconds, with gravitational constant g=1
(default value), and visualizing the results at times 0.0
, 0.1
, 0.5
and 1.0
seconds using method 'C'.
This produces the result in the following figure.
Project details
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
Built Distribution
File details
Details for the file SWE_Solver-0.0.4.tar.gz
.
File metadata
- Download URL: SWE_Solver-0.0.4.tar.gz
- Upload date:
- Size: 7.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | eb32ab9dc3763339072c1896476fe689e04e95617387d4150d5fa58aa96ace65 |
|
MD5 | 3315b76c7bacaf29434902908eeab5dd |
|
BLAKE2b-256 | e7df1f362089f09ead47e7a77fb0e220460ef470c9af03109ad5d2a2e4c92c85 |
File details
Details for the file SWE_Solver-0.0.4-py3-none-any.whl
.
File metadata
- Download URL: SWE_Solver-0.0.4-py3-none-any.whl
- Upload date:
- Size: 7.4 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? No
- Uploaded via: twine/4.0.2 CPython/3.11.5
File hashes
Algorithm | Hash digest | |
---|---|---|
SHA256 | f7512ad1f82cbcd3a30a26895b8db23fa588fd8e0f0f8fb3d0719c75cf427fc6 |
|
MD5 | 71e66dc75403b52422b1ac4ced6844e6 |
|
BLAKE2b-256 | 0fabc127502fe1a3966226fad2e544b8f1ac48e6bd722cc1f9680aba35eae0f3 |