Алгоритм Дейкстры – Шолтена - Википедия - Dijkstra–Scholten algorithm
В Алгоритм Дейкстры – Шолтена (названный в честь Эдсгер В. Дейкстра и Карел С. Шолтен ) является алгоритм для обнаружения прекращение в распределенная система.[1][2] Алгоритм был предложен Дейкстрой и Шолтеном в 1980 году.[3]
Сначала рассмотрим случай простого граф процесса который является дерево. Распределенные вычисления с древовидной структурой не редкость. Такой граф процесса может возникнуть, когда вычисление строго разделяй и властвуй тип. А узел начинает вычисление и делит задачу на две (или более, обычно кратные 2) примерно равные части и распределяет эти части по другим процессорам. Этот процесс продолжается рекурсивно до тех пор, пока проблемы не станут достаточно маленькими, чтобы их можно было решить на одном процессоре.
Алгоритм
Алгоритм Дейкстры – Шолтена - это древовидный алгоритм, который можно описать следующим образом:
- Инициатор вычисления - корень дерева.
- При получении вычислительного сообщения:
- Если принимающий процесс в настоящее время не участвует в вычислениях: процесс присоединяется к дереву, становясь потомком отправителя сообщения. (На этом этапе подтверждающее сообщение не отправляется.)
- Если получающий процесс уже находится в вычислении: процесс немедленно отправляет сообщение подтверждения отправителю сообщения.
- Когда у процесса больше нет дочерних процессов и он стал бездействующим, процесс отделяется от дерева, отправляя сообщение подтверждения своему родительскому дереву.
- Завершение происходит, когда у инициатора нет дочерних элементов и он стал бездействующим.
Алгоритм Дейкстры – Шолтена для дерева
- Для дерева легко обнаружить завершение. Когда листовой процесс определяет, что он завершен, он отправляет сигнал своему родителю. В общем, процесс ожидает, пока все его дочерние элементы отправят сигналы, а затем он отправляет сигнал своему родителю.
- Программа завершается, когда корень получает сигналы от всех своих дочерних элементов.
Алгоритм Дейкстры – Шолтена для ориентированных ациклических графов
- Алгоритм для дерева может быть расширен до ациклических ориентированных графов. Мы добавляем дополнительный целочисленный атрибут Дефицит к каждому ребру.
- На входящем фронте Deficit будет обозначать разницу между количеством полученных сообщений и количеством сигналов, отправленных в ответ.
- Когда узел желает завершить работу, он ждет, пока он не получит сигналы от исходящих ребер, уменьшая их дефицит до нуля.
- Затем он посылает достаточно сигналов, чтобы гарантировать, что дефицит равен нулю на каждом входящем фронте.
- Поскольку граф является ациклическим, некоторые узлы не будут иметь исходящих ребер, и эти узлы будут завершаться первыми после отправки достаточного количества сигналов своим входящим ребрам. После этого узлы на более высоких уровнях будут отключены уровень за уровнем.
Алгоритм Дейкстры – Шолтена для циклических ориентированных графов
- Если циклы разрешены, предыдущий алгоритм не работает. Это потому, что не может быть ни одного узла с нулевыми исходящими ребрами. Таким образом, потенциально нет узла, который мог бы завершить работу без консультации с другими узлами.
- Алгоритм Дейкстры – Шолтена решает эту проблему путем неявного создания остовное дерево графа. Остовное дерево - это дерево, которое включает в себя каждый узел базового графа один раз, а набор ребер является подмножеством исходного набора ребер.
- Дерево будет направлено (то есть каналы будут направлены) с исходным узлом (который инициирует вычисление) в качестве корня.
- Остовное дерево создается следующим образом. Переменная Первый край добавляется к каждому узлу. Когда узел получает сообщение в первый раз, он инициализирует Первый край с той кромки, через которую было получено сообщение. Первый край никогда не меняется впоследствии. Обратите внимание, что связующее дерево не уникально и зависит от порядка сообщений в системе.
- Завершение обработки выполняется каждым узлом в три этапа:
- Отправлять сигналы по всем входящим фронтам, кроме первого. (Каждый узел будет посылать сигналы, которые уменьшают дефицит на каждом входящем фронте до нуля.)
- Дождитесь сигналов со всех исходящих ребер. (Количество сигналов, полученных на каждом исходящем фронте, должно уменьшить каждый из их дефицитов до нуля.)
- Отправлять сигналы на Первый край. (После завершения шагов 1 и 2 узел информирует своего родителя в связующем дереве о своем намерении завершить работу.)
Смотрите также
Рекомендации
- ^ Гош, Сукумар (2010), «9.3.1 Алгоритм Дейкстры – Шолтена», Распределенные системы: алгоритмический подход, CRC Press, стр. 140–143, ISBN 9781420010848.
- ^ Фоккинк, Ван (2013), «6.1 Алгоритм Дейкстры – Шолтена», Распределенные алгоритмы: интуитивный подход, MIT Press, стр. 38–39, ISBN 9780262318952.
- ^ Dijkstra, Edsger W .; Шолтен, С. С. (1980), «Обнаружение завершения для рассеивающих вычислений» (PDF), Письма об обработке информации, 11 (1): 1–4, Дои:10.1016/0020-0190(80)90021-6, МИСТЕР 0585394.