Foronoi
An implementation of Fortune's algorithm for Voronoi diagrams in Python.
Install / Use
/learn @Yatoom/ForonoiREADME
Foronoi
Fortune's algorithm for Voronoi diagrams.

Foronoi is a Python implementation of the Fortune’s algorithm based on the description of “Computational Geometry: Algorithms and Applications” by de Berg et al.
This algorithm is a sweep line algorithm that scans top down over the cell points and traces out the lines via breakpoints in between parabola’s (arcs). When lines converge, a circle event happens which inserts a new vertex.
Documentation can be found here.
Pip Installation
pip install foronoi
Manual Installation
First, clone the repository and then install the package.
git clone https://github.com/Yatoom/foronoi.git
cd foronoi
python setup.py install
Note: you need to use sudo python3 setup.py install on most Linux distributions.
Example usage
Example that uses a polygon as a bounding box.
from foronoi import Voronoi, Polygon, Visualizer, VoronoiObserver
# Define some points (a.k.a sites or cell points)
points = [
(2.5, 2.5),
(4, 7.5),
(7.5, 2.5),
(6, 7.5),
(4, 4),
(3, 3),
(6, 3),
]
# Define a bounding box / polygon
polygon = Polygon([
(2.5, 10),
(5, 10),
(10, 5),
(10, 2.5),
(5, 0),
(2.5, 0),
(0, 2.5),
(0, 5),
])
# Initialize the algorithm
v = Voronoi(polygon)
# Attach a Voronoi Observer that monitors and visualizes the construction of
# the Voronoi Diagram step-by-step. See for more information
# examples/quickstart.py or examples/observers.py.
v.attach_observer(VoronoiObserver())
# Create the diagram
v.create_diagram(points=points)
# Get properties. See more examples in examples/quickstart.py
edges = v.edges
vertices = v.vertices
arcs = v.arcs
points = v.points
# Plotting
# Note: plot_border_to_site() indicates with dashed line to which site a border
# belongs. The site's first edge is colored green.
Visualizer(v, canvas_offset=1)\
.plot_sites(show_labels=True)\
.plot_edges(show_labels=False)\
.plot_vertices()\
.plot_border_to_site()\
.show()

Calculate the shell size for each point
for point in v.sites:
print(f"{point.xy} \t {point.area()}")
Output:
(2.5, 2.5) 11.529761904761905
(4, 7.5) 15.064062500000006
(7.5, 2.5) 11.75
(6, 7.5) 10.520833333333329
(4, 4) 7.640625
(3, 3) 5.946354166666666
(6, 3) 9.423363095238095
More examples can be found in the examples/ folder.
Get coordinates of the cell borders for a point
vertices = v.sites[0].get_vertices()
coords = [(vertex.x, vertex.y) for vertex in vertices]
print(coords)
Output:
[(0.167, 5.333), (4.5, 1.0), (4.643, 0.0), (2.5, 0), (0, 2.5), (0, 5)]
Testing
To run unit tests, run the following comand.
python3 -m "nose" foronoi/tests/unit.py
Related Skills
node-connect
346.4kDiagnose OpenClaw node connection and pairing failures for Android, iOS, and macOS companion apps
claude-opus-4-5-migration
107.2kMigrate prompts and code from Claude Sonnet 4.0, Sonnet 4.5, or Opus 4.1 to Opus 4.5
frontend-design
107.2kCreate distinctive, production-grade frontend interfaces with high design quality. Use this skill when the user asks to build web components, pages, or applications. Generates creative, polished code that avoids generic AI aesthetics.
model-usage
346.4kUse CodexBar CLI local cost usage to summarize per-model usage for Codex or Claude, including the current (most recent) model or a full model breakdown. Trigger when asked for model-level usage/cost data from codexbar, or when you need a scriptable per-model summary from codexbar cost JSON.
