Вычисление скалярных переменных
Поможем в ✍️ написании учебной работы
Поможем с курсовой, контрольной, дипломной, рефератом, отчетом по практике, научно-исследовательской и любой другой работой

 

Будем рассматривать цикл, в котором вычисляется переменная X:

 

DO I = 1, N                                                                                     (13)

X = GI(X);

 

Здесь Gi, i=1,...,N, – отображения из N-рекуррентного множества D. В частности, если GI(X)=X+A(I), то цикл (13) вычисляет сумму N чисел A(I), I=1,...,N.

Параллельное выполнение цикла (13) отличается от цикла (12) тем, что в межпроцессорных пересылках участвует меньшее количество данных. Для вычисления цикла (13) воспользуемся следующим алгоритмом:

1. В каждом ПЭ с номером k вычисляем ]N/p[ следующих суперпозиций Hk = Gk*]N/p[ о...оG(k-1)*]N/p[+1 . Это потребует (]N/p[-1)*Ta времени.

2. Пользуясь принципом сдваивания, вычисляем суперпозицию

 

               W = Hp о...оH2 оH1

 

Это потребует log2(p) шагов, на каждом из которых вычисляется одна операция суперпозиция и выполняется одна межпроцессорная пересылка отображения Hk . Для универсальных коммутаторов или для гиперкуба здесь понадобится log2(p)*(Ta+T0), а для решетки log2(p)*(Ta+T1)+T2*m* (p-1) времени (в частности, для кольцевой коммутационной сети log2(p)*(Ta+T1)+T2*(p-1) времени).

3. За 1 шаг вычисляем W(X). Это отнимет Tb времени.

4. Конец.

 

Итак, для МВС с универсальным коммутатором или с архитектурой гиперкуба время работы оценивается величиной

 

F(p) = (]N/p[ - 1)*Ta+log2(p)*(Ta+T0)+Tb

 

и оптимальное количество ПЭ равно

 

     p = N/(ln2*(1+T0/Ta)),

 

а для МВС с архитектурой m-мерной решетки

 

F(p) = (]N/p[ - 1)*Ta+log (p)*(Ta+T1)+m* (  - 1)*T2+Tb

 

и оптимальное количество ПЭ p удовлетворяет уравнению

 

p1+1/m * T2 + p * (Ta+T1)/ln(2) - N*Ta = 0 .

 

в частности, для МВС с кольцевой сетью

 

F(p) = (]N/p[ - 1)*Ta+log (p)*(Ta+T1)+(p-1)*T2+Tb

 

и оптимальное количество ПЭ равно

 

p=(-(Ta+T1)+  )/(2*T2*ln2) ~  

 

 

Остальные циклы и программы

 

Отметим, что, если цикл не содержит рекуррентностей, то независимо от вида коммуникационного устройства для его вычисления требуется времени

F(p) = ]N/p[ * Tb

При этом тело цикла может не принадлежать какому-либо N-рекуррентному множеству D.

Если же цикл имеет рекуррентную зависимость, но тело цикла не принадлежит какому-либо N-рекуррентному множеству D, то этот цикл надо вычислять последовательно, потратив времени F(p)=N*Tb+p*T0 для МВС с универсальным коммутатором и F(p)=N*Tb+p*T1 для МВС с кольцевой сетью.

Предположим, что некоторая программа имеет вид последовательности циклов

 

DO I = 1, N1

ТЕЛОЦИКЛА1

DO I = 1, N2

ТЕЛОЦИКЛА2

....................

DO I = 1, Nm

ТЕЛОЦИКЛАm

 

Тогда время работы этой программы имеет следующий характер зависимости от p.

 

F(p) = a/p+b*log2p +c*p+d                                                                 (14)

 

Вычислим производную от функции F и, приравняв ее к нулю, получим


c*p +b*p-a=0

 

Если a=0, то в тексте программы вообще нет циклов.

Если c=0, b=0 и a не равно 0, то производная от F отрицательна для всех p и, следовательно, чем больше количество используемых процессоров, тем быстрее выполнение программы. Это возможно при отсутствии каких-либо рекуррентных циклов.

Если c=0 и b не равно 0, то оптимальное количество ПЭ p=a/b. Эта ситуация возможна, если тело всякого рекуррентного цикла из текста программы принадлежит некоторому N-рекуррентному множеству D и в МВС используется коммутатор с кольцевой сетью. Отметим, что данное теоретически оптимальное значение p может превосходить максимально разумное значение.

Если c не равно 0, то оптимальное количество используемых ПЭ равно

 

p=(-b+ )/(2*c).

 

Константы a,b,c,d, входящие в формулу функции F, можно найти методом неопределенных коэффициентов, вычислив исследуемую программу для четырех различных значений p.

Случай программы с кратными циклами сводится к предыдущему.

Действительно, двойной цикл

 

DO J=1, M

DO I=1, N

ТЕЛОЦИКЛА(I,J)

 

можно рассматривать, как M циклов по I.

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

 


Дата: 2018-12-21, просмотров: 488.