حساب کاربری
​
زمان تقریبی مطالعه: 6 دقیقه
لینک کوتاه

الگوریتم فورچون

الگوریتم فورچون یک الگوریتم خط جارویی برای ساختن نمودار ورونی از یک دسته نقطه در صفحه با استفاده از زمان O ( n l o g n )

و حافظۀ O ( n )
است. این الگوریتم اولین بار توسط استیون فورچون در سال ۱۹۸۶ در مقالۀ "یک الگوریتم خط جارویی برای نمودارهای ورونی" چاپ شد.

پویانمایی الگوریتم فورچون

فهرست

  • ۱ توضیح الگوریتم
    • ۱.۱ شبه‌کد
  • ۲ بخش‌ها و دیسک‌های وزن‌دار
  • ۳ منابع
  • ۴ پیوند به بیرون

توضیح الگوریتم

این الگوریتم هم از خط جارویی و هم از خط ساحلی استفاده می‌کند که هردوی این خطوط در حین پیشرفت الگوریتم روی صفحه حرکت می‌کنند. خط جارویی خط مستقیمی است که ما به صورت توافقی می‌توانیم فرض کنیم که یک خط عمودی است و از چپ به راست صفحه حرکت می‌کند. در هر لحظه در طی الگوریتم نقاط ورودی سمت چپ خط جارویی با نمودار ورونی یکپارچه خواهند شد درحالی که نقاط سمت راست خط هنوز در نظر گرفته نشده‌اند. خط ساحلی یک خط نیست، بلکه یک منحنی مرکب در سمت چپ خط جارویی است که از تکه‌های سهمیها تشکیل شده است؛ این خط صفحه را به گونه‌ای تقسیم می‌کند که در آن نمودار ورونی، بدون توجه به وجود نقاط ممکن در سمت راست خط جارویی، از بقیۀ صفحه قابل تشخیص است. برای هر نقطه در سمت چپ خط جارویی، میتوان یک سهمی از نقاط هم‌فاصله از آن نقطه و خط جارویی تعریف کرد. خط ساحلی مرز مجموعۀ این سهمی‌ها است. هر چه خط جارویی پیشروی می‌کند رئوس خط ساحلی، که محل تلاقی دو سهمی است، یال‌های نمودار ورونی را رسم می‌کنند. خط ساحلی طوری پیشرفت می‌کند که رأس هر سهمی دقیقأ در وسط نقاط اولیۀ خط جارویی و جایگاه جدید خط جارویی قرار بگیرد.

این الگوریتم از داده ساختارها استفاده می‌کند: یک درخت جستجوی دودویی که ساختار ترکیبی خط ساحلی را توصیف می‌کند و یک صف اولویت‌دار که رخدادهای بالقوۀ بعدی را که می‌توانند ساختار خط ساحلی را تغییر دهند لیست می‌کند. این رخدادها شامل اضافه کردن یک سهمی دیگر به خط ساحلی هستند (وقتی که خط جارویی از نقطۀ ورودی دیگری عبور می‌کند) و برداشتن منحنی از خط ساحلی (وقتی که خط جارویی با یک دایرۀ عبورکننده از سه نقطه، که سهمی‌هایشان بخش‌های متوالی خط ساحلی را تشکیل می‌دهند، مماس می‌شود). هر رخداد می‌تواند توسط محور xهای خط جارویی در محل وقوع رخداد، اولویت‌بندی شود. الگوریتم از برداشتن مکرر رخداد بعدی از صف اولویت‌دار، یافتن تغییراتی که آن رخداد در خط ساحلی ایجاد می‌کند و بهنگام‌سازی داده ساختارها، تشکیل می‌شود. از آنجا که O ( n )

رخداد وجود دارند تا پردازش شوند (که هرکدام با برخی ویژگی‌های دیاگرام ورونی مرتبط هستند) و زمان O ( l o g n )
برای پردازش یک رخداد (که هرکدام شامل تعداد ثابتی از اعمال درخت جستجوی دودویی و صف اولویت‌دار هستند) زمان کلی الگوریتم O ( n l o g n )
است.

شبه‌کد

شبه‌کد توضیحات الگوریتم.

let 
  
    
      
        ∗
        (
        z
        )
      
    
    
  
be the transformation ∗ ( z ) = ( z x , z y + d ( z ) )
, where d ( z )
is the Euclidean distance between z
and the nearest site let T
be the "beach line" let R p
be the region covered by site p
. let C p q
be the boundary ray between sites p
and q
. let p 1 , p 2 , . . . , p m
be the sites with minimal y
-coordinate, ordered by x
-coordinate Q ← S − p 1 , p 2 , . . . , p m
create initial vertical boundary rays C p 1 , p 2 0 , C p 2 , p 3 0 , . . . C p m − 1 , p m 0
T ← ∗ ( R p 1 ) , C p 1 , p 2 0 , ∗ ( R p 2 ) , C p 2 , p 3 0 , . . . , ∗ ( R p m − 1 ) , C p m − 1 , p m 0 , ∗ ( R p m )
while not IsEmpty( Q
) do p
← DeleteMin( Q
) case p
of p
is a site in ∗ ( V )
: find the occurrence of a region ∗ ( R q )
in T
containing p
, bracketed by C r q
on the left and C q s
on the right create new boundary rays C p q −
and C p q +
with bases p
replace ∗ ( R q )
with ∗ ( R q ) , C p q − , ∗ ( R p ) , C p q + , ∗ ( R q )
in T
delete from Q
any intersection between C r q
and C q s
insert into Q
any intersection between C r q
and C p q −
insert into Q
any intersection between C p q +
and C q s
p
is a Voronoi vertex in ∗ ( V )
: let p
be the intersection of C q r
on the left and C r s
on the right let C u q
be the left neighbor of C q r
and let C s v
be the right neighbor of C r s
in T
create a new boundary ray C q s 0
if q y = s y
, or create C q s +
if p
is right of the higher of q
and s
, otherwise create C q s −
replace C q r , ∗ ( R r ) , C r s
with newly created C q s
in T
delete from Q
any intersection between C u q
and C q r
delete from Q
any intersection between C r s
and C s v
insert into Q
any intersection between C u q
and C q s
insert into Q
any intersection between C q s
and C s v
record p
as the summit of C q r
and C r s
and the base of C q s
output the boundary segments C q r
and C r s
endcase endwhile output the remaining boundary rays in T

بخش‌ها و دیسک‌های وزن‌دار

همان‌طور که فورچون در توضیح داده است، یک نوع الگوریتم توسعه‌یافتۀ خط جارویی می‌تواند برای ساخت نمودار ورونی وزن‌دارافزایشی استفاده شود، که در آن فاصلۀ هر بخش با وزن آن تعیین می‌شود؛ که این می‌تواند برابر با نمودار ورونی مجموعه‌ای از دیسک‌های هم‌مرکز بخش‌ها و به شعاع وزن آن‌ها باشد.

زمانی که از نمودار ورونی برای ساخت treemapها استفاده می‌شود، می‌توان از بخش‌های وزن‌دار برای کنترل مکان‌های سلولی ورونی استفاده کرد. در یک دیاگرام ورونی وزن‌دار افزایشی، نیم‌ساز بین بخش‌ها به‌طور عمومی یک هذلولی است در حالی که در نمودارهای ورونی غیروزن‌دار و نمودار پاور دیسک‌ها نیم‌ساز یک خط مستقیم است.

منابع

  1. ↑ Mark de Berg, Marc van Kreveld, Mark Overmars, and Otfried Schwarzkopf (2000), Computational Geometry (2nd revised ed.), Springer-Verlag, ISBN 3-540-65620-0 Section 7.2: Computing the Voronoi Diagram: pp.151–160.
  2. ↑ Austin, David, Voronoi Diagrams and a Day at the Beach, Feature Column, American Mathematical Society.
  3. ↑ Steven Fortune. A sweepline algorithm for Voronoi diagrams. Proceedings of the second annual symposium on Computational geometry. Yorktown Heights, New York, United States, pp.313–322. 1986. ISBN 0-89791-194-6. ACM Digital LibrarySpringerLink
  4. ↑ Kenny Wong, Hausi A. Müller, An Efficient Implementation of Fortune's Plane-Sweep Algorithm for Voronoi Diagrams.

پیوند به بیرون

  • Steven Fortune's C implementation
  • Fortune's Voronoi algorithm implemented in C++
  • Fortune's Voronoi algorithm implemented in C# بایگانی‌شده در ۱۰ ژانویه ۲۰۱۲ توسط Wayback Machine
  • Fortune's algorithm implemented in JavaScript
آخرین نظرات
کلیه حقوق این تارنما متعلق به فرا دانشنامه ویکی بین است.