Skip to main content

Robust polytope partitioning and efficient point classification in Python

Project description

PyPI PyPI Downloads Python License: MIT GitHub Repo

polypart-logo

PolyPart is a Python package for partitioning d-dimensional convex polytopes by affine hyperplane arrangements. The algorithm works by iteratively slicing the polytope with hyperplanes and organizing the resulting subdivisions into a decision tree, which enables:

  • Counting the exact number of regions
  • Efficient point classification into the corresponding region

All computations use exact rational arithmetic, which ensures robustness and eliminates floating-point errors. The implementation builds on pycddlib with GMP to provide efficient and reliable polyhedral computations.

🚀 Quick Start

Prerequisites

  • Python >= 3.10.6
  • numpy >= 1.24.4
  • pycddlib >= 3.0.2

Installation

  1. Install the package from PyPI
pip install polypart
  1. Import the package in your Python code
import polypart

Basic Usage

from fractions import Fraction
from polypart.geometry import Polytope, Hyperplane
from polypart.ppart import build_partition_tree
from polypart.io import save_tree

# 1. Create initial polytope object in H-representation
# unit square: 0 <= x <= 1, 0 <= y <= 1
A = [[-1, 0], [1, 0], [0, -1], [0, 1]]
b = [0, 1, 0, 1]
square = Polytope(A, b) # expressed as A x <= b
square.extreme()  # compute vertices (Optional)

h1 = Hyperplane.from_coefficients([1, 0, Fraction(1, 3)]) # x = 1/3
h2 = Hyperplane.from_coefficients([0, 1, Fraction(1, 3)]) # y = 1/3

tree, n_parts = build_partition_tree(square, [h1, h2])
save_tree(tree, "data/square_partitions.json")
print("Number of regions:", n_parts)

# Output: 'Number of regions: 4'

🎯 Examples

Complete Jupyter notebooks providing guided, reproducible demonstrations of how to use PolyPart are available in the examples folder:

  • Partitioning_Unit_Square.ipynb

    Demonstrates the algorithm on a simple, visual case: partitioning the unit square with three hyperplanes. Includes a plot of the resulting regions and new random points classified into their respective regions using the partition tree.

  • Moduli_Stability_Chambers.ipynb A higher-dimensional research application on moduli spaces of parabolic vector bundles.

📜 License

This project is licensed under the MIT License - see the LICENSE file for details.

👥 Authors

  • Sergio Herreros Pérez, Institute for Research in Technology, ICAI, Comillas Pontifical University
  • José Portela González, Department of Quantitative Methods, ICADE, Comillas Pontifical University and Institute for Research in Technology, IIT, Comillas Pontifical University
  • David Alfaya Sánchez, Department of Applied Mathematics and Institute for Research in Technology, ICAI, Comillas Pontifical University
  • Jaime Pizarroso Gonzalo, Department of Telematics and Computing and Institute for Research in Technology, ICAI, Comillas Pontifical University, and Santalucía Chair of Analytics for Education.

🙌 Acknowledgments

This research was supported by project CIAMOD (Applications of computational methods and artificial intelligence to the study of moduli spaces, project PP2023_9) funded by Convocatoria de Financiación de Proyectos de Investigación Propios 2023, Universidad Pontificia Comillas, and by grants PID2022-142024NB-I00 and RED2022-134463-T funded by MCIN/AEI/10.13039/501100011033.

Find more about the CIAMOD project in the project webpage and the IIT proyect webpage.

Special thanks to everyone who contributed to the project:

  • David Alfaya Sánchez (PI), Department of Applied Mathematics and Institute for Research in Technology, ICAI, Comillas Pontifical University
  • Javier Rodrigo Hitos, Department of Applied Mathematics, ICAI, Comillas Pontifical University
  • Luis Ángel Calvo Pascual, Department of Quantitative Methods, ICADE, Comillas Pontifical University
  • Anitha Srinivasan, Department of Quantitative Methods, ICADE, Comillas Pontifical University
  • José Portela González, Department of Quantitative Methods, ICADE, IIT, Comillas Pontifical University
  • Jaime Pizarroso Gonzalo, Department of Telematics and Computing and Institute for Research in Technology, ICAI, Comillas Pontifical University
  • Tomás Luis Gómez de Quiroga, Institute of Mathematical Sciences, UAM-UCM-UC3M-CSIC
  • Daniel Sánchez Sánchez, Student of the Degree in Mathematical Engineering and Artificial Intelligence, Institute for Research in Technology, ICAI, Comillas Pontifical University
  • Alejandro Martínez de Guinea García, Student of the Degree in Mathematical Engineering and Artificial Intelligence, Institute for Research in Technology, ICAI, Comillas Pontifical University
  • Sergio Herreros Pérez, Student of the Degree in Mathematical Engineering and Artificial Intelligence, Institute for Research in Technology, ICAI, Comillas Pontifical University

📚 References

  • David Alfaya, Sergio Herreros, Jaime Pizarroso, José Portela, and Javier Rodrigo, "A Computational Analysis of Ismorphism Classes of Moduli Spaces of Parabolic Vector Bundles", in preparation, 2025.
  • David Alfaya, Sergio Herreros, Jaime Pizarroso and José Portela, "PolyPart: Exact Partitioning of Convex Polytopes uisng Decision Trees", in preparation, 2025.

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

polypart-0.1.1.tar.gz (154.5 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

polypart-0.1.1-py3-none-any.whl (13.1 kB view details)

Uploaded Python 3

File details

Details for the file polypart-0.1.1.tar.gz.

File metadata

  • Download URL: polypart-0.1.1.tar.gz
  • Upload date:
  • Size: 154.5 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.17

File hashes

Hashes for polypart-0.1.1.tar.gz
Algorithm Hash digest
SHA256 7eafdae9982e256413cdfe03414a300a3c584c90631bb0fd4f359f397f26ae5c
MD5 0d20e070387a84b7efb7b87cc11bfcac
BLAKE2b-256 8aa2f8e1eea294059ae060ec5222c2e8c8eecc5bd8894303ded1f8de68f9ae3b

See more details on using hashes here.

File details

Details for the file polypart-0.1.1-py3-none-any.whl.

File metadata

  • Download URL: polypart-0.1.1-py3-none-any.whl
  • Upload date:
  • Size: 13.1 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: uv/0.8.17

File hashes

Hashes for polypart-0.1.1-py3-none-any.whl
Algorithm Hash digest
SHA256 1b2e71b3650f94c7b0dde0fe0a166e7c7bbeb403b91f423a326121e64061152d
MD5 5e9b104787c57682664ee1e094b8d45c
BLAKE2b-256 533e4284988cd6006db3cfd4f8bbec46fa5b0bd0cc047077b49dc329ffdfa49e

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