Fast Shannon entropy estimator using C++
Project description
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
Release history Release notifications | RSS feed
Download files
Download the file for your platform. If you're not sure which to choose, learn more about installing packages.
Source Distribution
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
| Algorithm | Hash digest | |
|---|---|---|
| SHA256 |
5accefb4722581f6eee7330739e25bedb4f549a684542c89e828e3c9c6a9055f
|
|
| MD5 |
b64ab061ae38a199c44c42023902299b
|
|
| BLAKE2b-256 |
26b66d119a9790b8db81b66b9e452e97764e5fe9c75c4cad3e0ffad211c06f25
|