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.3.1.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.3.1-py3-none-any.whl (26.6 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: sindy_exp-0.3.1.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.3.1.tar.gz
Algorithm Hash digest
SHA256 51fd7bb4b5186c6bceaee46134e594c02217d732d46f328ad3de4c47a46c465b
MD5 9108194997835bc5edce50531990db51
BLAKE2b-256 7483547a60ed3cc742492c0380fc41dd65a0a5e5e78000c8674d5669fd490261

See more details on using hashes here.

Provenance

The following attestation bundles were made for sindy_exp-0.3.1.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.3.1-py3-none-any.whl.

File metadata

  • Download URL: sindy_exp-0.3.1-py3-none-any.whl
  • Upload date:
  • Size: 26.6 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.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 53c063ece79ab106d5ce7cd1bd929944e0814b71452b2d7ad45ca5f42eb1ea34
MD5 e001d336beafbc2d37a0faded2ef21a8
BLAKE2b-256 b9e2ebca02efb90a116a1845050c63585cd666dbc98a5c3a62482c83e1bc55b9

See more details on using hashes here.

Provenance

The following attestation bundles were made for sindy_exp-0.3.1-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