Шаг 12.
Параллельные алгоритмы. Моделирование и анализ параллельных вычислений. Показатели эффективности параллельного алгоритма
На этом шаге мы рассмотрим вопросы, связанные с эффективностью параллельного алгоритма.
Ускорение, получаемое при использовании параллельного алгоритма для p процессоров, по сравнению с последовательным вариантом
выполнения вычислений определяется величиной
Sp(n)=T1(n)/Tp(n),
т.е. как отношение времени решения задач на скалярной ЭВМ к времени выполнения параллельного алгоритма (величина n применяется для
параметризации вычислительной сложности решаемой задачи и может пониматься, например, как количество входных данных задачи).
Эффективность использования параллельным алгоритмом процессоров при решении задачи определяется соотношением
Ep(n)=T1(n)/(pTp(n))=Sp(n)/p
(величина эффективности определяет среднюю долю времени выполнения алгоритма, в течение которой процессоры реально задействованы для
решения задачи).
Из приведенных соотношений можно показать, что в наилучшем случае Sp(n)=p и Ep(n)=1. При
практическом применении данных показателей для оценки эффективности параллельных вычислений следует учитывать два важных момента:
- При определенных обстоятельствах ускорение может оказаться больше числа используемых процессоров Sp(n)>p -
в этом случае говорят о существовании сверхлинейного ускорения. Несмотря на парадоксальность таких ситуаций (ускорение превышает число
процессоров), на практике сверхлинейное ускорение может иметь место. Одной из причин такого явления может быть неодинаковость условий
выполнения последовательной и параллельной программ. Например, при решении задачи на одном процессоре оказывается недостаточно
оперативной памяти для хранения всех обрабатываемых данных и тогда становится необходимым использование более медленной внешней памяти
(в случае же использования нескольких процессоров оперативной памяти может оказаться достаточно за счет разделения данных
между процессорами). Еще одной причиной сверхлинейного ускорения может быть нелинейный характер зависимости сложности решения
задачи от объема обрабатываемых данных. Так, например, известный алгоритм пузырьковой сортировки характеризуется квадратичной зависимостью
количества необходимых операций от числа упорядочиваемых данных. Как результат, при распределении сортируемого массива между процессорами
может быть получено ускорение, превышающее число процессоров. Источником сверхлинейного ускорения может быть и различие вычислительных
схем последовательного и параллельного методов.
- При внимательном рассмотрении можно обратить внимание, что попытки повышения качества параллельных вычислений по одному из
показателей (ускорению или эффективности) могут привести к ухудшению ситуации по другому показателю, ибо показатели качества параллельных
вычислений являются часто противоречивыми. Так, например, повышение ускорения обычно может быть обеспечено за счет увеличения числа
процессоров, что приводит, как правило, к падению эффективности. И наоборот, повышение эффективности достигается во многих случаях при
уменьшении числа процессоров (в предельном случае идеальная эффективность Ep(n)=1 легко обеспечивается при
использовании одного процессора). Как результат, разработка методов параллельных вычислений часто предполагает выбор некоторого компромиссного
варианта с учетом желаемых показателей ускорения и эффективности.
При выборе надлежащего параллельного способа решения задачи может оказаться полезной оценка стоимости вычислений, определяемой как
произведение времени параллельного решения задачи и числа используемых процессоров Cp=pTp.
В связи с этим можно определить понятие стоимостно-оптимального параллельного алгоритма как метода, стоимость которого является пропорциональной
времени выполнения наилучшего последовательного алгоритма.
На следующем шаге мы рассмотрим оценке максимально достижимого параллелизма.
Предыдущий шаг
Содержание
Следующий шаг