Wolfram Function Repository
Instant-use add-on functions for the Wolfram Language
Function Repository Resource:
Compute shortest tours visiting all lattice points within each Voronoi cell in a region
| ResourceFunction["VoronoiCellTours"][pts, reg] computes shortest tours starting from each point in pts within each Voronoi cell of the Voronoi diagram from pts within the region reg. | 
Compute shortest tours starting at three random starting points within a rectangle:
| In[1]:= | ![SeedRandom[50];
pts = RandomInteger[{-8, 8}, {3, 2}];
reg = Rectangle[{-10, -10}, {10, 10}];
tours = ResourceFunction["VoronoiCellTours"][pts, reg];
ListLinePlot[tours, ImageSize -> Medium]](https://www.wolframcloud.com/obj/resourcesystem/images/ca5/ca535918-69d8-44ec-8b3e-1c44435c8d70/729181eb26b9ddb0.png) | 
| Out[5]= |  | 
Compute the shortest tour from a single point within a rectangle:
| In[6]:= | ![pts = {{0, 0}};
reg = Rectangle[{-10, -10}, {10, 10}];
tours = ResourceFunction["VoronoiCellTours"][pts, reg];
ListLinePlot[tours, ImageSize -> Medium]](https://www.wolframcloud.com/obj/resourcesystem/images/ca5/ca535918-69d8-44ec-8b3e-1c44435c8d70/7f779e477da0f349.png) | 
| Out[9]= |  | 
Compute shortest tours within Voronoi cells from five random points within a random convex polygon:
| In[10]:= | ![SeedRandom[50];
pts = RandomInteger[{-10, 10}, {5, 2}];
reg = RandomPolygon["Convex", DataRange -> {{-20, 20}, {-20, 20}}];
tours = ResourceFunction["VoronoiCellTours"][pts, reg];
ListLinePlot[tours, ImageSize -> Medium]](https://www.wolframcloud.com/obj/resourcesystem/images/ca5/ca535918-69d8-44ec-8b3e-1c44435c8d70/0ac8691604c42f05.png) | 
| Out[14]= |  | 
Use the resource function LloydAlgorithm with VoronoiCellTours for shortest tours within Voronoi cells of similar areas:
| In[15]:= | ![SeedRandom[50];
pts = RandomInteger[{-10, 10}, {5, 2}];
reg = RandomPolygon["Convex", DataRange -> {{-20, 20}, {-20, 20}}];
lloydPts = ResourceFunction["LloydAlgorithm"][pts, reg, 100];
tours = ResourceFunction["VoronoiCellTours"][lloydPts, reg];
ListLinePlot[tours, ImageSize -> Medium]](https://www.wolframcloud.com/obj/resourcesystem/images/ca5/ca535918-69d8-44ec-8b3e-1c44435c8d70/24a4289f404c0d01.png) | 
| Out[20]= |  | 
If a point does not lie within the region, a shortest tour is not computed within the point's Voronoi cell:
| In[21]:= | ![pts = {{0, 0}, {11, 11}};
reg = Rectangle[{-10, -10}, {10, 10}];
tours = ResourceFunction["VoronoiCellTours"][pts, reg];
ListLinePlot[tours, ImageSize -> Medium]](https://www.wolframcloud.com/obj/resourcesystem/images/ca5/ca535918-69d8-44ec-8b3e-1c44435c8d70/1a3c6a1bce33f8c9.png) | 
| Out[24]= |  | 
VoronoiCellTours is not able to correctly compute shortest tours for some concave regions:
| In[25]:= | ![SeedRandom[50];
pts = {{-5, 0}, {5, 0}, {0, -5}};
reg = RandomPolygon["Simple", DataRange -> {{-20, 20}, {-20, 20}}];
tours = ResourceFunction["VoronoiCellTours"][pts, reg];
Show[ListLinePlot[tours, AspectRatio -> 1], Graphics[{FaceForm[], EdgeForm[Black], reg}], PlotRange -> All, ImageSize -> Medium]](https://www.wolframcloud.com/obj/resourcesystem/images/ca5/ca535918-69d8-44ec-8b3e-1c44435c8d70/55960e2cf97cd6b9.png) | 
| Out[29]= |  | 
Compute shortest tours within Voronoi cells from eight random points within a convex polygon:
| In[30]:= | ![SeedRandom[50];
pts = RandomInteger[{-20, 20}, {8, 2}];
reg = RandomPolygon["Convex", DataRange -> {{-50, 50}, {-50, 50}}];
tours = ResourceFunction["VoronoiCellTours"][pts, reg];
Show[ListLinePlot[tours, AspectRatio -> 1], Graphics[{FaceForm[], EdgeForm[Black], reg}], PlotRange -> All, ImageSize -> Large]](https://www.wolframcloud.com/obj/resourcesystem/images/ca5/ca535918-69d8-44ec-8b3e-1c44435c8d70/31069bb26f4eb21b.png) | 
| Out[34]= |  | 
Compute shortest tours within Voronoi cells from 10 random points within a large disk region:
| In[35]:= | ![SeedRandom[50];
pts = RandomInteger[{-40, 40}, {10, 2}];
reg = Disk[{0, 0}, 50];
tours = ResourceFunction["VoronoiCellTours"][pts, reg];
Show[ListLinePlot[tours, AspectRatio -> 1], Graphics[{FaceForm[], EdgeForm[Black], reg}], PlotRange -> All, ImageSize -> Large]](https://www.wolframcloud.com/obj/resourcesystem/images/ca5/ca535918-69d8-44ec-8b3e-1c44435c8d70/6d0bf2f5b480ef5f.png) | 
| Out[39]= |  | 
This work is licensed under a Creative Commons Attribution 4.0 International License