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.5.tar.gz (45.2 kB view details)

Uploaded Source

Built Distribution

joe_lab-0.0.5-py3-none-any.whl (56.3 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: joe_lab-0.0.5.tar.gz
  • Upload date:
  • Size: 45.2 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.5.tar.gz
Algorithm Hash digest
SHA256 f601cf74cffcbdac2f78b43b0af3c48100aed3bc7234261597c70d720065b338
MD5 cf8db522bfb069e3153c1411fab5103f
BLAKE2b-256 607e0b0f6c0e61fcf5bdc5d3761691cccdfbd07f5836c47fdc4b63f3caf66dd5

See more details on using hashes here.

File details

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

File metadata

  • Download URL: joe_lab-0.0.5-py3-none-any.whl
  • Upload date:
  • Size: 56.3 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.5-py3-none-any.whl
Algorithm Hash digest
SHA256 b11bb1f1d27c43ce65fe0702bf1d42d1a9e350a3c799c6fad5632463d3004ebc
MD5 8f2fe00dba867e9a4779f814767e5919
BLAKE2b-256 0ee6843cb3bd25e30a7c0298bfd61a485db4073f248da824f186131259062c70

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