Skip to main content

Universal Partial Differential Equations Simulator

Project description

𝕌pdes

𝕌pdes is a general-purpose library for mesh-free PDE simulation and control.

Features

𝕌pdes leverages Radial Basis Functions (RBFs) and JAX to provide the following features:

  • User-centric design: no need to re-implement a solver for each new PDE
  • Lightning fast mesh-free simulation via Radial Basis Functions
  • Robust differentiable simulation via JAX, and portable across CPU, GPU, and TPU
  • Support for Dirichlet, Neumann, Robin, and Periodic boundary conditions
  • Automatic generation of normals from 2D GMSH meshes

𝕌pdes in incredibly extendable, with additional features added frequently.

Getting started

The package is available on PyPI. You can install it with

pip install updes

The example below illustrates how to solve the Laplace equation with Dirichlet and Neumann boundary conditions:

import updes
import jax.numpy as jnp

# Create a mesh-free cloud of points on a unit square
facet_types={"South":"n", "West":"d", "North":"d", "East":"d"}
cloud = updes.SquareCloud(Nx=30, Ny=20, facet_types=facet_types)

# Define the differential operator (left-hand side of the PDE)
def my_diff_operator(x, center, rbf, monomial, fields):
    return updes.nodal_laplacian(x, center, rbf, monomial)

# Define the right-hand side of the PDE
def my_rhs_operator(x, centers, rbf, fields):
    return 0.0

# Set a sin function as the Dirichlet BC on the North, and zero everywhere else
sine = lambda coord: jnp.sin(jnp.pi * coord[0])
zero = lambda coord: 0.0
boundary_conditions = {"South":zero, "West":zero, "North":sine, "East":zero}

# Solve the Laplace equation with a JIT-compiled solver
sol = updes.pde_solver_jit(diff_operator=my_diff_operator, 
                    rhs_operator=my_rhs_operator, 
                    cloud=cloud, 
                    boundary_conditions=boundary_conditions, 
                    rbf=updes.polyharmonic,
                    max_degree=1)

# Visualize the solution
cloud.visualize_field(sol.vals, cmap="jet", projection="3d", title="RBF solution")

𝕌pdes can handle much complicated cases with little to no modifications to the code above. Check out further notebooks and scripts in the documentation and the folder demos!

Dependencies

  • Core: JAX - GMSH - Lineax - Matplotlib - Seaborn - Scikit-Learn
  • Optional: PyVista - FFMPEG - QuartoDoc

See the pyproject.toml file the specific versions of the dependencies.

Cite us !

If you use this software, please cite us with the following BibTeX entry:

@inproceedings{nzoyem2023comparison,
  title={A comparison of mesh-free differentiable programming and data-driven strategies for optimal control under PDE constraints},
  author={Nzoyem Ngueguin, Roussel Desmond and Barton, David AW and Deakin, Tom},
  booktitle={Proceedings of the SC'23 Workshops of The International Conference on High Performance Computing, Network, Storage, and Analysis},
  pages={21--28},
  year={2023}}

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

updes-1.0.2.post1.tar.gz (26.8 kB view details)

Uploaded Source

Built Distribution

updes-1.0.2.post1-py3-none-any.whl (26.2 kB view details)

Uploaded Python 3

File details

Details for the file updes-1.0.2.post1.tar.gz.

File metadata

  • Download URL: updes-1.0.2.post1.tar.gz
  • Upload date:
  • Size: 26.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.10

File hashes

Hashes for updes-1.0.2.post1.tar.gz
Algorithm Hash digest
SHA256 421ae8d6234011c501fdbf899ffd88f215cab72ed0cf17ca314a9691404e2459
MD5 c5cae5752a82646fede17a7eed878dfc
BLAKE2b-256 1d578a4e9d13c8b1fa52aa8388dbcd8cca976ff95820826f3b99668f30b067bc

See more details on using hashes here.

File details

Details for the file updes-1.0.2.post1-py3-none-any.whl.

File metadata

  • Download URL: updes-1.0.2.post1-py3-none-any.whl
  • Upload date:
  • Size: 26.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.10.10

File hashes

Hashes for updes-1.0.2.post1-py3-none-any.whl
Algorithm Hash digest
SHA256 5f7634843f2e7428d9973247bb510acc3980fba76e9bd1e921b358c087338aa0
MD5 c30446246d907fd976066f6bdb30976d
BLAKE2b-256 e860cb3f2dccd6f122179f8adf008c8de7d63389b6842bfdf10c321ef020c0e4

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