Skip to main content

A basic library for constructing dynamics experiments

Project description

Overview

A library for constructing dynamics experiments from the dynamics models in the dysts package. This includes data generation and model evaluation. The first contribution is the static typing of trajectory data (ProbData) that, I believe, provides the necessary information to be useful in evaluating a wide variety of dynamics/time-series learning methods. The second contribution is the collection of utility functions for designing dynamics learning experiments. The third contribution is the collection of such experiments for evaluating dynamics/time-series learning models that meet the BaseSINDy API.

It aims to (a) be amenable to both numpy and jax arrays, (b) be usable by any dynamics/time-series learning models that meet the BaseSINDy or scikit-time API. Internally, this package is used/will be used in benchmarking pysindy runtime/memory usage and choosing default hyperparameters.

Getting started

Install with pip install sindy-exp or pip install sindy-exp[jax].

Generate data

data = sindy_exp.data.gen_data("lorenz", num_trajectories=5, t_end=10.0, dt=0.01)["data]

Evaluate your SINDy-like model with:

sindy_exp.odes.fit_eval(model, data)

Coefficient plots

A list of available ODE systems can be found in ODE_CLASSES, which includes most of the systems from the dysts package as well as some non-chaotic systems.

ODE & Data Model

Generated or measured data has the dataclass type ProbData or SimProbData, respectively, to indicate whether it includes ground truth information and a noise level. If the data is generated in jax, it will have an integrator that can later be used to evaluate the true data on collocation points.

We deal primarily with autonomous ODE systems of the form:

dx/dt = sum_i f_i(x)

We represent ODE systems as a list of right-hand side expressions. Each element is a dictionary mapping a term (Sympy expression) to its coefficient. Thus, the rhs of an ODE is of type: list[dict[sympy.Expr, float]]

Other useful imports, compatibility, and extensions

  • The experiments are built to be compatible with the mitosis tool, an experiment runner. Mitosis is not a dependency, however, to allow using other experiment runners.
  • To integrate your own experiments or data generation in a way that is compatible, see the ProbData, SimProbData, DynamicsTrialData, and FullDynamicsTrialData classes.
  • For plotting tools, see plot_coefficients, compare_coefficient_plots_from_dicts, plot_test_trajectory, plot_training_data, and COLOR.
  • For evaluation of models, see coeff_metrics, pred_metrics, and integration_metrics.

3d plot 1d plot

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

sindy_exp-0.4.0.tar.gz (332.0 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

sindy_exp-0.4.0-py3-none-any.whl (26.7 kB view details)

Uploaded Python 3

File details

Details for the file sindy_exp-0.4.0.tar.gz.

File metadata

  • Download URL: sindy_exp-0.4.0.tar.gz
  • Upload date:
  • Size: 332.0 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sindy_exp-0.4.0.tar.gz
Algorithm Hash digest
SHA256 b301c3d28ead8b4c0f9eb3ac3a10f7325ab21258f35eb49a13db7793fd3a5993
MD5 3fb3678a6cc15e78176c51d9d1ea5024
BLAKE2b-256 cd66f1a6c999428fc810243262ff54379a092477dad58d3a64279538c6068e61

See more details on using hashes here.

Provenance

The following attestation bundles were made for sindy_exp-0.4.0.tar.gz:

Publisher: release.yml on Jacob-Stevens-Haas/pysindy-experiments

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

File details

Details for the file sindy_exp-0.4.0-py3-none-any.whl.

File metadata

  • Download URL: sindy_exp-0.4.0-py3-none-any.whl
  • Upload date:
  • Size: 26.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? Yes
  • Uploaded via: twine/6.1.0 CPython/3.13.7

File hashes

Hashes for sindy_exp-0.4.0-py3-none-any.whl
Algorithm Hash digest
SHA256 6a8e5c4effddc515ca1b31a60f5ed19837b70f077af5deff13ebf66134c9b373
MD5 9ca6772b23c2cfdda6a9ee4649405091
BLAKE2b-256 0eece99470c37488e52768c8350d0c42c3260c72d655057d7dd0cc2549b19a6b

See more details on using hashes here.

Provenance

The following attestation bundles were made for sindy_exp-0.4.0-py3-none-any.whl:

Publisher: release.yml on Jacob-Stevens-Haas/pysindy-experiments

Attestations: Values shown here reflect the state when the release was signed and may no longer be current.

Supported by

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