Skip to content

mjayadharan/DAE-FINDER_dev

Repository files navigation

DaeFinder

DaeFinder is a Python package designed to discover Differential Algebraic Equations (DAEs) from noisy data using sparse optimization framework. It is based on the SODAs algorithm developed by the researchers in the Mangan Group at Northwestern University. The associated research paper will soon be available on arXiv, and a link will be provided here once published.

If you use DaeFinder for your development or research, please cite the SODAs paper once it is available.


Author and Contributors

  • Manu Jayadharan (Primary Developer)
  • Christina Catlett
  • Arthur Montanari
  • Niall Mangan

Features

  • Decoupling of Algebraic and Dynamic Equations
  • Smoothening noisy data and calculating derivatives.
  • Generate polynomial features for regression models.
  • Support for sparse feature coupling.
  • SVD Analysis.
  • Example notebooks for practical demonstrations including chemical reaction networks, power grid networks, etc.

Dependencies

The following Python packages are required to use DaeFinder:

  • numpy
  • scipy
  • pandas
  • sympy
  • scikit-learn
  • matplotlib
  • joblib

Installation

To install the DaeFinder package, follow these steps:

  1. Ensure you have Python 3.7 or higher installed.
  2. Install the package using pip:
    pip install DaeFinder
    

Examples

Walkthrough notebooks are available in the Examples/ folder of the repository. These notebooks include:

  • A step-by-step guide to using DaeFinder.
  • Application to chemical reaction network, non-linear pendulum, power grid, etc.

For examples that require additional data (e.g., the power grid example), the data files are included in the GitHub repository. Be sure to download the required datasets from the relevant folders in the repository.

Dependency

In the power-grid example, Matpower 6.0 (https://matpower.org/download/) is required for the power flow calculation.

Known Issues

  • The parallel function currently has some bugs that need fixing.
  • If you encounter issues with the installation or the package itself, please feel free to contact the authors or contributors.

Contributing

We welcome contributions to improve DaeFinder! If you are interested in contributing to the package or working on related research, please reach out to the author or the Mangan Group.

Contact

For any questions, issues, or collaboration inquiries, please contact: