data:image/s3,"s3://crabby-images/ca364/ca36463f9b82c90b6f3e27c6326cdcdc31617e4c" alt=""
Fortune's algorithm
Encyclopedia
data:image/s3,"s3://crabby-images/950f2/950f2891e54a53f9c6a05b82adbc3fe12c84948d" alt=""
Sweep line algorithm
In computational geometry, a sweep line algorithm or plane sweep algorithm is a type of algorithm that uses a conceptual sweep line or sweep surface to solve various problems in Euclidean space...
for generating a Voronoi diagram
Voronoi diagram
In mathematics, a Voronoi diagram is a special kind of decomposition of a given space, e.g., a metric space, determined by distances to a specified family of objects in the space...
from a set of points in a plane using O
Big O notation
In mathematics, big O notation is used to describe the limiting behavior of a function when the argument tends towards a particular value or infinity, usually in terms of simpler functions. It is a member of a larger family of notations that is called Landau notation, Bachmann-Landau notation, or...
(n log n) time and O(n) space. It was originally published by Steven Fortune in 1986 in his paper "A sweepline algorithm for Voronoi diagrams."
Algorithm description
The algorithm maintains both a sweep line and a beach line, which both move through the plane as the algorithm progresses. The sweep line is a straight line, which we may by convention assume to be vertical and moving left to right across the plane. At any time during the algorithm, the input points left of the sweep line will have been incorporated into the Voronoi diagram, while the points right of the sweep line will not have been considered yet. The beach line is not a line, but a complex curve to the left of the sweep line, composed of pieces of parabolaParabola
In mathematics, the parabola is a conic section, the intersection of a right circular conical surface and a plane parallel to a generating straight line of that surface...
s; it divides the portion of the plane within which the Voronoi diagram can be known, regardless of what other points might be right of the sweep line, from the rest of the plane. For each point left of the sweep line, one can define a parabola of points equidistant from that point and from the sweep line; the beach line is the boundary of the union of these parabolas. As the sweep line progresses, the vertices of the beach line, at which two parabolas cross, trace out the edges of the Voronoi diagram.
The algorithm maintains as data structures a binary search tree
Binary search tree
In computer science, a binary search tree , which may sometimes also be called an ordered or sorted binary tree, is a node-based binary tree data structurewhich has the following properties:...
describing the combinatorial structure of the beach line, and a priority queue
Priority queue
A priority queue is an abstract data type in computer programming.It is exactly like a regular queue or stack data structure, but additionally, each element is associated with a "priority"....
listing potential future events that could change the beach line structure. These events include the addition of another parabola to the beach line (when the sweep line crosses another input point) and the removal of a curve from the beach line (when the sweep line becomes tangent to a circle through some three input points whose parabolas form consecutive segments of the beach line). Each such event may be prioritized by the x-coordinate of the sweep line at the point the event occurs. The algorithm itself then consists of repeatedly removing the next event from the priority queue, finding the changes the event causes in the beach line, and updating the data structures. As there are O(n) events to process (each being associated with some feature of the Voronoi diagram) and O(log n) time to process an event (each consisting of a constant number of binary search tree and priority queue operations) the total time is O(n log n).
Pseudocode
PseudocodePseudocode
In computer science and numerical computation, pseudocode is a compact and informal high-level description of the operating principle of a computer program or other algorithm. It uses the structural conventions of a programming language, but is intended for human reading rather than machine reading...
description of algorithm
Note: This pseudocode uses a horizontal sweepline and not vertical as in the above example.
let
data:image/s3,"s3://crabby-images/188c8/188c8bee04032e133ddb26d382da0785a22d444b" alt=""
data:image/s3,"s3://crabby-images/1d7ef/1d7efecc444f751dd91755816181aed328b4791a" alt=""
data:image/s3,"s3://crabby-images/7c6f1/7c6f18bea2cb093df0c5e5339aebcf58a17c0f8e" alt=""
data:image/s3,"s3://crabby-images/e6bbe/e6bbe6c2236da6974c9f5c60b9ea4d15f57d6958" alt=""
let T be the "beach line"
let
data:image/s3,"s3://crabby-images/aa60d/aa60dbe79bf00dede1cd2156177fbbe42bb5fdf9" alt=""
let
data:image/s3,"s3://crabby-images/08157/081573b0c020ba38b2dd147e133bdf650a836f6d" alt=""
data:image/s3,"s3://crabby-images/6adbd/6adbd3da3823cb824e0a51d6ccaad1dee868633a" alt=""
data:image/s3,"s3://crabby-images/e395f/e395f7f892ef08c6c1010fbf3113f0357a2c805e" alt=""
let
data:image/s3,"s3://crabby-images/52ff5/52ff50515b0ada8ef1e5fe1979c6ee8a38bfcd11" alt=""
data:image/s3,"s3://crabby-images/a48ec/a48ec44da9a0e7471a4415bd225697d640287a47" alt=""
data:image/s3,"s3://crabby-images/4e149/4e1498cc83354877e6f38058c2488a3e007f4d7c" alt=""
data:image/s3,"s3://crabby-images/0c55e/0c55e58bc29c0d0232095ad77fb68d9bfa8c7289" alt=""
create initial vertical boundary rays
data:image/s3,"s3://crabby-images/31cb2/31cb2eb00225b8aaa5043439853653215a05bc89" alt=""
data:image/s3,"s3://crabby-images/14d19/14d19ff04077d3f9b7edf502924f6980b887deb2" alt=""
while not IsEmpty(
data:image/s3,"s3://crabby-images/80246/802465a6b8f356641b4ce9eac99423b2d0b355f1" alt=""
data:image/s3,"s3://crabby-images/b6b5b/b6b5bde8020aa3e94bb9e08580ac1dd6e521fe45" alt=""
data:image/s3,"s3://crabby-images/10163/10163ef9a77b4eadb55069c0c996c953a7b2fd41" alt=""
case
data:image/s3,"s3://crabby-images/6bc41/6bc411faaf9d503ada9ba6792f26ee96934c0421" alt=""
data:image/s3,"s3://crabby-images/2e675/2e675cf17735e177c4c516baf2583b08d8f926cb" alt=""
data:image/s3,"s3://crabby-images/eb44e/eb44eb729c6a13da6d6e5dcca4fef251b05fd368" alt=""
find the occurrence of a region
data:image/s3,"s3://crabby-images/26ddd/26dddd3a619a8dc4634db0fd469670563e2895f0" alt=""
data:image/s3,"s3://crabby-images/65614/65614e757cbbc682da1c079a0bffd445cecf6948" alt=""
data:image/s3,"s3://crabby-images/e1d99/e1d996979708b7c1d5a6e84c00fe7ec462ebb534" alt=""
bracketed by
data:image/s3,"s3://crabby-images/d64f7/d64f7842b117f536feada4b0eb9b63e91861a953" alt=""
data:image/s3,"s3://crabby-images/c7ef6/c7ef6778914bd646d08a2a273c9c773d310d329b" alt=""
create new boundary rays
data:image/s3,"s3://crabby-images/a36fa/a36fa584fe881340606b12d1b33508c95646a4bb" alt=""
data:image/s3,"s3://crabby-images/b08f6/b08f6fa2d1eec2caa18b521759a139b55d56b82a" alt=""
data:image/s3,"s3://crabby-images/01c1b/01c1b0a145911a5ae69c4348bb84dea0cc2b4ad9" alt=""
replace
data:image/s3,"s3://crabby-images/9bf1d/9bf1df1f0a959d8cfca7e45df26432fcf51ce07a" alt=""
data:image/s3,"s3://crabby-images/30931/30931a123c23ae0b7ffb82473c31ea9b3230888c" alt=""
data:image/s3,"s3://crabby-images/14f3d/14f3d407630fc188277cf16e35668705dcb68d68" alt=""
delete from
data:image/s3,"s3://crabby-images/56624/56624a186fc94a0e31b8deabe2c42665b2f22b1d" alt=""
data:image/s3,"s3://crabby-images/41834/41834c2b1d5a5d546df2b9c19a249f178e475b74" alt=""
data:image/s3,"s3://crabby-images/478c9/478c9a418984e1cf744720889b60005dcbe41340" alt=""
insert into
data:image/s3,"s3://crabby-images/ce300/ce30022bcc8e68708245d7a9265bc802d94b721c" alt=""
data:image/s3,"s3://crabby-images/4f09d/4f09d8aebe471e97cf111e26ecac1e381be560ea" alt=""
data:image/s3,"s3://crabby-images/93f3e/93f3e3651a4e5e831a71594530565b6e2c57bee8" alt=""
insert into
data:image/s3,"s3://crabby-images/70b27/70b272e3a2be31cab03b2f5f1ed7ef8c75691f5b" alt=""
data:image/s3,"s3://crabby-images/2226f/2226f72c4eca73f8fe8c0956c9b36dec5eacb717" alt=""
data:image/s3,"s3://crabby-images/ed07a/ed07af793c1cd73ab039d0554da8a42fd3b54352" alt=""
data:image/s3,"s3://crabby-images/bf1c4/bf1c4e14947e6eb0ab48bdeec3c80ffe9c3ef6e6" alt=""
data:image/s3,"s3://crabby-images/840a8/840a8d8b68518ca6d83c0bcb5f5118e28a04e2a4" alt=""
let
data:image/s3,"s3://crabby-images/629a2/629a29cef6fcb2b63fa06913789d4bee0a0175be" alt=""
data:image/s3,"s3://crabby-images/fe532/fe5324af5a9574a4ca240ad57b7a76088277f3b8" alt=""
data:image/s3,"s3://crabby-images/5d97b/5d97b24434cdc53077bb2ab4de144343d24c690f" alt=""
let
data:image/s3,"s3://crabby-images/418a4/418a4f330495d839fcff86ef4c93f2d098a8565b" alt=""
data:image/s3,"s3://crabby-images/8cdde/8cddec4a0705e49f45e56aae7e7c07d1e32fc608" alt=""
let
data:image/s3,"s3://crabby-images/9a22a/9a22a460176727cd8257d68b80f27d35e43e435f" alt=""
data:image/s3,"s3://crabby-images/6269a/6269ad44f4c821f4f21b9539e2272342c6dc2e8a" alt=""
data:image/s3,"s3://crabby-images/7aaa4/7aaa43ca91a1129fad8c075e8e5c03b362828c8e" alt=""
create a new boundary ray
data:image/s3,"s3://crabby-images/30257/30257f81fbbd9c6bfa9e63f02a1b76135165e567" alt=""
data:image/s3,"s3://crabby-images/c44a2/c44a2f3640873a2ca65408055251c14129abf213" alt=""
or create
data:image/s3,"s3://crabby-images/4098c/4098c39a80592a8875bfeaa20956953afb8bb2cb" alt=""
data:image/s3,"s3://crabby-images/4f910/4f91095b1ba14fc09b3d1b5891eb93deee4168ac" alt=""
data:image/s3,"s3://crabby-images/0fa44/0fa44cd09e28a0fe1e59023d8bacf67b4bf826e1" alt=""
data:image/s3,"s3://crabby-images/aa441/aa4414f8074ae108d3e1e2dfe5e27a015917b9a3" alt=""
otherwise create
data:image/s3,"s3://crabby-images/008d8/008d8a703d89ae48e1112cede4b7e24f89d3fce2" alt=""
replace
data:image/s3,"s3://crabby-images/d8c8c/d8c8c5bb08e1e24a5afc461e74376650680a5790" alt=""
data:image/s3,"s3://crabby-images/19c3b/19c3ba91536abf71428d044ac44925566ab22be0" alt=""
data:image/s3,"s3://crabby-images/ae33d/ae33d1349fb19d73d1cd4c99021f91b2dcf4cea6" alt=""
delete from
data:image/s3,"s3://crabby-images/add63/add63d6bf0b7dd569ade93536840d5acc02be004" alt=""
data:image/s3,"s3://crabby-images/986a7/986a7f3ba02310de3a54618f676162de7028a312" alt=""
data:image/s3,"s3://crabby-images/b3d09/b3d090abeb884256bf9aa9766d475f48506bfa51" alt=""
delete from
data:image/s3,"s3://crabby-images/ecf60/ecf60f852953b0693ab81d57f991d7c59fdd1c91" alt=""
data:image/s3,"s3://crabby-images/e7a8d/e7a8d2c0db1bd2359f62579c6ac60f7af0390c52" alt=""
data:image/s3,"s3://crabby-images/87c06/87c0643c3bfd39fdd27f909b0b6e7a60c3b875f8" alt=""
insert into
data:image/s3,"s3://crabby-images/b32a4/b32a419e4907124da93d3ff1eabb50a22e720f30" alt=""
data:image/s3,"s3://crabby-images/c3ab4/c3ab42e0ba82d4b74e8d18cc605e4b578c152254" alt=""
data:image/s3,"s3://crabby-images/620f1/620f1f8cb0bac81a49f608b1771839be0462dddc" alt=""
insert into
data:image/s3,"s3://crabby-images/1dee5/1dee53f8490a54efba00680e18c26f83939af48d" alt=""
data:image/s3,"s3://crabby-images/c48bf/c48bffc1d56b9c25de880ff7f1143fff3b65a569" alt=""
data:image/s3,"s3://crabby-images/3ed9d/3ed9d593df7e6dedc323c229cfaf4c8fee7a6d3f" alt=""
record
data:image/s3,"s3://crabby-images/b0fc4/b0fc4873dfc153c41a9cdbf3c3525869d267ec4a" alt=""
data:image/s3,"s3://crabby-images/1b348/1b3480785a18429b4c103d560399104474201d96" alt=""
data:image/s3,"s3://crabby-images/14987/14987a3a323fc0470048432073de177ae330d265" alt=""
data:image/s3,"s3://crabby-images/487aa/487aa5e03c2a817a8f3d9321a3a1a4c4e1d716c8" alt=""
output the boundary segments
data:image/s3,"s3://crabby-images/4c06c/4c06c94479b63ecf4c9c39c63494dad29955329d" alt=""
data:image/s3,"s3://crabby-images/99785/997856ec0e70b496f062fe0f5e100cb0f03e242f" alt=""
endcase
endwhile
output the remaining boundary rays in
data:image/s3,"s3://crabby-images/e3679/e3679453b0e1abf5e2927e8dbdb4494b415ad754" alt=""
Weighted sites and disks
As Fortune describes in a modified version of the sweepline algorithm can be used to construct an additively weighted Voronoi diagram, in which the distance to each site is offset by the weight of the site; this may equivalently be viewed as a Voronoi diagram of a set of disks, centered at the sites with radius equal to the weight of the site.Weighted sites may be used to control the areas of the Voronoi cells when using Voronoi diagrams to construct treemaps. In an additively weighted Voronoi diagram, the bisector between sites is in general a hyperbola, in contrast to unweighted Voronoi diagrams and power diagrams of disks for which it is a straight line.