# hilbert-bytes **Repository Path**: mirrors_erikbrinkman/hilbert-bytes ## Basic Information - **Project Name**: hilbert-bytes - **Description**: A python library for converting between d-dimensional points and indices on a hilbert curve - **Primary Language**: Unknown - **License**: MIT - **Default Branch**: main - **Homepage**: None - **GVP Project**: No ## Statistics - **Stars**: 0 - **Forks**: 0 - **Created**: 2025-02-16 - **Last Updated**: 2025-10-18 ## Categories & Tags **Categories**: Uncategorized **Tags**: None ## README # Hilbert Bytes [![build](https://github.com/erikbrinkman/hilbert-bytes/actions/workflows/python-package.yml/badge.svg)](https://github.com/erikbrinkman/hilbert-bytes/actions/workflows/python-package.yml) [![pypi](https://img.shields.io/pypi/v/hilbert-bytes)](https://pypi.org/project/hilbert-bytes/) [![docs](https://img.shields.io/badge/api-docs-blue)](https://erikbrinkman.github.io/hilbert-bytes) Hilbert Bytes is a python library for converting to and from points in d-dimensions and their corresponding index on a hilbert curve. It's similar to [hilbertcurve](https://pypi.org/project/hilbertcurve/) and [numpy-hilbert-curve](https://pypi.org/project/numpy-hilbert-curve/) but is faster and more space efficient than either by keeping manipulations at the byte level, and using numba to compile the results. It also uses arbitrary precision integers, allowing you to make the grid arbitrarily fine ## Installation ```sh pip install hilbert-bytes ``` ## Usage ```py import hilbert_bytes import numpy as np points = ... # arbitrary d-dimensional points num, dim = points.shape # convert to big-endian bytes points_bytes = points[..., None].astype(">u8").view("u1") index_bytes = hilbert_bytes.encode(points_bytes) # indies as big-endian ints new_points_bytes = hilbert_bytes.decode(index_bytes) ``` If you want the indices as multi-byte ints, you can can do a similar trick in reverse: ```py index_bytes = ... # an array of big-endian ints indices = index_bytes.view(">u8").astype("u8")[..., 0] ``` But note that this will only work if your index fits in 8 bytes ## Publishing ```sh rm -rf dist uv build uv publish --username __token__ ```