الگوریتم گره‌های بالا

الگوریتم گره‌های بالا (به انگلیسی: top-nodes algorithm، معروف به Rayrole's Algorithm) الگوریتمی برای مدیریت تقویم رزرو منابع است. این الگوریتم برای اولین بار در سال ۲۰۰۳[۱] منتشر شد، و در سال ۲۰۰۹[۲] بهبود یافته‌است. این الگوریتم هنگامی استفاده می‌شود که یک منبع بین کاربران زیادی به اشتراک گذاشته شده‌است (برای مثال پهنای باند در یک لینک ارتباط از راه دور یا ظرفیت دیسک در یک مرکز دادهٔ گسترده). هنگامی که احتیاجات یک منبع برنامه‌ریزی شوند، مدیر شبکه می‌تواند رزروهای صورت گرفته از منبع را بر روی یک تقویم پیاده‌سازی کند تا در در دسترس بودن شبکه را در هر لحظه در دست داشته باشد. این الگوریتم به کاربران اجازه می‌دهد کارهای زیر را انجام دهند:

  • بررسی کنند که آیا مقدار مشخصی از یک منبع در یک بازهٔ زمانی معین موجود است یا نه،
  • مقداری از منبع را برای بازهٔ زمانی مشخصی رزرو کنند،
  • رزرو قبلی را حذف کنند،
  • تقویم را به جلو حرکت دهند (تقویم مدت زمان مشخصی را پوشش می‌دهد، و با گذشت زمان باید به جلو منتقل شود).

پیاده‌سازی ویرایش

تقویم به صورت یک درخت دودویی مرتب می‌شود که هر گره نشان دهندهٔ یک بازهٔ زمانی مشخص است. بازهٔ زمانی یک گره والد برابر اجتماع بازه‌های زمانی تمام فرزندانش است.

 

نمونه ای از تقویم ۷ ساعته (با دوره‌های زمانی اولیه یک ساعته)

مدت زمان تحت پوشش یک رزرو توسط مجموعه ای از "گره‌های بالاً نشان داده می‌شود. این مجموعه، دقیقاً دورهٔ زمانی رزرو شده را پوشش می‌دهد و تعداد اعضای آن کمترین مقدار ممکن است. (مجموعه مینیمال است) یک گره مشخص از درخت دودویی زمانی «گره بالا» یک رزرو است که:

  • همه فرزندان آن در بازه زمانی رزرو قرار بگیرند و
  • این گره باید ریشه باشد زیرا در غیر این صورت حداقل یکی از فرزندان گره والد خارج از بازه زمانی رزرو شده قرار خواهد گرفت.
 
گره‌های بالا برای رزروی از ساعت ۱ تا 5:59

مقدار زیر در هر گره ذخیره می‌شود:

q(node) = max(q(left child), q(right child)) + a

که در رابطه بالا a برابر تعداد نهایی منابع رزرو شده برای تمام رزروهایی است که این گره را به عنوان یک گره بالا دارند. (برای بهینه شدن کد، دو قسمت جمع بالا عموماً جداگانه ذخیره‌سازی می‌شوند)

الگوریتم Rayrole ویرایش

[۳]این الگوریتم که در سال ۲۰۱۲ برای بهبود نسخه‌های پیشینِ ارائه شده منتشر شد، زمان مورد نیاز برای اجرای عملیات ابتدایی بر روی تقویم منابع رزرو شده را بهینه کرده و به حداقل رسانده‌است. از جمله عملیات‌هایی که از لحاظ زمانی بهبود بخشیده شده‌اند عبارت اند از: عملیات‌های حذف کردن یک رزرو یا اضافه کردن یک رزرو به درخت، محاسبهٔ مقدار منابع دردسترس و جلو بردن تقویم با گذشت زمان. مرتبه زمانی این عملیات‌ها مستقل از تعداد رزروها، طول بازه زمانی آنها و دانه‌بندی آنهاست. به منظور رسیدن به این مرتبه‌های زمانی بهینه، مدل Rayrole پیشنهاد می‌کند که یک درخت رزرو پویا ساخته شود و همین‌طور گره‌های حاوی رزروهای دائمی مدیریت شوند. با استفاده از همین دو اصل، Rayrole توانسته‌است مرتبه زمانی عملیات‌های ابتدایی درخت را به   برساند. به منظور رسیدن به این الگوریتم، موضوع مطالعهٔ او روشی برای به اشتراک گذاری منبعی به اندازهٔ   بین کاربران متعدد در یک شبکه ارتباط از راه دور یا یک سیستم محاسبه‌گر با شروع از یک تاریخ مشخص است.

ساخت درخت در الگوریتم Rayrole ویرایش

درخت در این الگوریتم همچنان تعریف خود را حفظ کرده‌است (یعنی یک درخت دودویی است که هر گره آن نماینده یک بازه زمانی است) در این الگوریتم ادعاهای مختلفی به اثبات رسیده‌است که از جمله آنها داریم: ۱-به روزرسانی درخت:

این کار شامل چند مرحله است:

  • یکی ضبط یک دوره زمانی برای رزرو P که شامل مقدار   از منابع می‌باشد که این کار توسط یک کاربر صورت می‌گیرد
  • مرحله ای شامل اضافه کردن گره‌ها به درخت به صورتی که ریشهٔ درخت، تاریخ شروع بازهٔ P را دربر بگیرد و
  • در روش Rayrole، مرحله اضافه کردن گره به درخت، شامل اضافه کردن تمام گره‌های مینیمم بازه زمانی رزرو P نیز می‌شود.

گره مینیمم چیست؟ ویرایش

یک گره، زمانی گره مینیمم بازهٔ زمانی رزرو P است که:

  • اگر بازهٔ زمانی رزرو P یک دورهٔ غیر دائمی با تاریخ پایان مشخص باشد، گره مینیمم نشان دهنده یک بازهٔ زمانی است که زمان خود گره کاملاً درون بازه P قرار دارد اما زمان پدر گره به‌طور کامل در P قرار نمی‌گیرد. همچنین
  • اگر بازه زمانی رزرو P یک دوره دائمی بدون تاریخ پایان مشخص باشد، گره مینیمم نماینده یک بازه زمانی است که به‌طور کامل در بازهٔ F قرار می‌گیرد. (بازهٔ F بازه‌ای است که از زمان شروع بازه P شروع می‌شود و زمان پایان آن برابر با زمان پایانِ بازهٔ زمانیِ ریشه درخت است)

۲- ایده ای که بر مبنای ایدهٔ ارائه شده در «۱» بیان شده‌است:

در این ایده هر گره از درخت شامل موارد زیر است:

  : ابتدا رزروهایی را که در میان گره‌های مینیمم خود، گره مورد نظر ما را دارند پیدا می‌کنیم. سپس حاصل جمع مقدار منبع تمام این رزروها را با نام   به عنوان یکی از مشخصه‌های گره ذخیره می‌کنیم.

 : اگر گره انتخاب شده هیچ فرزندی نداشته باشد این مقدار را ۰ قرار می‌دهیم. در غیر این صورت، مقدار آن برابر ماکزیمم   در میان تمام فرزندان گره خواهد بود.

۳- ایده ای که بر مبنای ایده «۲» بیان شده‌است:

این ایده، ایده ای است که بیشتر شامل یکی از مراحل محاسبه مقدار   از منابع موجود در طول رزرو دوره P است، به این صورت که برای محاسبه آن داریم: اگر تاریخ شروع دوره P بعد از پایان یافتن دوره زمانی ای باشد که توسط ریشهٔ درخت نمایش داده می‌شود، داریم:

 

حال   و   را تعریف می‌کنیم:

  : متغیری است که برابر مجموع مقادیر منابعی است که برای رزروهای دائمی ذخیره شده‌اند و ریشه درخت را به عنوان گره مینیمم در خود دارند.

  : با حفظ شرایط   تعریف می‌شود با این تفاوت که ریشه درخت اصلی جزو گره‌های مینیمم نمی‌باشد. در این صورت رابطه به شکل زیر تبدیل خواهد شد:

 

۴- این ایده بر مبنای ایدهٔ «۳» ارائه شده‌است:

در این ایده کمتر بودن مقدار   نسبت به مقدار   منجر به اضافه شدن تعدادی عملیات به مرحلهٔ اضافه کردن گره به درخت می‌شود:

اگر به گره موجود، گره فرزندی اضافه شود، مقدار   و   گره اضافه شده برابر صفر قرار گیرد.

درغیر این صورت، اگر گرهی اضافه شود و ریشه جدید باشد آنگاه:

اگر ریشهٔ قبلی چپ‌ترین فرزند ریشه جدید باشد: مقدار   گره جدید را برابر مقدار   قرار داده و از مقدار   ریشهٔ قبلی، مقدار   را می‌کاهیم.

اگر ریشهٔ قبلی شرایط حالت قبل را نداشته باشد: مقدار   ریشهٔ جدید را برابر صفر، مقدار   را به اندازه   افزایش داده، مقدار   را برابر ۰ و مجموع مقادیر   و   ریشه قدیمی را به عنوان   ریشه جدید قرار می‌دهیم.

مرحلهٔ بعدی اضافه کردن گره‌های برادر سمت راست ریشهٔ قدیمی می‌باشد، با این تغییرات که مقدار   در تمامی این گره‌های ذکر شده برابر مقدار   قرار گیرد و مقدار   همین گره‌ها صفر در نظر گرفته شود.

اگر دوره P یک دوره دائمی بدون تاریخ پایان باشد: اگر ریشه درخت یک گره مینیمم باشد، مقدار   به اندازه   افزایش داده شود، و در غیر این صورت مقدار   به اندازه   افزایش داده شود.

مقدار   به مولفه   همهٔ گره‌های مینیمم دوره P اضافه شود و مقدار   همهٔ گره‌های والد این گره‌های مینیمم به روز رسانی شود.

کارایی ویرایش

مزیت این الگوریتم این است که زمان ثبت یک رزرو منبع جدید فقط به اندازه تقویم بستگی دارد (و بستگی به تعداد رزروها ندارد). فرض می‌کنیم "n" تعداد دوره‌های اولیه تقویم باشد. حداکثر تعداد "گره‌های بالاً برای رزروی مشخص شده برابر   است.

برخی پرسش‌ها و مرتبه زمانی آنها ویرایش

  • برای بررسی اینکه آیا در طی یک دوره زمانی مشخص مقدار معلومی از منبع موجود است یا خیر :  
  • ذخیره مقدار مشخصی از یک منبع برای بازهٔ زمانی خاص :  
  • برای حذف رزرو قبلی :  
  • برای حرکت تقویم به جلو :  

که در مرتبه زمانی بالا M برابر تعداد رزروهایی است که در طول دوره‌های زمانی تقویم موجود فعال هستند. (اگر رزرو منبع پس از پایان یافتن تقویم ممکن نباشد مقدار M برابر ۰ خواهد بود)

منابع ویرایش

  1. Related US Patent, (the algorithm is in the public domain since 2008)
  2. Improved top-nodes Algorithm
  3. Rayrole,US Patent Application Publication,2012