Научная статья на тему 'Алгоритмическая оптимизация программной реализации метода параллельно-последовательной декомпозиции граф-схем параллельных алгоритмов'

Алгоритмическая оптимизация программной реализации метода параллельно-последовательной декомпозиции граф-схем параллельных алгоритмов Текст научной статьи по специальности «Компьютерные и информационные науки»

CC BY
328
47
i Надоели баннеры? Вы всегда можете отключить рекламу.
Ключевые слова
СИСТЕМА ЛОГИЧЕСКОГО УПРАВЛЕНИЯ / ПРОЕКТИРОВАНИЕ ЛОГИЧЕСКИХ МУЛЬТИКОНТРОЛЛЕРОВ / РАЗБИЕНИЯ / ГРАФ-СХЕМЫ ПАРАЛЛЕЛЬНЫХ АЛГОРИТМОВ / АЛГОРИТМИЧЕСКАЯ ОПТИМИЗАЦИЯ / LOGICAL CONTROL SYSTEM / LOGICAL MULTI-CONTROLLERS DESIGN / GRAPH PARTITION / PARALLEL ALGORITHM GRAPH-SCHEME / ALGORITHMIC OPTIMIZATION

Аннотация научной статьи по компьютерным и информационным наукам, автор научной работы — Ватутин Эдуард Игоревич, Титов Виталий Семенович

Описаны результаты профилирования и анализа „узких мест“ программной реализации метода параллельно-последовательной декомпозиции граф-схем параллельных алгоритмов. В результате алгоритмической оптимизации вычислительные затраты на синтез разбиений сокращены в 30 раз.

i Надоели баннеры? Вы всегда можете отключить рекламу.

Похожие темы научных работ по компьютерным и информационным наукам , автор научной работы — Ватутин Эдуард Игоревич, Титов Виталий Семенович

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.
i Надоели баннеры? Вы всегда можете отключить рекламу.

Algorithmic Optimization of Program Implementation of the Parallel-Sequential Method for Partition of Parallel Algorithm Graph-Scheme

Description of profiling results and bottlenecks analysis of program implementation of parallel-sequential method are presented. The cost of computations with the use of algorithmic optimization is shown to reduce by a factor of 30.

Текст научной работы на тему «Алгоритмическая оптимизация программной реализации метода параллельно-последовательной декомпозиции граф-схем параллельных алгоритмов»

ВЫЧИСЛИТЕЛЬНАЯ ТЕХНИКА

УДК 621.397.01

Э. И. Ватутин, В. С. Титов

АЛГОРИТМИЧЕСКАЯ ОПТИМИЗАЦИЯ ПРОГРАММНОЙ РЕАЛИЗАЦИИ МЕТОДА ПАРАЛЛЕЛЬНО-ПОСЛЕДОВАТЕЛЬНОЙ ДЕКОМПОЗИЦИИ ГРАФ-СХЕМ ПАРАЛЛЕЛЬНЫХ АЛГОРИТМОВ

Описаны результаты профилирования и анализа „узких мест" программной реализации метода параллельно-последовательной декомпозиции граф-схем параллельных алгоритмов. В результате алгоритмической оптимизации вычислительные затраты на синтез разбиений сокращены в 30 раз.

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

При проектировании систем логического управления на базе логических мультиконтроллеров [1, 2] возникает ряд многокритериальных задач дискретной оптимизации, одной из которых является задача поиска разбиения заданной параллельной граф-схемы алгоритма. Ввиду невозможности отыскания точного решения в течение приемлемого времени для граф-схем реальной размерности с целью решения указанной задачи разработан ряд эвристических методов, в частности, метод параллельно-последовательной декомпозиции [3, 4]. В настоящей статье, являющейся продолжением работы [5], приведены результаты профилирования его программной реализации и последующей алгоритмической оптимизации его отдельных этапов.

В процессе расчета значений для таблиц включений при распределении субсечений по блокам [6], в частности, определяются параметры весовой функции приращения сложности сети межблочных связей AZa и интенсивности межблочных взаимодействий AZg. Расчет этих параметров производится на основе множества дуг межблочной передачи управления, особенности построения которого, в свою очередь, зависят от способа поиска дуги по номерам инцидентных ей вершин (например, требуется найти дугу, инцидентную вершинам 03 и

a8, принадлежащим разным блокам разбиения: 03 е Д , a8 е A3 ). Схематично это можно представить в следующем виде.

S : = 0;

for аА е S! do // O(N)

for aj е S2 do // O(N)

if ■vy=(ail а^) е V then // O(M) или O(log M) S := S U { k }; // O(1)

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

вложенных циклов: по ¿у = Ау, А2,..., Ан и по ¿2 = Ау, А2,..., Ая , ф ¿2. Однако при расчете приращений AZa и AZg с использованием суммирования параметров дуг в (у,-) и 5 (у,-) [7] для включения (р,, Ау) можно положить

н

¿1 = и Ак и ¿2 = Р,,

к=1, к ф у

т.е. рассматривать только вновь добавляемые дуги межблочной передачи управления (рис. 1). На рисунке пунктиром показан блок разбиения Ау после включения в него субсечения р,,

стрелками изображены дуги межблочной передачи управления, жирными стрелками — „новые" дуги передачи управления, возникающие в случае включения субсечения р, в блок Ау .

(Более сложные способы расчета интенсивности межблочных взаимодействий — через выделение отношений совместимости дуг или с использованием дерева фрагментов — потребуют рассмотрения всех дуг межблочной передачи управления, а не только „новых".)

Рис. 1

При реализации подпрограммы по алгоритму линейного (унарного) поиска время поиска дуги (проверка vk = (а,, а у ) е V с выдачей номера дуги к) занимает 25 % от общего времени построения разбиения. С целью уменьшения вычислительной сложности операции линейный поиск заменен бинарным (двоичным). Как известно [8], при бинарном поиске число выполняемых действий сокращается с O (n) до O (log n), где n в данном случае — число дуг в

обрабатываемом графе, однако требуется, чтобы исходный массив был отсортирован. При сортировке массива дуг полагается v, < Vj в том случае, если

( (vi) = анач (Vj )) л (акон (vi) < акон (vy )j_ v

v ( (v,.) * анач (vj )) л (анач (v,) < анач (vj ) ,

сравниваются номера начальных и конечных дуг v, и vj. Другими словами, порядок дуг в

массиве при сортировке определяется соотношением номеров начальных вершин или, при их совпадении, конечных вершин. На рис. 2 приведены пример исходного массива дуг (а) и результаты его сортировки (б).

Процедура сортировки выполняется три раза (для исходной параллельной граф-схемы алгоритма, после ее преобразований и для скелетного графа), это занимает всего 0,05 % от общего времени построения разбиения. Процедура поиска дуги выполняется более 300 000 раз, а ее вклад в общее время построения разбиения после замены алгоритма линейного поиска на би-

а)

б)

5 0 3 6 6 9 8 1

1 4 2 5 2 6 6 9

0 1 3 5 6 6 8 9

4 9 2 1 2 5 6 6

Рис. 2

нарный сокращается с 25 до 16 %. В результате оптимизации алгоритма поиска асимптотическая временная сложность алгоритма выделения „новых" дуг межблочной передачи

управления уменьшается с О [ы2М) до О (N21о§М), где

N — число вершин в граф-схеме алгоритма, М — число дуг. Практический выигрыш во времени синтеза разбиения — со 183 до 156 мс (снижение на 14,8 %).

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

Множество дуг межблочной передачи управления можно найти путем сопоставления вершинам алгоритма цветов. Значение цвета 0 будем приписывать вершинам, еще не размещенным по субсечениям и вершинам блока Ау; 1 — вершинам блоков разбиения, за исключением Ау; 2 — вершинам субсечения р1. При этом дугу будем считать дугой межблочной

передачи управления в том случае, если она соединяет две разноцветные вершины ненулевого цвета (рис. 3).

Рис. 3

Если необходимо выделять все дуги межблочной передачи управления, распределение цветов меняется: не распределенные по блокам вершины окрашиваются в цвет 0, вершины

блока разбиения Ак (к = 1, H, H — число блоков в разбиении) — в цвет к, а вершины субсечения р, — в цвет j.

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

// Получение множества вершин блоков разбиения без Aj — O(H*N)

Si : = 0;

for k := 1 to H do if k * j then

Si := Si U Ak;

// Раскраска вершин

for k := 1 to N do case ak of

akeSi: цвет[ак] : akePi: цвет[ак] : else

цвет[ак] := 0; end;

// Построение множества дуг межблочной передачи управления — O(M)

S := 0;

for k := 1 to M do

if (цвет[анач (vk)] * 0) л (цвет[акон^к)] * 0) л (цвет[анач (vk)] * цвет[акон (vk)]) then S := S U { k };

Асимптотическая временная сложность предложенного алгоритма составляет O (HN + N+M) ^ O (HN + M) , практическое преимущество от его использования заключается в дополнительном уменьшении времени построения разбиения с 156 до 108 мс (на 30,9 %).

В программной реализации параллельно-последовательного метода [4] вследствие применения нескольких способов подсчета интенсивности межблочных взаимодействий ряд действий повторялся. Устранение таких повторов позволило дополнительно сократить время синтеза разбиения с 108 до 46,6 мс (в 2,3 раза).

После описанной оптимизации суммарные затраты времени на выполнение различных операций с множествами (объединение, пересечение, проверка принадлежности и др.) составляют 53,4 % от общего времени синтеза разбиений. Для операций с множествами использован разработанный класс TSet [9], выполняющий необходимые операции с использованием команд SIMD-расширений, поддерживаемых процессором, на языке ассемблер. Благодаря использованию разработанного класса временные затраты дополнительно сокращаются с 46,6 до 31,9 мс (на 31,5 %).

Построение множества смежных сечений Ш [2] по имеющемуся базовому сечению Qmax заключается в последовательном нахождении u- и J-сечений. Каждое новое сечение Q,-

формируется в результате отыскания множества Su или Sd выражений системы S, удовлетворяющих условиям u- или d-подстановки, и серии последующих подстановок.

Для отыскания очередного сечения в ходе построения множеств Su или Sd выполняется Ns операций проверки конструктивного включения ^-выражений, т.е. общее число операций в ходе построения всех сечений составляет Ns Nq . Можно заметить, что каждое выра-

— O(N)

= 1; = 2;

жение S; (i = 1, Nз) в ходе построения множества смежных сечений используется однократно, чем можно воспользоваться с целью уменьшения числа проверок путем использования множества доступных выражений S + .

ЭТ := 0; S+ := з;

// Получение u-сечений

Q : Qmax ;

repeat

Su := 0; for Si e S+ do

if ( Si.£2[c] Q) then begin

Su := Su U { Si }; S+ := S+ \ { Si }; end;

for Si e Su do

Выполнить подстановку (Q, Si.R2r Si.R1);

:= U { Q };

until (Q Ф Знач); // Получение d-сечений

Q Qmax;

repeat

Sd := 0; for Si e S+ do

if ( Si.Ri[c] Q) then begin

Sd := Sd U { Si }; S+ := S+ \ { Si }; end;

for Si e Sd do

Выполнить подстановку (Q, Si.R1, Si.R2);

:= U { Q }; until (Q Ф акон);

Число проверок отношения нестрогого включения R-выражений сокращается до Ns,

что ведет к сокращению общего времени поиска разбиения с 31,9 до 24,4 мс (на 16,5 %).

В работе [10] предложены два необходимых условия отсутствия г-изоморфизма у пары

R R

R-выражений A и B , для которых производится проверка отношения нестрогого включения Ar [с]Br :

R

1) в составе представления R-выражения A в виде дерева отыскивается такой набор листьев, для которого не найден эквивалентный набор листьев в представлении R-выражения

B в виде дерева;

2) наличие более одного набора листьев в отношении неполной эквивалентности. Оба необходимых условия проверяются в ходе попарного сопоставления наборов листьев, сокращение времени проверки г-изоморфизма достигается за счет раннего выявления отсутствия

г-изоморфности пары ^-выражений. Добавление проверки необходимых условий в программную реализацию параллельно-последовательного метода в совокупности со сравнением числа узлов в рассматриваемых деревьях ведет к уменьшению общего времени синтеза разбиения с 27,4 до 24,2 мс (на 11,7 %).

В работах [10, 11] предложен итеративный алгоритм (точнее, две его модификации, ориентированные на аппаратную и программную реализацию) выяснения отношения нестрогого включения ^-выражений на основе распространения отношения эквивалентности в представлении ^-выражений в виде деревьев снизу-вверх (от наборов листьев к корню). Как показало тестирование, использование этого алгоритма вместо алгоритма рекуррентного сравнения поддеревьев с совпадающими оценками [12] приводит к снижению времени синтеза разбиения с 24,2 до 21,4 мс (на 11,6 %).

Выделение базового сечения на основе системы выражений 5 заключается в попарном выборе выражений и 8у, г, j = 1, N5 с целью выполнения и- или ^-постановки. После подстановки число N5 выражений системы 5 сокращается на один, для оставшихся выражений

снова производится попарное сопоставление и т.д. Указанные действия продолжаются до тех пор, пока число выражений в системе 5 не станет равно двум. Число операций проверки отношения нестрогого включения при этом составляет в худшем случае

O (Ns (Ns -1) (JVa -2)) - O (NS)

попарные число ^ сопоставления подстановок J

iНе можете найти то, что вам нужно? Попробуйте сервис подбора литературы.

Если на i-м шаге работы алгоритма для пары выражений Sj и Sj невозможно выполнить ни u-, ни ^-подстановку и они не участвуют на i-м шаге в подстановке с использованием других выражений, то на (i +1) -м шаге подстановка для пары выражений Sj и Sj по-прежнему не будет невозможна. Указанной особенностью можно воспользоваться, сохранив в специальной матрице Ms информацию о предыдущих неудачных попытках подстановки для экономии вычислительного времени. При этом на каждом шаге алгоритма, кроме первого, вместо N1 (N1 -1) производится Ns -1 сопоставлений для выражения Sk, полученного в ходе выполнения подстановки на i-м шаге, что сокращает число операций подстановки до O ((-Ns -1) (Ns - 2)) - O (n1 ), а общее время синтеза разбиения с 21,4 до 19,4 мс (на 9,4 %).

Таким образом, описанные шаги программной алгоритмической оптимизации позволяют сократить затраты времени вычислений с 183 до 21,4 мс, т.е. в 8,6 раза (в 30 раз с учетом оптимизаций, описанных в статье [5]), что дает существенную экономию вычислительного времени при выполнении эксперимента по сравнению методов синтеза разбиений с использованием добровольных распределенных вычислений [13].

Работа выполнена в рамках программы „Научные и научно-педагогические кадры инновационной России на 2009—2013 годы" (проект 14.B37.21.0598 „Теоретические основы и методы использования распределенных и высокопроизводительных вычислительных систем для решения дискретных оптимизационных задач").

список литературы

1. Емельянов С. Г., Зотов И. В., Титов В. С. Архитектура параллельных логических мультиконтроллеров. М.: Высш. школа, 2009. 233 с.

2. Ватутин Э. И. Проектирование логических мультиконтроллеров. Синтез разбиений параллельных граф-схем алгоритмов. Saarbrücken: Lambert Academic Publishing, 2011. 292 с.

3. Ватутин Э. И., Зотов И. В. Метод формирования субоптимальных разбиений параллельных управляющих алгоритмов // Параллельные вычисления и задачи управления (PACO'04). М.: Ин-т проблем управления им. В. А. Трапезникова РАН, 2004. С. 884—917.

4. Ватутин Э. И., Зотов И. В. Параллельно-последовательный метод формирования субоптимальных разбиений параллельных управляющих алгоритмов. Свидетельство об официальной регистрации программы для ЭВМ № 2005613091 от 28.11.05.

5. Ватутин Э. И. Анализ эффективности и программная оптимизация методов синтеза разбиений параллельных алгоритмов логического управления в среде PAE // Изв. ЮЗГУ. Серия „Управление, вычислительная техника, информатика. Медицинское приборостроение". № 2. Ч. 1. С. 191—195.

6. Ватутин Э. И., Волобуев С. В., Зотов И. В. Комплексный сравнительный анализ качества разбиений при синтезе логических мультиконтроллеров в условиях присутствия технологических ограничений // Тр. 4-й Междунар. конф. „Параллельные вычисления и задачи управления" PAC0'08. М.: Ин-т проблем управления им. В. А. Трапезникова РАН, 2008. С. 643—685.

7. Ватутин Э. И. Проблема оценки интенсивности межблочного взаимодействия в задаче нахождения субоптимальных разбиений параллельных управляющих алгоритмов // III Междунар. студенческий фестиваль „Образование, наука, производство". Белгород, 2006.

8. [Электронный ресурс]: <Шр://т.-дак1ре&а.о^/^1к1/Двоичный_поиск>

9. Ватутин Э. И. Библиотека классов обработки множеств с SIMD-оптимизацией. Свидетельство об официальной регистрации программы для ЭВМ № 2007614221 от 03.08.07.

10. Ватутин Э. И., Зотов И. В., Титов В. С. Алгоритм и устройство выявления изоморфных вхождений R-выражений при построении множества сечений параллельных алгоритмов логического управления // Изв. вузов. Приборостроение. 2009. Т. 52, № 2. С. 37—45.

11. Ватутин Э. И., Зотов И. В., Титов В. С. Выявление изоморфных вхождений R-выражений при построении множества сечений параллельных алгоритмов логического управления // Информационно-измерительные и управляющие системы. 2009. Т. 7, № 11. С. 49—56.

12. Ватутин Э. И., Зотов И. В. Поиск базового сечения в задаче разбиения параллельных алгоритмов. Курск: КГТУ, 2003. 30 с. Рук. деп. в ВИНИТИ 24.11.03 № 2036-B2003.

13. Ватутин Э. И., Титов В. С. Использование добровольных распределенных вычислений на платформе BOINC для анализа качества разбиений граф-схем параллельных алгоритмов // Параллельные вычисления и задачи управления (PACO'12). М.: ИПУ РАН, 2012. С. 37—54.

Сведения об авторах

Эдуард Игоревич Ватутин — канд. техн. наук, доцент; Юго-Западный государственный университет,

кафедра вычислительной техники, Курск; E-mail: evatutin@rambler.ru

Виталий Семенович Титов — д-р техн. наук, профессор; Юго-Западный государственный университет,

кафедра вычислительной техники, Курск; заведующий кафедрой; E-mail: titov-kstu @rambler.ru

Рекомендована Юго-Западным Поступила в редакцию

государственным университетом 18.02.13 г.

i Надоели баннеры? Вы всегда можете отключить рекламу.