Skip to main content

Data-driven learning of dynamical system in the SUBNET structure and ANNs

Project description

deepSI

deepSI provides a lightweight PyTorch-based framework for data-driven learning of dynamical systems (i.e., system identification). It focuses on the SUBNET method, which robustly models many systems.

⚠️ deepSI has been refactored without backward compatibility (5 December 2024) ⚠️

If you need to install the legacy version, you can do so with:

pip install git+https://github.com/GerbenBeintema/deepSI@legacy

and by using the legacy documentation available at https://github.com/MaartenSchoukens/deepSI/tree/legacy.

Example usage

import numpy as np
import deepSI as dsi

# Generate or load data 
np.random.seed(0)
ulist = np.random.randn(10_000) # Input sequence
x = [0, 0] # Initial state
ylist = [] # Output sequence
for uk in ulist:
    ylist.append(x[1]*x[0]*0.1 + x[0] + np.random.randn()*1e-3)  # Compute output
    x = x[0]/(1.2+x[1]**2) + x[1]*0.4, \
        x[1]/(1.2+x[0]**2) + x[0]*0.4 + uk*(1+x[0]**2/10) # Advance state

# Put the input and output sequence in the Input_output_data format
data = dsi.Input_output_data(u=ulist, y=np.array(ylist)) 

# Split dataset
train, val, test  = data[:8000], data[8000:9000], data[9000:]

# Create model
nu, ny, norm = dsi.get_nu_ny_and_auto_norm(data) # Characterize data
model = dsi.SUBNET(nu, ny, norm, nx=2, nb=20, na=20) # Creates encoder, f and h as MLP

# Train model on data using Adam
train_dict = dsi.fit(model, train, val, n_its=10_000, T=20, batch_size=256, val_freq=100)

# Simulate model on the test input sequence (using the encoder to initialize the state)
test_p = model.simulate(test)

# Visualize simulation of the model
from matplotlib import pyplot as plt
plt.figure(figsize=(7,3))
plt.plot(test.y, label='Real Data')
plt.plot(test_p.y, label=f'Model Sim. (NRMS = {((test.y-test_p.y)**2).mean()**0.5/test.y.std():.2%})', linestyle='--')
plt.title('Comparison of Real Data and Model Simulation', fontsize=14, fontweight='bold')
plt.legend(); plt.xlabel('Time Index'); plt.ylabel('y'); plt.grid(); plt.tight_layout(pad=0.5)
plt.show()

dsi SUBNET result on example

Installation

pip install deepSI

Features

  • A number of popular SUBNET model structures
    • SUBNET encoder structue (deepSI.models.SUBNET). Featuring in: [1], [2], [3], [4], [5]
    • Continuous time SUBNET encoder structure (deepSI.models.SUBNET_CT). Featuring in: [6], [7], [8]
    • Base class for fully custom SUBNET structures with shared parameters between f, h or encoder. (deepSI.models.Custom_SUBNET) as used in:
    • CNN SUBNET (CNN_SUBNET). Featuring in: [9] Chapter 4, [10]
    • LPV SUBNET (SUBNET_LPV and SUBNET_LPV_ext_scheduled). Featuring in: [11]
    • port HNN SUBNET (pHNN_SUBNET). Featuring in: [12]
    • Koopman SUBNET (Koopman_SUBNET). Featuring in: [13]
  • Connection to nonlinear_benchmarks to easily load and evaluate on benchmarks.
  • Low amount of code such that it can be easily forked and edited to add missing features.

Futher documentation

Check out examples/1. Overview deepSI.ipynb.

Contributing

deepSI is under ongoing development, and contributions to any part of the module are welcome.

todo list and known issues

  • Expand demonstration notebook with pHNN examples.
  • Issue where discrete time is printed in Input_output_data with torch.Tensors, and np.array sample time.
  • General documentation improvements.
  • Known issue: CT SUBNET and DT SUBNET do not produce the correct initial state when the sampling time is altered (the encoder assumes the sampling time does not change).
  • Possible improvement: Improve speed by copying if sufficient memory is available. Also, consider pre-transfer to GPU and asynchronous array retrieval.
  • Known issue: Using the compile function in fit may result in a memory leak.

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

deepsi-0.4.4.tar.gz (19.7 kB view details)

Uploaded Source

Built Distribution

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

deepsi-0.4.4-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file deepsi-0.4.4.tar.gz.

File metadata

  • Download URL: deepsi-0.4.4.tar.gz
  • Upload date:
  • Size: 19.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.10

File hashes

Hashes for deepsi-0.4.4.tar.gz
Algorithm Hash digest
SHA256 0c9b8b3935e04a7feae067a37bd7ee46dbc97d9bbd3372924c4132a32a6f8f40
MD5 3283b6591f32413934aa91f61ebec29a
BLAKE2b-256 28510134ec4fda47ca09f207414c17ddb5772a79cf957e9f69ac178e8215bc4f

See more details on using hashes here.

File details

Details for the file deepsi-0.4.4-py3-none-any.whl.

File metadata

  • Download URL: deepsi-0.4.4-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.0.1 CPython/3.11.10

File hashes

Hashes for deepsi-0.4.4-py3-none-any.whl
Algorithm Hash digest
SHA256 b5b72694159085d512217f706d856cf878971cc5a480af3dfd138cb758aebabb
MD5 874a79aba94508cdccd9f69027d5ff3a
BLAKE2b-256 047cd1fd59cdedeb981a5b3617b1dd737613ce711aba396b6317d617a63af2a5

See more details on using hashes here.

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