Параллельный алгоритм - Parallel algorithm

В Информатика, а параллельный алгоритм, в отличие от традиционного последовательный алгоритм, является алгоритм который может выполнять несколько операций за определенное время. Это была традиция Информатика для описания последовательных алгоритмов в абстрактных моделях машин, часто известной как Машина с произвольным доступом. Точно так же многие исследователи информатики использовали так называемый параллельная машина с произвольным доступом (PRAM) как параллельная абстрактная машина (разделяемая память).[1][2]

Выполняется множество параллельных алгоритмов одновременно - хотя в целом параллельные алгоритмы представляют собой отдельную концепцию - и, таким образом, эти концепции часто смешиваются, при этом, какой аспект алгоритма является параллельным, а какой - параллельным, четко не различается. Кроме того, непараллельные и непараллельные алгоритмы часто называют "последовательные алгоритмы ", в отличие от параллельных алгоритмов.

Возможность распараллеливания

Степень распараллеливания алгоритмов значительно различается: от легко распараллеливаемых до полностью непараллелизируемых. Кроме того, данная проблема может включать в себя различные алгоритмы, которые могут быть более или менее распараллеливаемыми.

Некоторые задачи легко разделить таким образом на части - они называются смущающе параллельные проблемы. Примеры включают множество алгоритмов решения Кубики Рубика и найти значения, которые приводят к заданному хэш.[нужна цитата ]

Некоторые проблемы нельзя разделить на параллельные части, так как они требуют результатов предыдущего шага, чтобы эффективно перейти на следующий шаг - они называются по сути серийная проблемаs. Примеры включают итерационные численные методы, Такие как Метод Ньютона, итерационные решения проблема трех тел, и большинство доступных алгоритмов для вычисления число Пи (π).[нужна цитата ] Некоторые последовательные алгоритмы могут быть преобразованы в параллельные алгоритмы, используя автоматическое распараллеливание.[3]

Мотивация

Параллельные алгоритмы на отдельных устройствах стали более распространенными с начала 2000-х годов из-за значительных улучшений в многопроцессорность системы и рост многоядерный процессоры. Вплоть до конца 2004 года производительность одноядерных процессоров быстро увеличивалась за счет частотное масштабирование, и поэтому было проще построить компьютер с одним быстрым ядром, чем с большим количеством медленных ядер с тем же пропускная способность, поэтому многоядерные системы имели более ограниченное применение. Однако с 2004 года масштабирование частоты упало, и, таким образом, многоядерные системы стали более распространенными, что сделало параллельные алгоритмы более общими.

вопросы

Коммуникация

Стоимость или сложность последовательных алгоритмов оценивается с точки зрения занимаемого ими пространства (память) и времени (циклы процессора). Параллельным алгоритмам необходимо оптимизировать еще один ресурс - связь между разными процессорами. Есть два способа связи между параллельными процессорами: общая память или передача сообщений.

Общая память обработка требует дополнительных запирание для данных накладывает накладные расходы на дополнительные циклы процессора и шины, а также сериализует некоторую часть алгоритма.

Передача сообщений обработка использует каналы и ящики сообщений, но это взаимодействие увеличивает накладные расходы на передачу по шине, дополнительную память, необходимую для очередей и ящиков сообщений, а также задержку в сообщениях. В конструкциях параллельных процессоров используются специальные шины типа перекладина так что накладные расходы на связь будут небольшими, но именно параллельный алгоритм определяет объем трафика.

Если накладные расходы на связь дополнительных процессоров перевешивают выгоду от добавления еще одного процессора, возникает параллельное замедление.

Балансировка нагрузки

Другая проблема с параллельными алгоритмами заключается в том, что они балансировка нагрузки, гарантируя, что нагрузка (общая работа) сбалансирована, а не размер входного сигнала сбалансирован. Например, проверку простоты всех чисел от одного до ста тысяч легко разделить между процессорами; однако, если числа просто разделить поровну (1–1 000, 1 001–2 000 и т. д.), объем работы будет несбалансированным, так как меньшие числа легче обрабатывать этим алгоритмом (легче проверить на простоту) и таким образом, у некоторых процессоров будет больше работы, чем у других, которые будут бездействовать до завершения загрузки загруженных процессоров.

Распределенные алгоритмы

Подтип параллельных алгоритмов, распределенные алгоритмы алгоритмы, предназначенные для работы в кластерные вычисления и распределенных вычислений среды, в которых необходимо решать дополнительные проблемы, выходящие за рамки «классических» параллельных алгоритмов.

Смотрите также

Рекомендации

  1. ^ Blelloch, Guy E .; Мэггс, Брюс М. «Параллельные алгоритмы» (PDF). США: Школа компьютерных наук, Университет Карнеги Меллон. Получено 2015-07-27. Цитировать журнал требует | журнал = (помощь)
  2. ^ Вишкин, Узи (2009). «Параллельное мышление: некоторые базовые алгоритмы и методы работы с параллельными данными, 104 страницы» (PDF). Классные заметки по курсам по параллельным алгоритмам, которые читаются с 1992 года в Мэрилендском университете, Колледж-Парке, Тель-Авивском университете и Технионе. Цитировать журнал требует | журнал = (помощь)
  3. ^ Megson G M; Чэнь Сиань (4 января 1997 г.). Автоматическое распараллеливание для класса регулярных вычислений. World Scientific. ISBN  978-981-4498-41-8.

внешняя ссылка