Алгоритм вибору лідера

У розподілених обчисленнях, вибір лідера є процесом позначення одного процесу як організатора деякого завдання, розподіленого між декількома комп'ютерами (вузлами). Перш ніж розпочати завдання, всі вузли мережі або не знають, який вузол буде виконувати роль «лідера» (або координатора) завдання, або ці вузли не можуть спілкуватися з поточним координатором. Проте після запуску алгоритму вибору лідера кожен вузол у мережі визначає один особливий, унікальний вузол і сприймає його як лідера завдання.

Вузли мережі спілкуються між собою, щоб вирішити, який з них отримає статус «лідеру». Для цього вони використовують певний метод (алгоритм), щоб розірвати симетрію серед них (назначити одному з них особливий статус). Наприклад, якщо кожен вузол має унікальні та порівнянні ідентичності, то вузли можуть порівнювати свої ідентичності і вирішувати, що вузол з найвищою ідентичністю є лідером.

Формулювання цієї проблеми часто приписується ЛеЛану (англ. LeLann), який сформулював її як метод створення нового маркера в мережі маркерів кільця, в якому маркер був втрачений.

Алгоритми виборів лідерів розроблені так, щоб бути максимально ефективними з точки зору загальної кількості переданих байтів і часу прийняття рішення. Алгоритм, запропонований Галлагером, Хумблетом і Спірою[1] для загальних неорієнтованих графів, справив сильний вплив на розробку розподілених алгоритмів загалом, і отримав премію Дейкстри за значний внесок в розподілені обчислення.

Багато інших алгоритмів були запропоновані для різних типів мережевих графів, таких як неорієнтовані кільця, односпрямовані кільця, повні графи, сітки, напрямлені графи Ейлера та інші. Загальний метод, який відокремлює проблему з сімейства графів від проектування алгоритму виборів лідера, був запропонований Корахом, Куттеном[en] і Мораном[en].[2]

Визначення

Задача вибору лідера полягає в тому, щоб кожен процесор на кінець роботи алгоритму вирішив, чи є він лідером, чи ні, за умови, що тільки один процесор вирішує, що він є лідером.[3] Алгоритм здатен вирішити задачу вибору лідера, якщо:

  1. У процесорів є два стани відносно лідерства «обраний лідером» або «не обраний лідером». Після того, як процесор стає обраним він ним і залишається (аналогічним чином, якщо він не був обраним).
  2. При кожному виконанні алгоритму обирається тільки один процесор, як лідер, решта процесорів визначають, що вони не були обрані.

Дійсний алгоритм вибору лідера повинен відповідати наступним умовам:[4]

  1. Скінченність: алгоритм повинен закінчитися протягом обмеженого часу після вибору лідера. У підходах, що базуються на випадковості ця умова іноді заміняється певною іншою умовою (наприклад, вимагає припинення з ймовірністю 1).
  2. Унікальність: є лише один процесор, який вважає себе лідером.
  3. Узгодженість: всі інші процесори знають, хто є лідером.

Алгоритм вибору лідера може змінюватися в наступних аспектах:[5]

  • Механізм зв'язку: процесори можуть бути або синхронізовані (процесори синхронізуються тактовим сигналом), або асинхронними[en], де процесори мають різну тактову частоту.
  • Імена процесів: процеси можуть мати унікальну ідентичність або не відрізнятися один від одного (в такому випадку вони називаються анонімними).
  • Топологія мережі: наприклад, кільце, ациклічний граф або повний граф.
  • Розмір мережі: алгоритм може використовувати або може не використовувати знання про кількість процесорів у системі.

Алгоритми

Вибір лідера в кільцях

Топологія кільцевої мережі

Кільцева мережа являє собою топологію зв'язаного графа, в якій кожен вузол точно з'єднаний з двома іншими вузлами, тобто для графа з n вузлами є рівно n ребер, що з'єднують вузли. Кільце може бути односпрямованим, тобто процесори здійснюють зв'язок лише в одному напрямку (вузол може надсилати повідомлення лише ліворуч або надсилати повідомлення лише праворуч), або двонаправлений, тобто процесори можуть передавати та отримувати повідомлення в обох напрямках (кожен вузол може передавати та отримувати повідомлення в обох напрямках, надсилати повідомлення ліворуч і праворуч).

Анонімні кільця

Анонімним є те кільце в якому кожен процесор ідентичний. Більш формально, система має один і той же автомат для кожного процесора.[3][6] Не існує детермінованого алгоритму для вибору лідера в анонімних кільцях, навіть якщо розмір мережі відомий процесорам.[3][6] Це пов'язано з тим, що не існує можливості порушення симетрії в анонімному кільці, якщо всі процесори працюють з однаковою швидкістю. Стан процесорів після деяких кроків залежить тільки від початкового стану сусідніх вузлів. Тому, оскільки їхні стани ідентичні і виконують ті ж самі процедури, на кожному кроці кожен процесор посилає ті самі повідомлення. Таким чином, кожний стан процесора також змінюється тотожним чином, і в результаті, якщо один процесор обраний лідером, то всі інші також мають бути обрані лідером.

Для простоти доведемо це твердження в анонімних синхронних кільцях. Доведення протиріччям. Розглянемо анонімне кільце R з розміром n>1. Припустимо, що існує алгоритм «А» для вирішення виборів лідера в цьому анонімному кільці R.[3]

Лема: після проходів виконання алгоритму A в R, всі процеси мають однакові стани.

Доказ. проводиться за допомогою індукції по .

База індукції: : всі процесори знаходяться в початковому стані, тому всі процесори однакові.

Індукційний перехід: припустимо, що лема виконується для раундів.

Індуктивний крок: на кроці , кожен процесор посилає одне і те ж повідомлення праворуч і посилає те саме повідомлення ліворуч. Оскільки всі процесори знаходяться в одному і тому ж стані після кроку , в раунді , кожен процесор отримає повідомлення з лівого краю, і отримає повідомлення з правого краю. Оскільки всі процесори отримують одне і те ж повідомлення на кроці , вони знаходяться в одному і тому ж стані після кроку .

Лема, наведена вище, суперечить тому, що після деякого кінцевого числа раундів у виконанні А один процесор отримав би стан «обраний лідером», а інші процесори отримали б стан «не обраний».

Увипадковлені алгоритми вибору лідера

Загальним підходом до вирішення проблеми виборів лідера в анонімних кільцях є використання увипадковлених алгоритмів. У таких підходах, як правило, процесори беруть на себе деякі ідентичності на основі ймовірнісної функції і передають їх іншим мережам. Наприкінці, за допомогою застосування алгоритму, вибирається лідер (з високою ймовірністю).

Асинхронне кільце[3]
O(nlogn) алгоритм для асинхронних кілець

Оскільки не існує алгоритму для анонімних кілець (доведено вище), асинхронні кільця будуть розглядатися як асинхронні не анонімні кільця. У не анонімних кільцях кожен процесор має унікальний ідентифікатор, і вони не знають розмір кільця до початку роботи алгоритму. Вибір лідера в асинхронних кільцях може бути вирішений за допомогою певного алгоритму з використанням повідомлень або повідомлень.

У алгоритмі кожен процесор надсилає повідомлення зі своїм ідентифікатором до лівого краю. Потім чекає, поки з'явиться повідомлення з правого краю. Якщо ідентифікатор в повідомленні більше, ніж його власний ідентифікатор, то він пересилає це повідомлення знову до лівого краю; інакше він ігнорує повідомлення, і нічого не робить. Якщо ідентифікатор в повідомленні дорівнює його власному ідентифікатору, то він відправляє повідомлення ліворуч, яке оголошує цей вузол обраним. Інші процесори передають оголошення ліворуч і перетворюються на не обраних. Зрозуміло, що для цього алгоритму верхня межа є .

У алгоритмі алгоритм працює по фазах. На -й фазі, процесор визначатиме, чи є він переможцем серед сусідів з лівої і з правої сторони. Якщо це переможець, то процесор може перейти до наступного етапу. У фазі кожен процесор повинен визначити себе як переможця чи ні, відправивши повідомлення з його ідентифікатором до лівого і правого сусідів (сусіди не пересилали це повідомлення). Сусід відповідає тільки, якщо ідентифікатор в повідомленні більше, ніж ідентифікатор сусіда, інакше відповідає . Якщо отримує два -и, один з лівого, один з правого, то є переможцем у фазі . На етапі , переможцям фази необхідно надіслати повідомлення з його ідентифікатором лівим і правим сусідам. Якщо сусіди на шляху отримують ідентифікатор в повідомленні, більший, ніж їхній ідентифікатор, то вони пересилають повідомлення наступному сусіду, інакше повертають відповідь . Якщо -й сусід отримує ідентифікатор більший, ніж його ідентифікатор, то відправляє назад , інакше відправляє відповідь . Якщо процесор отримує два -и, то він є переможцем на етапі. На останньому етапі остаточний переможець отримає свій ідентифікатор у повідомленні, а потім припинить виконання алгоритму та надішле повідомлення про закінчення іншим процесорам. У найгіршому випадку кожна фаза має не більше переможців, де  — номер фази. У загальній складності знаходяться фази . Кожен переможець надсилає в порядку повідомлень на кожній фазі. Отже, складність повідомлень є .

Синхронізовані кільця

У книзі «Розподілені обчислення» Аттія та Уельч[3] описали неоднорідний алгоритм, який використовує повідомлення в синхронному кільці з відомим розміром кільця . Алгоритм працює по фазах, кожна фаза має вигляд кроків, кожен крок є одиницею часу. У фазі , якщо є процес з , то процес посилає повідомлення завершення інших процесорів (вартість відправлення повідомлення завершення кроків). Інакше, переходимо до наступного етапу. Алгоритм перевірить, чи є номер фази, що дорівнює ідентифікатору процесору, потім робить ті ж кроки, що і фаза . Наприкінці виконання мінімальний ідентифікатор буде обраний лідером. Він використав точно повідомлень та кроків.

Ітай та Роде[7] ввели алгоритм односпрямованого кільця з синхронізованими процесорами. Вони припускають, що розміри кільця (кількість вузлів) відомі процесорам. Для кільця розміром n активні a≤n процесори. Кожен процесор вирішує з імовірністю a−1, чи стане він кандидатом. В кінці кожної фази кожен процесор обчислює кількість кандидатів c, і якщо він дорівнює 1, цей процесор стає лідером. Щоб визначити значення c, кожен кандидат посилає маркер (англ. pebble) на початку фази, який передається навколо кільця, повертаючи через рівно n одиниць часу своєму відправнику. Кожен процесор визначає c шляхом підрахунку кількості маркерів, які пройшли через нього. Цей алгоритм досягає виборів керівника з очікуваною складністю повідомлення . Аналогічний підхід також використовується, коли механізм тайм-ауту використовується для виявлення тупиків у системі.[8] Існують також алгоритми для кілець спеціальних розмірів, таких як розміри простого числа[9][10] і непарні розміри.[11]

Однорідний алгоритм

У типових підходах до виборів лідера розмір кільця вважається відомим процесорам. У випадку анонімних кілець, без використання зовнішньої сутності, неможливо обрати лідера. Навіть якщо алгоритм існує, лідер не може визначити розмір кільця. Тобто в будь-якому анонімному кільці існує висока ймовірність того, що алгоритм обчислить неправильний розмір кільця.[12] Щоб подолати цю проблему, Фішер і Цзян використовували так званого лідера-оракула Ω?, що кожен процесор може запитати, чи існує у кільці унікальний лідер. Вони показують, що з певної точки вгору гарантовано повертається однакова відповідь на всі процесори.[13]

Кільця з унікальними ідентифікаторами

В одній з ранніх робіт Чанг і Робертс[14] запропонували єдиний алгоритм, в якому процесор з найвищим ідентифікатором обирається в якості лідера. Кожен процесор посилає свій ідентифікатор за годинниковою стрілкою. Кожен процесор приймає повідомлення і порівнює його з власним. Якщо він більший, він посилає його далі, інакше він проігнорує повідомлення. Вони показують, що цей алгоритм використовує не більше O(n²) повідомлень і в середньому випадку. Хіршберг і Сінклер[en][15] удосконалили цей алгоритм з складністю повідомлень, ввівши 2-канальну схему передачі повідомлень, що дозволило процесорам надсилати повідомлення в обох напрямках.

Вибір лідера в решітці

Топологія решітчатої мережі. Червоні вузли означають кути, сині — границі і сірі — внутрішні вузли.

Решітка є ще однією з популярних форм топології мереж, особливо в паралельних системах, резервних системах пам'яті та мережах взаємоз'єднань.[16] У сітчастої структурі вузли — це кути (що мають тільки двох сусідів), межа (мають тільки по три сусіди) або внутрішність (середні вузли, що мають по чотири сусіди). Кількість ребер в сітці розміром a x b дорівнює m=2ab-a-b.

Неорієнтована сітка

Типовим алгоритмом для вирішення виборів лідера в неорієнтованій сітці є лише обрання одного з чотирьох кутових вузлів як лідера. Оскільки кутові вузли можуть не знати про стан інших процесорів, алгоритм повинен спочатку розбудити кутові вузли. Лідер може бути обраний наступним чином:[17]

  1. Процес пробудження: k вузлів ініціюють процес вибору. Кожен ініціатор посилає повідомлення пробудження всім сусіднім вузлам. Якщо вузол не є ініціатором, він просто пересилає повідомлення на інші вузли. На цьому етапі відправляються не більше 3n+k повідомлень.
  2. Процес виборів: вибори у зовнішньому кільці здійснюються не більше як в два етапи з 6(a+b)-16 повідомлень.
  3. Припинення: лідер відправляє повідомлення завершення до всіх вузлів. Це вимагає не більше 2n повідомлень.

Складність повідомлення не більше 6(a + b) - 16, і якщо сітка квадратної форми, .

Орієнтована сітка

Орієнтована сітка — це особливий випадок, коли номери портів — це компас, тобто північ, південь, схід і захід. Вибір лідеру в орієнтованій сітці тривіальний. Нам потрібно лише призначити кут, наприклад, «Північ» і «схід» і переконайтеся, що вузол знає, що він став лідером.

Роздута решітка

Структура роздутої решітки.

Особливим випадком сітчастої архітектури є тор (англ. torus), який є сіткою з «обгортаннями». У цій структурі кожен вузол має рівно по 4 з'єднувальні ребра. Один з підходів до обрання лідера в такій структурі називається етапами виборів. Подібно до процедур у кільцевих структурах, цей метод на кожному етапі виключає потенційних кандидатів доки не залишиться один з кандидатів.[16] Цей вузол стає лідером, а потім повідомляє всім іншим процесорам про припинення. Цей підхід може бути використаний для досягнення складності O(n). Існують також більш практичні підходи, що застосовуються для боротьби з наявністю несправних ланок у мережі.[18][19]

Вибір в гіперкубі

Топологія H_4 гіперкубової мережі.

Гіперкуб Hk — це мережа, що складається з n=2k вузлів, кожен зі ступенем k та ребер. Для вирішення проблеми обрання лідера в даному випадку можна застосовувати раніше розглянуті алгоритми. На кожному етапі змагаються два вузли (які називаються дуелянтами), а переможець переходить до наступного етапу. Це означає, що на кожному етапі тільки половина дуелянтів виходить на наступний етап. Ця процедура триває, поки не залишиться лише один дуелянт, і він стає лідером. Після вибору він повідомляє про це всі інші процесори. Цей алгоритм вимагає O(n) повідомлень. У випадку неорієнтованого гіперкуба можна використовувати аналогічний підхід, але з більш високою складністю повідомлення .[16]

Вибір в повних мережах

Структура повної мережі.

Повні мережі є структурами, в яких всі процесори з'єднані один з одним, тобто ступінь кожного вузла n-1, де n — це розмір мережі. Оптимальне рішення досягається з O(n) повідомленням та відомою просторовою складністю[20]. У цьому алгоритмі процесори мають наступні стани:

  1. Манекен: вузли, які не беруть участі в алгоритмі вибору лідера.
  2. Пасивний: початковий стан процесів перед запуском.
  3. Кандидат: статус вузлів після пробудження. Здатними стати лідером будуть вважатися кандидатські вузли.

Для вибору лідера в мережі розглядається віртуальне кільце. Всі процесори спочатку ініціюються пасивним станом, поки вони не прокинуться. Як тільки вузли прокинулися, вони є кандидатами, щоб стати лідером. На основі схеми пріоритету вузли-кандидати співпрацюють у віртуальному кільці. У певний момент кандидати дізнаються про ідентичність кандидатів, які передують їм в кільці. Кандидати з вищим пріоритетом запитують нижчих про своїх попередників. Кандидати з більш низьким пріоритетом стають манекенами після того, як вони відповіли кандидатам з вищим пріоритетом. Виходячи з цієї схеми, кандидат з найвищим пріоритетом в кінцевому підсумку знає, що всі вузли в системі — це манекени, крім себе, і в цей момент він дізнається, що він став лідером.

Універсальні методи вибору лідера

Як випливає з назви, ці алгоритми призначені для використання в будь-якій формі технологічних мереж без будь-яких попередніх знань топології мережі або її властивостей, таких, наприклад, як її розмір.[16]

Крик

Крик (англ. Shout) (протокол) створює кістякове дерево на загальному графі і обирає свій корінь як лідера. Алгоритм має лінійну загальну вартість по краях потужності.

Над-злиття

Ця методика Над-злиття[en] по суті схожа на пошук мінімального кістякового дерева, в якому корінь дерева стає лідером. Основна ідея цього методу полягає в тому, що окремі вузли зливаються один з одним для формування великих структур. Результатом цього алгоритму є дерево (граф без циклу), корінь якого є лідером всієї системи. Вартість методу над-злиття є де m — число ребер і n — кількість вузлів.

Йо-йо

Приклад роботи алгоритму Йо-Йо. a) Мережа, b) Орієнтована мережа після фази налаштування, c) Йо- фаза в якій значення джерел проходять, d)-Йо фаза надсилає відповіді від стоків, e) оновлена структура після фази -Йо.

Йо-йо (алгоритм)[en] є мінімальним алгоритмом пошуку, що складається з двох частин: фази попередньої обробки і послідовних ітерацій.[16] На першій фазі або установці кожен вузол обмінюється своїм ідентифікатором з усіма своїми сусідами і засновується на значенні своїх орієнтованих ребер. Наприклад, якщо вузол x має менший ідентифікатор, ніж y, x орієнтується на y. Якщо вузол має менший ідентифікатор, ніж всі його сусіди, він стає джерелом. Навпаки, вузол з усіма внутрішніми ребрами (тобто з ідентифікатором більшим, ніж усі його сусіди) є стоком. Всі інші вузли є внутрішніми вузлами. Після того, як всі ребра орієнтовані, починається фаза ітерації. Кожна ітерація є виборчим етапом, коли деякі кандидати будуть видалені. Кожна ітерація має дві фази: Йо- і -йо. У цій фазі джерела починають процес розповсюдження до кожного стоку найменших значень джерел, з'єднаних зі стоком.

Йо-

  1. Джерело (місцевий мінімуми) передає своє значення усім своїм сусідам
  2. Внутрішній вузол чекає на отримання значення від усіх своїх сусідів. Він обчислює мінімум і відправляє його до сусіда.
  3. Стік (вузол без вихідного ребра) отримує всі значення і обчислює їх мінімум.

-йо

  1. Стік посилає ТАК до сусідів, з від яких вона отримала найменше значення, а НІ — іншим
  2. Внутрішній вузол відправляє ТАК всім сусідам, з від яких він отримав найменше значення, і НІ — іншим. Якщо він отримує тільки один НІ, він посилає НІ всім.
  3. Джерело чекає, поки не отримає всі голоси. Якщо всі голоси — ТАК, цей вузол залишається, і якщо наявні голоси НІ, то цей вузол вже не є кандидатом.
  4. Коли вузол x посилає НІ до сусіда y, логічний напрямок цього ребра змінюється на протилежний.
  5. Коли вузол y отримує НІ від зовнішнього сусіда, він перевертає напрямок цього посилання.

Після завершального етапу будь-яке джерело, що отримує НІ, більше не є джерелом і стає стоком. Додаткова стадія, обрізка, також вводиться для видалення непридатних вузлів, тобто їх існування не впливає на наступні ітерації.

  1. Якщо стік є листом, то він не має сенсу і тому відкидається.
  2. Якщо в Йо-фазі вузол отримав одне і те ж значення від більш ніж одного сусіда, він запитає всіх, крім одного, видалити зв'язки з ним.

Цей метод має загальну вартість повідомлень . Його реальна складність повідомлення, включаючи обрізку, є відкритою проблемою дослідження і залишається невідомою.

Застосування

Радіо мережі

У протоколах радіомережі вибори лідера часто використовуються як перший крок для підходу до більш просунутих примітивів зв'язку, таких як збір повідомлень або трансляція.[21] Сама природа бездротових мереж індукує зіткнення, коли суміжні вузли передаються одночасно; обрання лідера дозволяє краще координувати цей процес. Хоча відстань D мережі є природною нижньою межею часу, необхідного для вибору лідера, верхня і нижня межі проблеми вибору лідера залежать від конкретної досліджуваної моделі радіозв'язку.

Моделі та середовище виконання

У радіомережах n вузлів на кожному кроці можуть або передавати, або отримувати повідомлення. Якщо не виявлено зіткнень, то вузол не може відокремлювати мовчання або прийняття більше одного повідомлення за один раз. Якщо виявлено зіткнення, то вузол може одночасно виявити більше одного вхідного повідомлення, навіть якщо самі повідомлення не можуть бути декодовані в цьому випадку. У звуковій моделі вузли можуть розрізняти лише тишу або принаймні одне повідомлення через зондування носія[en].

Відомі режими роботи для однохопних[en] мереж варіюються від постійної (очікуваної з виявленням зіткнення) до O(n log n) кроків (детермінований і без виявлення зіткнень). У багатохопних[en] мережах відомі періоди виконання відрізняються від грубо O((D+ log n)(log² log n)) кроків (з високою ймовірністю в моделі звукового сигналу), O(D log n) (детермінований в звуковій моделі), O(n) (детермінований з виявленням зіткнення) до O(n log3/2 n (log log n)0.5) кроків (детермінований і без виявлення зіткнень).

Див. також

Примітки

  1. R. G. Gallager, P. A. Humblet, and P. M. Spira (January 1983). A Distributed Algorithm for Minimum-Weight Spanning Trees (PDF). ACM Transactions on Programming Languages and Systems. 5 (1): 66—77. doi:10.1145/357195.357200. Архів оригіналу (PDF) за 12 жовтня 2016. Процитовано 26 березня 2019.
  2. Ephraim Korach, Shay Kutten, Shlomo Moran (1990). A Modular Technique for the Design of Efficient Distributed Leader Finding Algorithms. ACM Transactions on Programming Languages and Systems. 12 (1): 84—101. CiteSeerX 10.1.1.139.7342. doi:10.1145/77606.77610.
  3. а б в г д е H. Attiya and J. Welch, Distributed Computing: Fundamentals, Simulations and Advance Topics, John Wiley & Sons inc., 2004, chap. 3
  4. I. Gupta, R. van Renesse, and K. P. Birman,2000, A Probabilistically Correct Leader Election Protocol for Large Groups, Technical Report , Cornell University
  5. R. Bakhshi, W. Fokkink, J. pang, and J. Van de Pol, c2008 «Leader Election in Anonymous Rings: Franklin Goes Probabilistic», TCS, Vol. 273, pp. 57-72.
  6. а б H. Attiya and M. Snir, 1988,"Computing on an anonymous ring",JACM,Vol. 35, issue. 4, pp. 845—875
  7. A. Itai and M. Rodeh, 1990,"Symmetry breaking in distributed networks", Vol. 88, issue 1, pp. 60-87.
  8. L. Higham and S. Myers, 1998, «Self-Stabilizing Token Circulation on Anonymous Message Passing Rings», Second International Conference On Principles Of DIstributed Systems.
  9. G. Itkis, C. Lin, and J. Simon,1995,"Deterministic, constant space, self-stabilizing leader election on uniform rings.", In Proc. 9th Workshop on Distributed Algorithms, Vol. 972, pp. 288—302.
  10. J. Burns and J. Pachl,1989,"Uniform self-stabilizing rings",ACM Trans. Program. Lang. Systems, Vol. 11, issue. 2, pp.330-344
  11. T. Herman, 1990, «Probabilistic self-stabilization», Inf. Process. Lett., Vol. 35, issue 2, pp.63-67.
  12. G. Tel,Introduction to Distributed Algorithms. Cambridge University Press, 2000.2nd edition
  13. M. Fischer and H. Jiang, 2006,"Self-stabilizing leader election in networks of _nite-state anonymous agents", In Proc. 10th Conf. on Principles of Distributed Systems,Vol. 4305, pp. 395—409.
  14. E. Chang and R. Roberts, 1979, «An improved algorithm for decentralized extrema-finding in circular configurations of processes», ACM, Vol. 22, issue 5, pp. 281—283.
  15. D. S. Hirschberg and J. B. Sinclair, 1980, «Decentralized extrema-finding in circular configurations of processors», ACM, Vol. 23, issue 11, pp. 627—628.
  16. а б в г д N. Santoro, Design and Analysis of Distributed Algorithms, Wiley, 2006.
  17. H. Kallasjoki, 2007, «Election in Mesh, Cube and Complete Networks», Seminar on Theoretical Computer Science.
  18. M. Refai, A. Sharieh and . Alsmmari, 2010, «Leader Election Algorithm in 2D Torus Network with the Presence of One Link Failure», The International Arab Journal of Information Technology, Vol. 7, No. 2.
  19. M Al Refai,2014, «Dynamic Leader Election Algorithm in 2D Torus Network with Multi Links Failure», IJCST, Vol. 2, issue 5.
  20. J. Villadangos, A. Cordoba, F. Farina, and M. Prieto, 2005, «Efficient leader election in complete networks», PDP, pp.136-143.
  21. Haeupler, Bernhard; Ghaffari, Mohsen (2013). Near Optimal Leader Election in Multi-Hop Radio Networks. с. 748—766. arXiv:1210.8439. doi:10.1137/1.9781611973105.54. ISBN 978-1-61197-251-1. {{cite book}}: Проігноровано |journal= (довідка)

Read other articles:

Strömma Kanalbolaget passenger ferry and listed historic ship in Sweden Östanå I History NameÖstanå I Owner Ångfartygs AB Östanå (1906-1913) Waxholmsbolaget (1913-1964) Various (1967-1986) Strömma Kanalbolaget (1986-) Builder William Lindberg's Shipyard [sv], Sweden Bergsund's Mechanical Workshop [sv], Sweden In service1906 IdentificationIMO number: 5266348 General characteristics TypePassenger ferry Length35.04 m (115 ft 0 in) Beam6.86&#...

 

French actress Hélène PerdrièreHélène Perdrière in 1938Born(1912-04-17)17 April 1912Asnières FranceDied27 August 1992(1992-08-27) (aged 80)Hauts-de-Seine, Île-de-France FranceOccupationFilm actressYears active1930 - 1980 Hélène Perdrière (born 17 April 1912[citation needed] in Asnieres-sur-Seine, died 27 August 1992 in Boulogne-Billancourt) was a French stage and film actress.[1] After earning a first prize for comedy at the National Conservatory of Dramat...

 

يفتقر محتوى هذه المقالة إلى الاستشهاد بمصادر. فضلاً، ساهم في تطوير هذه المقالة من خلال إضافة مصادر موثوق بها. أي معلومات غير موثقة يمكن التشكيك بها وإزالتها. (ديسمبر 2018) محافظة عجلون. تتناول هذه القائمة المواقع الأثرية المسجَّلة رسمياً لدى دائرة الآثار العامة التابعة لوزار...

  لمعانٍ أخرى، طالع المرقب (توضيح). المرقب (محلة) تقسيم إداري البلد  اليمن المحافظة محافظة إب المديرية مديرية حبيش العزلة عزلة كومان القرية قرية الزواحي السكان التعداد السكاني 2004 السكان 49   • الذكور 14   • الإناث 35   • عدد الأسر 8   • عدد المساكن 8 معلومات أخرى...

 

Переписна місцевість Олмітоангл. Olmito Координати 26°01′10″ пн. ш. 97°32′04″ зх. д. / 26.01970000002777894° пн. ш. 97.53470000002778306° зх. д. / 26.01970000002777894; -97.53470000002778306Координати: 26°01′10″ пн. ш. 97°32′04″ зх. д. / 26.01970000002777894° пн. ш. 97.53470000002778306° ...

 

この記事には参考文献や外部リンクの一覧が含まれていますが、脚注による参照が不十分であるため、情報源が依然不明確です。適切な位置に脚注を追加して、記事の信頼性向上にご協力ください。(2022年12月) アルブレヒト2世Albrecht II. ザクセン=ヴィッテンベルク公 在位 1260年 - 1298年出生 1250年死去 1298年8月25日 神聖ローマ帝国マグデブルク大司教領、アケン埋葬 神

NATO strategic-level military command SACT redirects here. For the educational institution in Kerala, see St. Aloysius College, Thrissur. Allied Command TransformationEmblemFounded19 June 2003Part ofNorth Atlantic Treaty Organization (NATO)HeadquartersNaval Support Activity Hampton RoadsNorfolk, Virginia (USA)Websitewww.act.nato.intCommandersCurrentcommanderGénéral Philippe Lavigne, French Air and Space ForceMilitary unit Allied Command Transformation (ACT) (French: Commandement allié...

 

تاريخ الطوارقهذه المقالة جزء من سلسلةما قبل التاريخ الجرمنتيون التاريخ الإسلامي الملثمون مملكة أودغست المرابطون 448 - 540 هـ / 1056 - 1145 م دولة بني غانية (الفرع الثاني لدولة المرابطين) 580 - 633 هـ / 1184 - 1235 مالتاريخ الحديث سلطنات الطوارق مقاومة الطوارق للاستعمار الفرنسي 1881 م - 1923 م ثورا

 

Video game series Video game seriesSuper Robot WarsGenre(s)Tactical role-playingDeveloper(s)WinkysoftBanpresoftB.B. StudioPublisher(s)Banpresto (1991-2017)Bandai Namco Entertainment (2019-present)Platform(s) Platforms Game Boy, Family Computer, Super Famicom, Nintendo 64, Sega Saturn, PlayStation, Game Boy Color, WonderSwan, J2ME, PlayStation 2, GameCube, Dreamcast, Nintendo DS, PlayStation Portable, Wii, Xbox 360, PlayStation 3, Windows, Mobile phone, iOS, Android, PlayStation Vita, PlayStat...

Unincorporated community in Iowa, United StatesOakland Mills, IowaUnincorporated communityOakland MillsShow map of IowaOakland MillsShow map of the United StatesCoordinates: 40°56′10″N 91°37′00″W / 40.9361397°N 91.6165510°W / 40.9361397; -91.6165510CountryUnited StatesStateIowaCountyHenryElevation568 ft (173 m)Time zoneUTC-6 (Central (CST)) • Summer (DST)UTC-5 (CDT)Area code319GNIS feature ID459769[1] Oakland Mills is an uninco...

 

Chlamydia trachomatis C. trachomatis inclusion bodies (brown) in a McCoy cell culture. Klasifikasi ilmiah Kerajaan: Bacteria Filum: Chlamydiae Ordo: Chlamydiales Famili: Chlamydiaceae Genus: Chlamydia Spesies: C. trachomatis Nama binomial Chlamydia trachomatisBusacca, 1935 Chlamydia trachomatis adalah salah satu dari tiga spesies bakteri dalam genus Chlamydia, famili Chlamydiaceae, kelas Chlamydiae, filum Chlamydiae, domain Bacteria. C. trachomatis adalah agen chlamydial pertama yang dit...

 

Micro Machines 2 as a J-Cart All six J-Cart released games The J-Cart is a special ROM cartridge developed by Codemasters for the Sega Genesis console. It held not only the game data but also came with two additional gamepad ports. This effectively allowed four players to play simultaneously without any extra adapters. The first J-Cart game, Tennis All-Stars, was released in early 1994.[1][2] Micro Machines 2: Turbo Tournament also allowed up to eight players to play simultane...

2020 studio album by Alejandro FernándezHecho en MéxicoStudio album by Alejandro FernándezReleasedFebruary 14, 2020 (2020-02-14)Recorded2019GenreMariachiLength39:50LabelUniversal Music MéxicoProducerÁureo BaqueiroAlejandro Fernández chronology Rompiendo Fronteras(2017) Hecho en México(2020) Singles from Hecho en México CaballeroReleased: October 3, 2019 Te OlvidéReleased: January 17, 2020 Eso y MásReleased: April 8, 2020 DecepcionesReleased: August 21, 2020 Du...

 

Cette page concerne l'année 2008 (MMVIII en chiffres romains) du calendrier grégorien. Pour l'année 2008 av. J.-C., voir 2008 av. J.-C. Chronologies Données clés 2005 2006 2007  2008  2009 2010 2011Décennies :1970 1980 1990  2000  2010 2020 2030Siècles :XIXe XXe  XXIe  XXIIe XXIIIeMillénaires :Ier IIe  IIIe  Chronologies géographiques Afrique Afrique du Sud, Algérie, Angola, Bénin, Botswana, Burkina Faso, Burundi, Cameroun, Cap...

 

School in Cincinnati, Ohio, United StatesArchbishop Moeller High SchoolAddress9001 Montgomery Road[1]Cincinnati, Ohio 45242United StatesCoordinates39°13′12″N 84°21′30″W / 39.22000°N 84.35833°W / 39.22000; -84.35833InformationSchool typePrivate Comprehensive, Parochial, College-preparatory high schoolMottoNova bella elegit Dominus[7][8](Latin: The Lord has chosen new wars)Religious affiliation(s)Roman Catholic(Marianists)EstablishedSe...

General concept and operation in mathematics For the property of optimization problems, see Duality (optimization). In mathematics, a duality translates concepts, theorems or mathematical structures into other concepts, theorems or structures in a one-to-one fashion, often (but not always) by means of an involution operation: if the dual of A is B, then the dual of B is A. Such involutions sometimes have fixed points, so that the dual of A is A itself. For example, Desargues' theorem is self-...

 

José Ortiz de la Peña Intendente colonial de San Salvador 1786-1789Designado por Rey Carlos IIIPredecesor Manuel Fadrique y Goyena (último alcalde mayor)Sucesor Francisco Luis Héctor Información personalNacimiento c. 1730sSalamanca, Reino de las EspañasFallecimiento c. 1800sNueva Guatemala de la AsunciónFamiliaCónyuge Margarita (Mariquita) Alonso Barragán y SotomayorInformación profesionalOcupación Abogado, doctor en leyes, bibliotecario, y profesor en idioma griego[editar dat...

 

هذه المقالة يتيمة إذ تصل إليها مقالات أخرى قليلة جدًا. فضلًا، ساعد بإضافة وصلة إليها في مقالات متعلقة بها. (يوليو 2021) الصندوق الاسود للرحلة 149 (بالإنجليزية: Black Box 149)‏ هي مسرحية للكاتبة الأسترالية روزماري جونز. الصندوق الأسود للرحلة 149Black Box 149 (بالإنجليزية) معلومات عامةالمؤلف ...

こみやま りな小宮山 莉渚 第35回東京国際映画祭にて(2022年10月24日)プロフィール生年月日 2005年7月14日現年齢 18歳出身地 日本・宮城県公称サイズ(2022年10月時点)身長 / 体重 169 cm / ― kg 単位系換算身長 / 体重5′ 7″ / ― lb活動デビュー 2018年モデル内容 一般事務所 スターダストプロモーションモデル: テンプレート - カテゴリ 小宮山 莉渚(こみやま りな、2005年7月14...

 

أوزفالدو نارديلو   معلومات شخصية الميلاد 31 أغسطس 1936(1936-08-31)روساريو  تاريخ الوفاة 26 مايو 2020 (عن عمر ناهز 83 عاماً) مركز اللعب لاعب وسط  الجنسية الأرجنتين  المسيرة الاحترافية1 سنوات فريق م. (هـ.) 1955–57 نيولز أولد بويز 56 (12) 1958–62 بوكا جونيورز 107 (44) 1963–65 إستوديانتيس دي ل...

 

Strategi Solo vs Squad di Free Fire: Cara Menang Mudah!