Fortuneův algoritmus je algoritmus pro generování Voronoiova diagramu ze sady bodů v rovině v čase O pomocí paměti O( n ) [1] [2] . Algoritmus původně publikoval Stephen Fortune v roce 1986 ve svém článku "The Sweeping Line Algorithm for Voronoi Diagrams" [3] .
Algoritmus udržuje plynulou přímku a pobřeží , které se při běhu algoritmu pohybují podél roviny. Zametací čára je čára, kterou si můžeme tradičně představit jako vertikální a pohybující se zleva doprava. V každém okamžiku činnosti algoritmu budou do Voronoiova diagramu zahrnuty body ze sady nalevo od rozmítací čáry, zatímco body napravo od rozmítací čáry ještě nebyly vypracovány. Pobřežní čára není přímka, ale je složitá, skládající se z kousků parabol , křivky po částech nalevo od křivky. Odděluje část roviny, v níž lze znát Voronoiův diagram, nezávisle na jiných bodech napravo od rozmítané čáry. Pro každý bod nalevo od křivky můžete definovat parabolu pro bod, který je stejně vzdálený jak od tohoto bodu, tak od křivky. Pobřeží je hranicí asociací těchto parabol. Jak se pohybuje rovný vrchol pobřeží, ve kterém se protínají dvě paraboly, kreslí se okraje Voronoiova diagramu. Pobřežní čára se posouvá a udržuje základnu každé paraboly přesně v polovině cesty mezi počáteční polohou čáry závory a novou polohou čáry závory. Matematicky to znamená, že každá parabola je vytvořena pomocí rozmítané přímky jako směrové přímky a daný bod z množiny slouží jako ohnisko.
Algoritmus udržuje binární stromovou datovou strukturu popisující kombinatorickou strukturu pobřeží a prioritní frontu se seznamem potenciálních budoucích událostí, které by mohly změnit strukturu pobřeží. Tyto události zahrnují přidání další paraboly k pobřeží (když křivka prochází jiným vstupním bodem) a vymazání křivky z pobřeží (když se čára tažení stane tečnou ke kruhu přes některé tři vstupní body, jejichž paraboly tvoří po sobě jdoucí segmenty pobřeží). Každá taková událost může být upřednostněna podle souřadnice x rozmítací čáry v bodě, kde k události došlo. Algoritmus sestává z postupného mazání události z prioritní fronty, hledání změn událostí na pobřeží a aktualizace datové struktury.
Protože existuje O( n ) událostí ke zpracování (každá je spojena s nějakou vlastností Voronoiova diagramu) a O(log n ) času na zpracování události (která sestává z konstantního počtu prohledávání binárního stromu a prioritních frontových operací), celkový čas je .
Jak zdůrazňuje Fortune [5] , upravenou verzi algoritmu rozmítané čáry lze použít ke konstrukci aditivně váženého Voronoiova diagramu, ve kterém je vzdálenost ke každému bodu neutralizována váhou bodu. To lze ekvivalentně zobrazit jako Voronoiův diagram sady disků se středem v bodech as poloměrem rovným váze bodu.
Vážené body lze použít k ovládání oblastí Voronoiových buněk, když se Voronoiovy grafy používají k vytváření stromových map . V aditivně váženém Voronoiově diagramu je osou mezi body obecně hyperbola, na rozdíl od nevážených Voronoiových diagramů a diagramů energie disku