Basic ODE filtering and smooting implementation.
Project description
ODE Filters
A JAX-based implementation of probabilistic ODE solvers using Gaussian filtering and smoothing. This package provides tools for solving ordinary differential equations while quantifying uncertainty through Bayesian inference.
Features
- Pure JAX implementation - Fully differentiable and JIT-compilable
- Square-root filtering - Numerically stable EKF and RTS smoothing
- Flexible priors - Integrated Wiener Process (IWP), Matern, and joint priors
- First and second-order ODEs - Native support for both ODE types
- Constraint handling - Conservation laws and time-varying measurements
- State-parameter estimation - Joint inference with hidden states
- Black-box measurements - Custom observation models with autodiff Jacobians
- Transformed measurements - Nonlinear state transformations with chain-rule Jacobians
Installation
Install the latest release from PyPI:
pip install ode-filters
Or install from source with development dependencies:
git clone https://github.com/paufisch/ode_filters.git
cd ode_filters
pip install -e ".[dev]"
Quick Example
import jax.numpy as np
from ode_filters.filters import ekf1_sqr_loop, rts_sqr_smoother_loop
from ode_filters.measurement import ODEInformation
from ode_filters.priors import IWP, taylor_mode_initialization
# Define ODE: dx/dt = -x (exponential decay)
def vf(x, *, t):
return -x
x0 = np.array([1.0])
tspan = [0, 5]
# Setup prior and measurement model
prior = IWP(q=2, d=1, Xi=0.5 * np.eye(1))
mu_0, Sigma_0_sqr = taylor_mode_initialization(vf, x0, q=2)
measure = ODEInformation(vf, prior.E0, prior.E1)
# Run filter and smoother
m_seq, P_sqr, *_, G, d, P_back, _, _ = ekf1_sqr_loop(
mu_0, Sigma_0_sqr, prior, measure, tspan, N=50
)
m_smooth, P_smooth_sqr = rts_sqr_smoother_loop(
m_seq[-1], P_sqr[-1], G, d, P_back, N=50
)
Package Structure
ode_filters/
├── filters/ # EKF and RTS smoothing loops
├── inference/ # Square-root Gaussian algebra
├── measurement/ # ODE and observation models
└── priors/ # Gaussian Markov process priors
Documentation
Full documentation is available at paufisch.github.io/ode_filters.
Development
Run the test suite:
uv run pytest --cov=ode_filters --cov-report=term-missing
Build documentation locally:
uv run mkdocs serve
License
MIT License - see LICENSE for details.
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
Filter files by name, interpreter, ABI, and platform.
If you're not sure about the file name format, learn more about wheel file names.
Copy a direct link to the current filters
File details
Details for the file ode_filters-0.5.0.tar.gz.
File metadata
- Download URL: ode_filters-0.5.0.tar.gz
- Upload date:
- Size: 77.2 kB
- Tags: Source
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
97e5dec0facda7f34cf49ef5ab7e72bc2d5e8d8fe2c71966a341f04d352ce0c0
|
|
| MD5 |
07828c13e2ddc98e22510ca5d8db4f70
|
|
| BLAKE2b-256 |
f721cc3ad1f6f1e77fddf09773d7a7992138bcf385fdeb481bbb031bfb79efd5
|
File details
Details for the file ode_filters-0.5.0-py3-none-any.whl.
File metadata
- Download URL: ode_filters-0.5.0-py3-none-any.whl
- Upload date:
- Size: 29.1 kB
- Tags: Python 3
- Uploaded using Trusted Publishing? Yes
- Uploaded via: uv/0.11.7 {"installer":{"name":"uv","version":"0.11.7","subcommand":["publish"]},"python":null,"implementation":{"name":null,"version":null},"distro":{"name":"Ubuntu","version":"24.04","id":"noble","libc":null},"system":{"name":null,"release":null},"cpu":null,"openssl_version":null,"setuptools_version":null,"rustc_version":null,"ci":true}
File hashes
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
a41597a164b8a8c30b2a84d34b0eebb2ee084ad6baad01dfa2e4cdd78da1e94a
|
|
| MD5 |
20b748e021be10a946d40439c6c70742
|
|
| BLAKE2b-256 |
c796970cb4bda805289e3d5df6d1c591ed4c5fa14b916a84cfee546327a8d996
|