Skip to main content

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


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

SWE_Solver-0.0.4.tar.gz (7.2 kB view details)

Uploaded Source

Built Distribution

SWE_Solver-0.0.4-py3-none-any.whl (7.4 kB view details)

Uploaded Python 3

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

Hashes for SWE_Solver-0.0.4.tar.gz
Algorithm Hash digest
SHA256 eb32ab9dc3763339072c1896476fe689e04e95617387d4150d5fa58aa96ace65
MD5 3315b76c7bacaf29434902908eeab5dd
BLAKE2b-256 e7df1f362089f09ead47e7a77fb0e220460ef470c9af03109ad5d2a2e4c92c85

See more details on using hashes here.

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

Hashes for SWE_Solver-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 f7512ad1f82cbcd3a30a26895b8db23fa588fd8e0f0f8fb3d0719c75cf427fc6
MD5 71e66dc75403b52422b1ac4ced6844e6
BLAKE2b-256 0fabc127502fe1a3966226fad2e544b8f1ac48e6bd722cc1f9680aba35eae0f3

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page