Skip to main content

Fast Shannon entropy estimator using C++

Project description

PyPI version Downloads DOI

OUxInfo

OUxInfo is a high-performance Shannon entropy estimator for Python, powered by a C++ backend. It is designed for fast and scalable entropy estimation, particularly for causal inference.

Features

  • Fast Shannon entropy estimator (C++ backend)
  • Python interface via pybind11
  • Information-theoretic quantities for causal inference (e.g., transfer entropy, backward transfer entropy, information flow)

Installation

Requirements

  • Python >= 3.12 (3.13 recommended)
  • GCC >= 11 (>= 13 recommended)
  • OpenMP support (-fopenmp)

Install via pip

  • PyPI
$ pip install ouxinfo
  • Clone this repository and
$ pip install .

Dependencies

Python packages (installed automatically via pip)

  • pybind11
  • numpy
  • scipy
  • matplotlib
  • numba

C++ dependencies

  • Boost C++ Libraries (Boost Software License, included in this repository)
  • nanoflann (BSD License, included in this repository)

Usage (example)

import numpy as np
from ouxinfo import shannon_entropy

x = np.random.normal(0.e0, 1.e0, 10000)
H = shannon_entropy(x.reshape(-1,1), k=5)

Related Publication

This repository contains the implementation used in the following publication:

Jun Hatayama, Kento Tanaka, and Toshinori Kouchi. "Nonlinear causal relationship between separation bubbles and reflected shock wave in shock wave/turbulent boundary layer interaction based on information theory." Computers & Fluids (2026): 107016.

@article{hatayama2026nonlinear,
  title={Nonlinear causal relationship between separation bubbles and reflected shock wave in shock wave/turbulent boundary layer interaction based on information theory},
  author={Hatayama, Jun and Tanaka, Kento and Kouchi, Toshinori},
  journal={Computers \& Fluids},
  pages={107016},
  year={2026},
  publisher={Elsevier}
}

The repository was made publicly available after publication to improve reproducibility. However, this version may differ slightly from the version used in the paper.

License

This project is released under MIT license.

Third-party licenses

This project depends on the following libraries;

nanoflann (BSD License)

  • Copyright 2008-2009 Marius Muja (mariusm@cs.ubc.ca). All rights reserved.
  • Copyright 2008-2009 David G. Lowe (lowe@cs.ubc.ca). All rights reserved.
  • Copyright 2011-2025 Jose Luis Blanco (joseluisblancoc@gmail.com). Redistribution and use in source and binary forms are permitted under the BSD License.

Boost C++ Libraries (Boost Software License 1.0)

  • Copyright John Maddock 2006, 2007.
  • Copyright Paul A. Bristow 2006, 2007, 2009, 2010. Use, modification and distribution are subject to the Boost Software License, Version 1.0. (See accompanying file LICENSE_1_0.txt or copy at http://www.boost.org/LICENSE_1_0.txt)

Boost is now bundled in the third_party/ directory and is used automatically during build.

pybind11 (BSD License)

Used for Python bindings.

NumPy, SciPy, Matplotlib, Numba

These libraries are installed via pip and are subject to their respective licenses.

AI-Assisted Development

Development during 2025 was primarily conducted by the project owners.
Starting in 2026, the project expanded its contributor base and introduced AI-assisted "vibe coding" workflows using Claude Code.

To maintain transparency, we aim to clearly distinguish which parts of the codebase and development workflow involve AI-generated content or AI-assisted modifications. In addition, as part of our effort to share practical knowledge on AI-assisted development in the community, we provide Claude Code plan files under ./docs/plans.

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

ouxinfo-0.1.4.tar.gz (1.7 MB view details)

Uploaded Source

File details

Details for the file ouxinfo-0.1.4.tar.gz.

File metadata

  • Download URL: ouxinfo-0.1.4.tar.gz
  • Upload date:
  • Size: 1.7 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.2.0 CPython/3.13.13

File hashes

Hashes for ouxinfo-0.1.4.tar.gz
Algorithm Hash digest
SHA256 5accefb4722581f6eee7330739e25bedb4f549a684542c89e828e3c9c6a9055f
MD5 b64ab061ae38a199c44c42023902299b
BLAKE2b-256 26b66d119a9790b8db81b66b9e452e97764e5fe9c75c4cad3e0ffad211c06f25

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