Skip to main content

Deep Koopman operators for causal discovery

Project description

Kausal: Deep Koopman Operators for Causal Discovery

Kausal is a PyTorch package to perform causal inference in nonlinear, high-dimensional dynamics using deep Koopman operator-theoretic approach.

arXiv

Overview of Kausal

Features

  • 🌡️ Causal measures between high-dimensional, multi-scale, nonlinear timeseries
  • ⌛ Uncertainty quantification of causal measures
  • 🌐 Causal graph discovery

Abstract

Causal discovery aims to identify cause-effect mechanisms for better scientific understanding, explainable decision-making, and more accurate modeling. Standard statistical frameworks, such as Granger causality, lack the ability to quantify causal relationships in nonlinear dynamics due to the presence of complex feedback mechanisms, timescale mixing, and nonstationarity. Thus, applying these methods to study causal dynamics in real-world systems, such as the Earth, is a major challenge. Addressing this shortcoming, we leverage deep learning and a Koopman operator-theoretic formalism to present a new class of causal discovery algorithms. Kausal uses deep Koopman operator methods to approximate nonlinear dynamics in a linearized vector space in which traditional causal inference methods such as Granger causality can be more easily applied. Our idealized experiments demonstrate Kausal's superior ability in discovering and characterizing causal signals compared to existing deep learning and non-deep learning state-of-the-art approaches. Finally, the successful identification of major El Niño and La Niña events in observations showcases Kausal's skill to handle real-world applications.

Installation

Kausal is available on PyPi, so installation is as easy as:

pip install kausal

If you use conda, please use the following commands:

conda create --name venv python=3.10
conda activate venv
pip install kausal

Quickstart Guide

Please refer to our tutorial notebooks in the tutorial/ folder for demonstration.

Experimental Results

You can find accompanying code to reproduce the experimental results in the experiments/ folder.

Developer's Guide

We welcome and appreciate any contribution to improve the codebase! You can make a Pull Request or raise an Issue. During development, install the package in the editable format:

git clone https://github.com/juannat7/kausal.git
cd kausal/
pip install -e .

Citation

If you find any of the code and dataset useful, feel free to acknowledge our work through:

@article{nathaniel2025deepkoopmanoperatorframework,
  title={Deep Koopman operator framework for causal discovery in nonlinear dynamical systems},
  author={Juan Nathaniel and Carla Roesch and Jatan Buch and Derek DeSantis and Adam Rupe and Kara Lamb and Pierre Gentine},
  journal={arXiv preprint arXiv:2505.14828},
  year={2025}
}

@article{rupe2024causal,
  title={Causal Discovery in Nonlinear Dynamical Systems using Koopman Operators},
  author={Rupe, Adam and DeSantis, Derek and Bakker, Craig and Kooloth, Parvathi and Lu, Jian},
  journal={arXiv preprint arXiv:2410.10103},
  year={2024}
}

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

kausal-1.0.0.tar.gz (12.7 kB view details)

Uploaded Source

Built Distribution

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

kausal-1.0.0-py3-none-any.whl (12.2 kB view details)

Uploaded Python 3

File details

Details for the file kausal-1.0.0.tar.gz.

File metadata

  • Download URL: kausal-1.0.0.tar.gz
  • Upload date:
  • Size: 12.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for kausal-1.0.0.tar.gz
Algorithm Hash digest
SHA256 3a776639eb4d5c7e12b97ed0f9dc811d53b269ec6112ef2108a96471d7323a54
MD5 524aaf37989603fc13017aabb4a9b46b
BLAKE2b-256 e46704df67940eb2ebeb69698e9fec5d0fa8c528c58b364be77a0510ca60c979

See more details on using hashes here.

File details

Details for the file kausal-1.0.0-py3-none-any.whl.

File metadata

  • Download URL: kausal-1.0.0-py3-none-any.whl
  • Upload date:
  • Size: 12.2 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.10.19

File hashes

Hashes for kausal-1.0.0-py3-none-any.whl
Algorithm Hash digest
SHA256 c76d07d413e17d0259f4f9ca66ab93af06410e2417166bd3584d79a11518f649
MD5 eea4d8b6af075b2c5858a27247a69f28
BLAKE2b-256 542dba3b98f9d6dded6f8a9719ac8eae23c783b05d42a268ce5d62182a36f495

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