Skip to main content

A package for solving 1+1-dimensional PDEs quickly and accurately with Fourier spectral discretization in space and high-order time-stepping.

Project description

joe

A library for solving partial differential equations for real or complex scalar functions $u(x,t)$ that depend on one spatial variable and one temporal variable. joe uses Fourier spectral discretization in space and high-order exponential time-stepping to rapidly and precisely solve initial-value problems.

FEATURES

-Fast, accurate numerical solutions of partial differential equations (PDEs) of the form $$ \partial_{t}^m u +L\left(\frac{1}{i}\partial_{x}\right)u + f(x,t,u,u_{x}, u_{xx},...) = 0, $$ where $m=1$ or $m=2$, $u(x,t)$ is a real- or complex-valued scalar field defined on an interval, and $L(k)$ , $f$ are some nice functions supplied by the user.

-Supports periodic boundary conditions as well as absorbing boundaries/sponge layers (to simulate waves going off to spatial infinity)

-Users can either call the PDE they want to simulate from a catalogue of built-in options, or define their own custom PDE.

-Easily customizable initial conditions.

-Clean, object-oriented approach to handling simulations makes post-processing (accuracy assesment) very straightforward.

-Producing publication-quality visuals is quick and easy with joe's built-in functions: simply call the right plotting function on your simulation, tweak a few options, and you've got a plot or movie ready to go. Almost all the required matplotlib stuff is under the hood.

DEPENDENCIES

numpy, scipy, matplotlib, cmocean (https://matplotlib.org/cmocean/), alive-progress (https://pypi.org/project/alive-progress/1.0/). You may also want to download FFmpeg support for creating movies: I recommend using the PyAV package (https://pypi.org/project/av).

GETTING STARTED

Open up the Jupyter tutorials (https://github.com/ageorgemorgan/joe/blob/main/demos/tutorials/) to see joe in action!

Currently getting FFmpeg support is a bit of a tough one and it does not auto-install when you install joe. I recommend using conda, installing joe in a conda environment, and then using conda to install PyAV via

conda install av

or

conda install av -c conda-forge

FUTURE DIRECTIONS

-Get support for movies on install without installing further packages!

-Add functionality for fields defined on 2D domains

-Allow for higher-order-derivatives in time (ie. Timoshenko beam equations)

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

joe_lab-0.0.4.tar.gz (33.5 kB view details)

Uploaded Source

Built Distribution

joe_lab-0.0.4-py3-none-any.whl (43.4 kB view details)

Uploaded Python 3

File details

Details for the file joe_lab-0.0.4.tar.gz.

File metadata

  • Download URL: joe_lab-0.0.4.tar.gz
  • Upload date:
  • Size: 33.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.8

File hashes

Hashes for joe_lab-0.0.4.tar.gz
Algorithm Hash digest
SHA256 d718169184ad39fcbd736b8f35c2c6e9fb3cc0c551958adff4335358ae03bbd7
MD5 90e318c2de8f59f056de52c36d7834c9
BLAKE2b-256 4bff1a91bc563537bd1397584dbcab205e31d7ccb1f5618df597c083e1e2cb4b

See more details on using hashes here.

File details

Details for the file joe_lab-0.0.4-py3-none-any.whl.

File metadata

  • Download URL: joe_lab-0.0.4-py3-none-any.whl
  • Upload date:
  • Size: 43.4 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.11.8

File hashes

Hashes for joe_lab-0.0.4-py3-none-any.whl
Algorithm Hash digest
SHA256 284070d5fe0318cc6d0a86c95bf6439e609a496065dd121ef0bcfb5f7bda6f32
MD5 2c8f1a4e03e40bb9029756578d7644c9
BLAKE2b-256 36c4450f94f7bca6f3b91466940362794a45b90dddfba47c5789a6ef9a8e96e2

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