datafold


Namedatafold JSON
Version 2.0.0 PyPI version JSON
download
home_pagehttps://datafold-dev.gitlab.io/datafold
SummaryOperator-theoretic models to identify dynamical systems and parametrize point cloud geometry
upload_time2023-07-31 21:06:17
maintainer
docs_urlNone
authordatafold development team
requires_python>=3.9
licenseMIT
keywords mathematics machine learning dynamical system data-driven time series regression forecasting manifold learning diffusion map koopman operator nonlinear
VCS
bugtrack_url
requirements No requirements were recorded.
Travis-CI No Travis.
coveralls test coverage No coveralls.
            Quick links
^^^^^^^^^^^

`Source repository <https://gitlab.com/datafold-dev/datafold>`__ |
`Contributing and feedback <https://datafold-dev.gitlab.io/datafold/contributing.html>`__ |
`PyPI <https://pypi.org/project/datafold/>`__ |
`Documentation <https://datafold-dev.gitlab.io/datafold/>`__ |
`Tutorials <https://datafold-dev.gitlab.io/datafold/tutorial_index.html>`__ |
`Scientific literature <https://datafold-dev.gitlab.io/datafold/references.html>`__

What is *datafold*?
====================

*datafold* is a `MIT-licensed <https://gitlab.com/datafold-dev/datafold/-/blob/master/LICENSE>`__
Python package containing operator-theoretic, data-driven models to identify dynamical
systems from time series data and to infer geometrical structures in point clouds.

The package includes:

* An efficient implementation of the ``DiffusionMaps`` model to infer geometric
  meaningful structures from data, such as the eigenfunctions of the
  Laplace-Beltrami operator. As a distinguishing factor to other implementations, the
  model can handle a sparse kernel matrix and allows setting an arbitrary kernel,
  including the standard Gaussian kernel,
  `continuous k-nearest neighbor kernel <https://arxiv.org/abs/1606.02353>`__, or
  `dynamics-adapted cone kernel <https://cims.nyu.edu/~dimitris/files/Giannakis15_cone_kernels.pdf>`__.
* Implementations and variants of the Dynamic Mode Decomposition as data-driven methods to
  identify and analyze dynamical systems from time series collection data. This incldues:
  * ``DMDFull`` or ``DMDEco`` as standard methods of DMD
  * ``OnlineDMD`` or ``StreamingDMD`` modify the DMD to handle streaming data
  * ``DMDControl`` augments the DMD to handle additional control input
  * ``EDMD`` - The Extended-DMD, which allows setting up a highly flexible dictionary to
  transform time series data and thereby handle nonlinear dynamics within the Koopman
  operator framework. The EDMD wraps an arbitrary DMD variation for the decomposition.
  The key advantage of this is, that the ``EDMD`` directly profits from the above
  functionalities. ``EDMD`` can be used in control or streaming settings. Furthermore it is
  possible to learn the dictionary directly from data (commonly referred to EDMD-DL)
* Handling of cross-validation. The method ``EDMDCV``, for example, allows model parameters to
  be optimized with cross-validation splittings that account for the temporal order in time
  series data.
* Methods to perform Model Predictive Control (MPC) with Koopman operator-based methods (
  mainly the ``EDMD``). *This is currently still under development and experimental*.
* Regression models for high-dimensional data (often used for out-of-sample extensions for the
  Diffusion Maps model), such as the (auto-tuned) Laplacian Pyramids or Geometric Harmonics to
  interpolate general function values on a point cloud manifold.
* A data structure ``TSCDataFrame`` to handle time series collection data. It simplifies model
  inputs/outputs and make it easier to describe various forms of time series data.

See also `this introduction page <https://datafold-dev.gitlab.io/datafold/intro.html>`__.
For a mathematical thorough introduction, we refer to the `scientific literature
<https://datafold-dev.gitlab.io/datafold/references.html>`__.

.. note::
    The project is under active development in a research-driven environment.

    * Code quality varies from "experimental/early stage" to "well-tested". Well tested
      code is listed in the
      `software documentation <https://datafold-dev.gitlab.io/datafold/api.html>`__
      and are directly accessible through the highest module level (e.g.
      :code:`from datafold import ...`). Experimental code is
      only accessible via "deep imports" (e.g.
      :code:`from datafol.dynfold.outofsample import ...`) and may raise a warning when using
      it.
    * The interfaces within *datafold* are not stable. The software is **not** intended for
      production. Nevertheless, if we break something it is intentional and we hope that such
      adaptations become less over time.
    * There is no deprecation cycle. The software uses
      `semantic versioning <https://semver.org/>`__ policy `[major].[minor].[patch]`, i.e.

         * `major` - making incompatible changes in the (documented) API
         * `minor` - adding functionality in a backwards-compatible manner
         * `patch` - backwards-compatible bug fixes

      We do not intend to indicate a feature complete milestone with version `1.0`.

Cite
====

If you use *datafold* in your research, please cite
`this paper <https://joss.theoj.org/papers/10.21105/joss.02283>`__ published in the
*Journal of Open Source Software* (`JOSS <https://joss.theoj.org/>`__).

*Lehmberg et al., (2020). datafold: data-driven models for point clouds and time series on
manifolds. Journal of Open Source Software, 5(51), 2283,* https://doi.org/10.21105/joss.02283

BibTeX:

.. code-block:: latex

    @article{Lehmberg2020,
             doi       = {10.21105/joss.02283},
             url       = {https://doi.org/10.21105/joss.02283},
             year      = {2020},
             publisher = {The Open Journal},
             volume    = {5},
             number    = {51},
             pages     = {2283},
             author    = {Daniel Lehmberg and Felix Dietrich and Gerta K{\"o}ster and Hans-Joachim Bungartz},
             title     = {datafold: data-driven models for point clouds and time series on manifolds},
             journal   = {Journal of Open Source Software}}

How to get it?
==============

Installation requires `Python>=3.9 <https://www.python.org/>`__ with
`pip <https://pip.pypa.io/en/stable/>`__ and
`setuptools <https://setuptools.pypa.io/en/latest/>`__ installed (both packages ship with a
standard Python installation). The package dependencies
install automatically. The main dependencies and their usage in *datafold* are listed
in the section "Dependencies" below.

There are two ways to install *datafold*:

1. From PyPI
------------

This is the standard way for users. The package is hosted on the official Python package
index (PyPI) and installs the core package (excluding tutorials and tests). The tutorial
files can be downloaded separately
`here <https://datafold-dev.gitlab.io/datafold/tutorial_index.html>`__.

To install the package and its dependencies with :code:`pip`, run

.. code-block:: bash

   python -m pip install datafold

.. note::

    If you run Python in an Anaconda environment you can use pip from within ``conda``.
    See also
    `official instructions <https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-pkgs.html#installing-non-conda-packages>`__.

    .. code-block:: bash

        conda activate venv
        conda install pip
        pip install datafold

2. From source
--------------

This way is recommended if you want to access the latest (but potentially unstable)
development state, run tests or wish to contribute (see section "Contributing" for details).
Download or git-clone the source code repository.

1. Download the repository

   a. If you wish to contribute code, it is required to have
      `git <https://git-scm.com/>`__ installed. Clone the repository with

      .. code-block:: bash

        git clone https://gitlab.com/datafold-dev/datafold.git

   b. If you only want access to the source code (current ``master`` branch), download one
      of the compressed file types
      (`zip <https://gitlab.com/datafold-dev/datafold/-/archive/master/datafold-master.zip>`__,
      `tar.gz <https://gitlab.com/datafold-dev/datafold/-/archive/master/datafold-master.tar.gz>`__,
      `tar.bz2 <https://gitlab.com/datafold-dev/datafold/-/archive/master/datafold-master.tar.bz2>`__,
      `tar <https://gitlab.com/datafold-dev/datafold/-/archive/master/datafold-master.tar>`__)

2. Install the package from the downloaded repository

   .. code-block:: bash

       python -m pip install .

Contributing
============

Any contribution (code/tutorials/documentation improvements), question or feedback is
very welcome. Either use the
`issue tracker <https://gitlab.com/datafold-dev/datafold/-/issues>`__ or
`Email <incoming+datafold-dev-datafold-14878376-issue-@incoming.gitlab.com>`__ us.
Instructions to set up *datafold* for development can be found
`here <https://datafold-dev.gitlab.io/datafold/contributing.html>`__.

Dependencies
============

The dependencies of the core package are managed in the file
`requirements.txt <https://gitlab.com/datafold-dev/datafold/-/blob/master/requirements.txt>`__
and install with *datafold*. The tests, tutorials, documentation and code analysis
require additional dependencies which are managed in
`requirements-dev.txt <https://gitlab.com/datafold-dev/datafold/-/blob/master/requirements-dev.txt>`__.

*datafold* integrates with common packages from the
`Python scientific computing stack <https://scipy.org/about/>`__:

* `NumPy <https://numpy.org/>`__
   NumPy is used throughout *datafold* and is the default package for numerical
   data and algorithms.

* `pandas <https://pandas.pydata.org/pandas-docs/stable/index.html>`__
   *datafold* uses pandas'
   `DataFrame <https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.DataFrame.html>`__
   as a base class for ``TSCDataFrame`` to capture various forms of time series data. The data
   It includes specific time series collection functionality and is mostly compatible with
   pandas' rich functionality.

* `scikit-learn <https://scikit-learn.org/stable/>`__
   All *datafold* algorithms that are part of the "machine learning pipeline" align
   to the scikit-learn `API <https://scikit-learn.org/stable/developers/develop.html>`__.
   This is done by deriving the models from
   `BaseEstimator <https://scikit-learn.org/stable/modules/generated/sklearn.base.BaseEstimator.html>`__.
   and appropriate ``MixIns``. *datafold* defines own ``MixIns`` that align with the
   API in a duck-typing fashion to allow identifying dynamical systems from temporal data
   in ``TSCDataFrame``.

* `SciPy <https://docs.scipy.org/doc/scipy/reference/index.html>`__
   The package is used for elementary numerical algorithms and data structures in
   conjunction with NumPy. This includes (sparse) linear least
   square regression, (sparse) eigenpairs solver and sparse matrices as
   optional data structure for kernel matrices.

How does it compare to other software?
======================================

*Note: This list covers only Python packages.*

* `scikit-learn <https://scikit-learn.org/stable/>`__
   provides algorithms and models along the entire machine learning pipeline, with a
   strong focus on static data (i.e. without temporal context). *datafold* integrates
   into scikit-learn' API and all data-driven models are subclasses of
   `BaseEstimator <https://scikit-learn.org/stable/modules/generated/sklearn.base.BaseEstimator.html>`__.
   An important contribution of *datafold* is the ``DiffusionMaps`` model as popular
   framework for manifold learning, which is not contained in scikit-learn's `set of
   algorithms <https://scikit-learn.org/stable/auto_examples/manifold/plot_compare_methods
   .html#sphx-glr-auto-examples-manifold-plot-compare-methods-py>`__.
   Furthermore, *datafold* includes dynamical systems as a new model class that is
   operable with scikit-learn - the attributes align to supervised learning tasks.
   The key differences are that a model processes data of type ``TSCDataFrame``
   and instead of a one-to-one relation in the model's input/output, the model can return
   arbitrary many output samples (a time series) for a single input
   (an initial condition).

* `PyDMD <https://github.com/PyDMD/PyDMD>`__
   provides many variants of the `Dynamic Mode Decomposition (DMD)
   <https://en.wikipedia.org/wiki/Dynamic_mode_decomposition>`__. *datafold* provides a wrapper
   to make models of ``PyDMD`` accessible. However, a limitation of ``PyDMD`` is that it only
   processes single coherent time series, see `PyDMD issue 86
   <https://github.com/PyDMD/PyDMD/issues/86>`__. The DMD models that are directly included
   in *datafold* utilize the functionality of the data structure ``TSCDataFrame`` and can
   therefore process time series collections - in an extreme case only containing snapshot
   pairs.

* `PySINDy <https://pysindy.readthedocs.io/en/latest/>`__
   specializes on a *sparse* system identification of nonlinear dynamical systems to
   infer governing equations.

            

Raw data

            {
    "_id": null,
    "home_page": "https://datafold-dev.gitlab.io/datafold",
    "name": "datafold",
    "maintainer": "",
    "docs_url": null,
    "requires_python": ">=3.9",
    "maintainer_email": "",
    "keywords": "mathematics, machine learning, dynamical system, data-driven, time series, regression, forecasting, manifold learning, diffusion map, koopman operator, nonlinear",
    "author": "datafold development team",
    "author_email": "d.lehmberg@tum.de",
    "download_url": "https://files.pythonhosted.org/packages/ad/4a/1ace0f489ac55ba1c338b522237a30e327500704555e284fc23efe40d0ed/datafold-2.0.0.tar.gz",
    "platform": null,
    "description": "Quick links\n^^^^^^^^^^^\n\n`Source repository <https://gitlab.com/datafold-dev/datafold>`__ |\n`Contributing and feedback <https://datafold-dev.gitlab.io/datafold/contributing.html>`__ |\n`PyPI <https://pypi.org/project/datafold/>`__ |\n`Documentation <https://datafold-dev.gitlab.io/datafold/>`__ |\n`Tutorials <https://datafold-dev.gitlab.io/datafold/tutorial_index.html>`__ |\n`Scientific literature <https://datafold-dev.gitlab.io/datafold/references.html>`__\n\nWhat is *datafold*?\n====================\n\n*datafold* is a `MIT-licensed <https://gitlab.com/datafold-dev/datafold/-/blob/master/LICENSE>`__\nPython package containing operator-theoretic, data-driven models to identify dynamical\nsystems from time series data and to infer geometrical structures in point clouds.\n\nThe package includes:\n\n* An efficient implementation of the ``DiffusionMaps`` model to infer geometric\n  meaningful structures from data, such as the eigenfunctions of the\n  Laplace-Beltrami operator. As a distinguishing factor to other implementations, the\n  model can handle a sparse kernel matrix and allows setting an arbitrary kernel,\n  including the standard Gaussian kernel,\n  `continuous k-nearest neighbor kernel <https://arxiv.org/abs/1606.02353>`__, or\n  `dynamics-adapted cone kernel <https://cims.nyu.edu/~dimitris/files/Giannakis15_cone_kernels.pdf>`__.\n* Implementations and variants of the Dynamic Mode Decomposition as data-driven methods to\n  identify and analyze dynamical systems from time series collection data. This incldues:\n  * ``DMDFull`` or ``DMDEco`` as standard methods of DMD\n  * ``OnlineDMD`` or ``StreamingDMD`` modify the DMD to handle streaming data\n  * ``DMDControl`` augments the DMD to handle additional control input\n  * ``EDMD`` - The Extended-DMD, which allows setting up a highly flexible dictionary to\n  transform time series data and thereby handle nonlinear dynamics within the Koopman\n  operator framework. The EDMD wraps an arbitrary DMD variation for the decomposition.\n  The key advantage of this is, that the ``EDMD`` directly profits from the above\n  functionalities. ``EDMD`` can be used in control or streaming settings. Furthermore it is\n  possible to learn the dictionary directly from data (commonly referred to EDMD-DL)\n* Handling of cross-validation. The method ``EDMDCV``, for example, allows model parameters to\n  be optimized with cross-validation splittings that account for the temporal order in time\n  series data.\n* Methods to perform Model Predictive Control (MPC) with Koopman operator-based methods (\n  mainly the ``EDMD``). *This is currently still under development and experimental*.\n* Regression models for high-dimensional data (often used for out-of-sample extensions for the\n  Diffusion Maps model), such as the (auto-tuned) Laplacian Pyramids or Geometric Harmonics to\n  interpolate general function values on a point cloud manifold.\n* A data structure ``TSCDataFrame`` to handle time series collection data. It simplifies model\n  inputs/outputs and make it easier to describe various forms of time series data.\n\nSee also `this introduction page <https://datafold-dev.gitlab.io/datafold/intro.html>`__.\nFor a mathematical thorough introduction, we refer to the `scientific literature\n<https://datafold-dev.gitlab.io/datafold/references.html>`__.\n\n.. note::\n    The project is under active development in a research-driven environment.\n\n    * Code quality varies from \"experimental/early stage\" to \"well-tested\". Well tested\n      code is listed in the\n      `software documentation <https://datafold-dev.gitlab.io/datafold/api.html>`__\n      and are directly accessible through the highest module level (e.g.\n      :code:`from datafold import ...`). Experimental code is\n      only accessible via \"deep imports\" (e.g.\n      :code:`from datafol.dynfold.outofsample import ...`) and may raise a warning when using\n      it.\n    * The interfaces within *datafold* are not stable. The software is **not** intended for\n      production. Nevertheless, if we break something it is intentional and we hope that such\n      adaptations become less over time.\n    * There is no deprecation cycle. The software uses\n      `semantic versioning <https://semver.org/>`__ policy `[major].[minor].[patch]`, i.e.\n\n         * `major` - making incompatible changes in the (documented) API\n         * `minor` - adding functionality in a backwards-compatible manner\n         * `patch` - backwards-compatible bug fixes\n\n      We do not intend to indicate a feature complete milestone with version `1.0`.\n\nCite\n====\n\nIf you use *datafold* in your research, please cite\n`this paper <https://joss.theoj.org/papers/10.21105/joss.02283>`__ published in the\n*Journal of Open Source Software* (`JOSS <https://joss.theoj.org/>`__).\n\n*Lehmberg et al., (2020). datafold: data-driven models for point clouds and time series on\nmanifolds. Journal of Open Source Software, 5(51), 2283,* https://doi.org/10.21105/joss.02283\n\nBibTeX:\n\n.. code-block:: latex\n\n    @article{Lehmberg2020,\n             doi       = {10.21105/joss.02283},\n             url       = {https://doi.org/10.21105/joss.02283},\n             year      = {2020},\n             publisher = {The Open Journal},\n             volume    = {5},\n             number    = {51},\n             pages     = {2283},\n             author    = {Daniel Lehmberg and Felix Dietrich and Gerta K{\\\"o}ster and Hans-Joachim Bungartz},\n             title     = {datafold: data-driven models for point clouds and time series on manifolds},\n             journal   = {Journal of Open Source Software}}\n\nHow to get it?\n==============\n\nInstallation requires `Python>=3.9 <https://www.python.org/>`__ with\n`pip <https://pip.pypa.io/en/stable/>`__ and\n`setuptools <https://setuptools.pypa.io/en/latest/>`__ installed (both packages ship with a\nstandard Python installation). The package dependencies\ninstall automatically. The main dependencies and their usage in *datafold* are listed\nin the section \"Dependencies\" below.\n\nThere are two ways to install *datafold*:\n\n1. From PyPI\n------------\n\nThis is the standard way for users. The package is hosted on the official Python package\nindex (PyPI) and installs the core package (excluding tutorials and tests). The tutorial\nfiles can be downloaded separately\n`here <https://datafold-dev.gitlab.io/datafold/tutorial_index.html>`__.\n\nTo install the package and its dependencies with :code:`pip`, run\n\n.. code-block:: bash\n\n   python -m pip install datafold\n\n.. note::\n\n    If you run Python in an Anaconda environment you can use pip from within ``conda``.\n    See also\n    `official instructions <https://docs.conda.io/projects/conda/en/latest/user-guide/tasks/manage-pkgs.html#installing-non-conda-packages>`__.\n\n    .. code-block:: bash\n\n        conda activate venv\n        conda install pip\n        pip install datafold\n\n2. From source\n--------------\n\nThis way is recommended if you want to access the latest (but potentially unstable)\ndevelopment state, run tests or wish to contribute (see section \"Contributing\" for details).\nDownload or git-clone the source code repository.\n\n1. Download the repository\n\n   a. If you wish to contribute code, it is required to have\n      `git <https://git-scm.com/>`__ installed. Clone the repository with\n\n      .. code-block:: bash\n\n        git clone https://gitlab.com/datafold-dev/datafold.git\n\n   b. If you only want access to the source code (current ``master`` branch), download one\n      of the compressed file types\n      (`zip <https://gitlab.com/datafold-dev/datafold/-/archive/master/datafold-master.zip>`__,\n      `tar.gz <https://gitlab.com/datafold-dev/datafold/-/archive/master/datafold-master.tar.gz>`__,\n      `tar.bz2 <https://gitlab.com/datafold-dev/datafold/-/archive/master/datafold-master.tar.bz2>`__,\n      `tar <https://gitlab.com/datafold-dev/datafold/-/archive/master/datafold-master.tar>`__)\n\n2. Install the package from the downloaded repository\n\n   .. code-block:: bash\n\n       python -m pip install .\n\nContributing\n============\n\nAny contribution (code/tutorials/documentation improvements), question or feedback is\nvery welcome. Either use the\n`issue tracker <https://gitlab.com/datafold-dev/datafold/-/issues>`__ or\n`Email <incoming+datafold-dev-datafold-14878376-issue-@incoming.gitlab.com>`__ us.\nInstructions to set up *datafold* for development can be found\n`here <https://datafold-dev.gitlab.io/datafold/contributing.html>`__.\n\nDependencies\n============\n\nThe dependencies of the core package are managed in the file\n`requirements.txt <https://gitlab.com/datafold-dev/datafold/-/blob/master/requirements.txt>`__\nand install with *datafold*. The tests, tutorials, documentation and code analysis\nrequire additional dependencies which are managed in\n`requirements-dev.txt <https://gitlab.com/datafold-dev/datafold/-/blob/master/requirements-dev.txt>`__.\n\n*datafold* integrates with common packages from the\n`Python scientific computing stack <https://scipy.org/about/>`__:\n\n* `NumPy <https://numpy.org/>`__\n   NumPy is used throughout *datafold* and is the default package for numerical\n   data and algorithms.\n\n* `pandas <https://pandas.pydata.org/pandas-docs/stable/index.html>`__\n   *datafold* uses pandas'\n   `DataFrame <https://pandas.pydata.org/pandas-docs/stable/reference/api/pandas.DataFrame.html>`__\n   as a base class for ``TSCDataFrame`` to capture various forms of time series data. The data\n   It includes specific time series collection functionality and is mostly compatible with\n   pandas' rich functionality.\n\n* `scikit-learn <https://scikit-learn.org/stable/>`__\n   All *datafold* algorithms that are part of the \"machine learning pipeline\" align\n   to the scikit-learn `API <https://scikit-learn.org/stable/developers/develop.html>`__.\n   This is done by deriving the models from\n   `BaseEstimator <https://scikit-learn.org/stable/modules/generated/sklearn.base.BaseEstimator.html>`__.\n   and appropriate ``MixIns``. *datafold* defines own ``MixIns`` that align with the\n   API in a duck-typing fashion to allow identifying dynamical systems from temporal data\n   in ``TSCDataFrame``.\n\n* `SciPy <https://docs.scipy.org/doc/scipy/reference/index.html>`__\n   The package is used for elementary numerical algorithms and data structures in\n   conjunction with NumPy. This includes (sparse) linear least\n   square regression, (sparse) eigenpairs solver and sparse matrices as\n   optional data structure for kernel matrices.\n\nHow does it compare to other software?\n======================================\n\n*Note: This list covers only Python packages.*\n\n* `scikit-learn <https://scikit-learn.org/stable/>`__\n   provides algorithms and models along the entire machine learning pipeline, with a\n   strong focus on static data (i.e. without temporal context). *datafold* integrates\n   into scikit-learn' API and all data-driven models are subclasses of\n   `BaseEstimator <https://scikit-learn.org/stable/modules/generated/sklearn.base.BaseEstimator.html>`__.\n   An important contribution of *datafold* is the ``DiffusionMaps`` model as popular\n   framework for manifold learning, which is not contained in scikit-learn's `set of\n   algorithms <https://scikit-learn.org/stable/auto_examples/manifold/plot_compare_methods\n   .html#sphx-glr-auto-examples-manifold-plot-compare-methods-py>`__.\n   Furthermore, *datafold* includes dynamical systems as a new model class that is\n   operable with scikit-learn - the attributes align to supervised learning tasks.\n   The key differences are that a model processes data of type ``TSCDataFrame``\n   and instead of a one-to-one relation in the model's input/output, the model can return\n   arbitrary many output samples (a time series) for a single input\n   (an initial condition).\n\n* `PyDMD <https://github.com/PyDMD/PyDMD>`__\n   provides many variants of the `Dynamic Mode Decomposition (DMD)\n   <https://en.wikipedia.org/wiki/Dynamic_mode_decomposition>`__. *datafold* provides a wrapper\n   to make models of ``PyDMD`` accessible. However, a limitation of ``PyDMD`` is that it only\n   processes single coherent time series, see `PyDMD issue 86\n   <https://github.com/PyDMD/PyDMD/issues/86>`__. The DMD models that are directly included\n   in *datafold* utilize the functionality of the data structure ``TSCDataFrame`` and can\n   therefore process time series collections - in an extreme case only containing snapshot\n   pairs.\n\n* `PySINDy <https://pysindy.readthedocs.io/en/latest/>`__\n   specializes on a *sparse* system identification of nonlinear dynamical systems to\n   infer governing equations.\n",
    "bugtrack_url": null,
    "license": "MIT",
    "summary": "Operator-theoretic models to identify dynamical systems and parametrize point cloud geometry",
    "version": "2.0.0",
    "project_urls": {
        "Download": "https://pypi.org/project/datafold/",
        "Homepage": "https://datafold-dev.gitlab.io/datafold"
    },
    "split_keywords": [
        "mathematics",
        " machine learning",
        " dynamical system",
        " data-driven",
        " time series",
        " regression",
        " forecasting",
        " manifold learning",
        " diffusion map",
        " koopman operator",
        " nonlinear"
    ],
    "urls": [
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "30c4aae44a94e1126da6fea2f75a671403f9a2e161c4c3b719551970c5ae9fbf",
                "md5": "6a9817877e327fbbb863882e15461268",
                "sha256": "51156d840b3af3cf551ee474d504a11c1dfea421d2581cfce170f53c4dc3c339"
            },
            "downloads": -1,
            "filename": "datafold-2.0.0-py3-none-any.whl",
            "has_sig": false,
            "md5_digest": "6a9817877e327fbbb863882e15461268",
            "packagetype": "bdist_wheel",
            "python_version": "py3",
            "requires_python": ">=3.9",
            "size": 312374,
            "upload_time": "2023-07-31T21:06:15",
            "upload_time_iso_8601": "2023-07-31T21:06:15.060747Z",
            "url": "https://files.pythonhosted.org/packages/30/c4/aae44a94e1126da6fea2f75a671403f9a2e161c4c3b719551970c5ae9fbf/datafold-2.0.0-py3-none-any.whl",
            "yanked": false,
            "yanked_reason": null
        },
        {
            "comment_text": "",
            "digests": {
                "blake2b_256": "ad4a1ace0f489ac55ba1c338b522237a30e327500704555e284fc23efe40d0ed",
                "md5": "7bf97ce6a71bb4e38ae8356eccde82cd",
                "sha256": "4c538393efda88956f2802a5187adac9e083f62ad6bae9cfa9b5e51e549be59b"
            },
            "downloads": -1,
            "filename": "datafold-2.0.0.tar.gz",
            "has_sig": false,
            "md5_digest": "7bf97ce6a71bb4e38ae8356eccde82cd",
            "packagetype": "sdist",
            "python_version": "source",
            "requires_python": ">=3.9",
            "size": 291967,
            "upload_time": "2023-07-31T21:06:17",
            "upload_time_iso_8601": "2023-07-31T21:06:17.600546Z",
            "url": "https://files.pythonhosted.org/packages/ad/4a/1ace0f489ac55ba1c338b522237a30e327500704555e284fc23efe40d0ed/datafold-2.0.0.tar.gz",
            "yanked": false,
            "yanked_reason": null
        }
    ],
    "upload_time": "2023-07-31 21:06:17",
    "github": false,
    "gitlab": false,
    "bitbucket": false,
    "codeberg": false,
    "lcname": "datafold"
}
        
Elapsed time: 0.13424s