Skip to main content

Nonlinear measures for dynamical systems (based on one-dimensional time series)

Project description

https://github.com/CSchoel/nolds/actions/workflows/ci.yaml/badge.svg https://zenodo.org/badge/DOI/10.5281/zenodo.3814723.svg https://api.codacy.com/project/badge/Grade/42c30d253b384e87a86b70c8fa0da6b2 https://codecov.io/gh/CSchoel/nolds/graph/badge.svg?token=Xgr82QKhFi

Nolds is a small numpy-based library that provides an implementation and a learning resource for nonlinear measures for dynamical systems based on one-dimensional time series.

Currently the following measures are implemented:

sample entropy (sampen)

Measures the complexity of a time-series, based on approximate entropy

correlation dimension (corr_dim)

A measure of the fractal dimension of a time series which is also related to complexity.

Lyapunov exponent (lyap_r, lyap_e)

Positive Lyapunov exponents indicate chaos and unpredictability. Nolds provides the algorithm of Rosenstein et al. (lyap_r) to estimate the largest Lyapunov exponent and the algorithm of Eckmann et al. (lyap_e) to estimate the whole spectrum of Lyapunov exponents.

Hurst exponent (hurst_rs)

The Hurst exponent is a measure of the “long-term memory” of a time series. It can be used to determine whether the time series is more, less, or equally likely to increase if it has increased in previous steps. This property makes the Hurst exponent especially interesting for the analysis of stock data.

detrended fluctuation analysis (DFA) (dfa)

DFA measures the Hurst parameter H, which is very similar to the Hurst exponent. The main difference is that DFA can be used for non-stationary processes (whose mean and/or variance change over time).

Generalized Hurst Exponent (mfhurst_b)

The Generalized Hurst Exponent (GHE, H_q or H(q)) can (as the name implies) be seen as a generalization of the Hurst exponent for data series with multifractal properties. It’s origins are however not directly related to Hurst’s rescaled range approach, but to the definition of self-affine functions.

Example

import nolds
import numpy as np

rwalk = np.cumsum(np.random.random(1000))
h = nolds.dfa(rwalk)

Requirements

Nolds supports Python 2 (>= 2.7) and 3 (>= 3.4) from one code source. It requires the package numpy.

These are the only hard requirements, but some functions will need other packages:

  • If you want to use the RANSAC algorithm for line fitting, you will also need the package sklearn.

  • For the true random numbers generated by nolds.qrandom you need the package quantumrandom.

  • The plotting functions in nolds.examples require the package matplotlib.

Installation

Nolds is available through PyPI and can be installed using pip:

pip install nolds

You can test your installation by running some sample code with:

python -m nolds.examples lyapunov-logistic

Alternatively, if you do not have matplotlib installed, you can run the unittests with:

python -m unittest nolds.test_measures

Documentation

Nolds is designed as a learning resource for the measures mentioned above. Therefore the corresponding functions feature extensive documentation that not only explains the interface but also the algorithm used and points the user to additional reference code and papers. The documentation can be found in the code, but it is also available as HTML-Version and on Read the Docs.

The relevant measures can be found in the file nolds/measures.py.

How to cite nolds

I am planning to publish nolds in a peer-reviewed journal, but as this is a side project of my PhD thesis this may take a while. For the time being you can use the following Zenodo reference:

Schölzel, Christopher. (2019, June 16). Nonlinear measures for dynamical systems (Version 0.5.2). Zenodo. http://doi.org/10.5281/zenodo.3814723

You can also export a BibTeX reference from Zenodo.

Contact information

If you have any questions, suggestions or corrections, you can find my contact information in my GitHub profile or on my blog.

Please note that this is one of my side projects. Depending on my current workload it may take days, weeks or even months until I can find the time to check on mails and issues for nolds.

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distributions

No source distribution files available for this release.See tutorial on generating distribution archives.

Built Distribution

nolds-0.6.1-py2.py3-none-any.whl (225.1 kB view details)

Uploaded Python 2 Python 3

File details

Details for the file nolds-0.6.1-py2.py3-none-any.whl.

File metadata

  • Download URL: nolds-0.6.1-py2.py3-none-any.whl
  • Upload date:
  • Size: 225.1 kB
  • Tags: Python 2, Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/5.1.1 CPython/3.12.5

File hashes

Hashes for nolds-0.6.1-py2.py3-none-any.whl
Algorithm Hash digest
SHA256 208714600333f03e428c968a0cea0e8029d75ac30b454e28e968630b14973829
MD5 0ce73d650cd2c59d5f2a52293be1fdf7
BLAKE2b-256 ec514748c375a59c195be43aef5645fb17b48572c857384bfbc363eaecfcdfe4

See more details on using hashes here.

Supported by

AWS AWS Cloud computing and Security Sponsor Datadog Datadog Monitoring Fastly Fastly CDN Google Google Download Analytics Microsoft Microsoft PSF Sponsor Pingdom Pingdom Monitoring Sentry Sentry Error logging StatusPage StatusPage Status page