Программирование на JAVA

Навигация

Технология Hyper-Threading от Intel

Производительности всегда мало

0 1

Hyper-Threading

2 3

Углубляемся в технологию

4 5

Максимум эффективности от Hyper-Threading

6 7

Архитектура IA-64

8 9

Архитектура Е2К

10 11 12 13 14 15

Большие компьютерные системы

Виды параллельной обработки

16 17 18 19 20 21 22

Матричная обработка данных

23 24 25 26

Архитектура мультипроцессорных систем общего назначения

27 28 29

Коммуникационные сети

30 31 32 33 34 35 36 37 38 39 40 41 42 43

Организация памяти в мультипроцессорных системах

44 45 46

Программный параллелизм и общие переменные

47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62

Мультикомпьютерные системы

63 64 65

Общая память и передача сообщений

66 67 68 69 70 71 72 73 74

Производительность мультипроцессорных систем

75 76 77 78 79 80 81 82

Использование технологии параллельного программирования MPI-2

Введение

83 84 85

Кластерные системы и стандарт параллельного программирования MPI

86 87 88 89 90 91 92 93 94 95 96 97 98 99

Математические проблемы параллельных вычислений

100 101 102 103 104 105 106 107 108 109 110 111 112 113 114 115 116 117 118 119 120 121 122

Реклама :




read temparray [1...N/2] from vector_a

send (temparray[l...N/2],l)

read b[l...N/2] from vectorjb

read temparray [1...N/2] from vector_b

send (temparray[l...N/2],l)

else receive (a(l...N/2], 0)

receive (b(l...N/2], 0)

end

dot_product :=0

do_dot(a, b)

 if (id=0) send (dot_product, 0)

else receive (temp, 1)

dot_product := dot_product + temp

print dot_product

end

do_dot (integer array x[l...N/2], integer array y[l...N/2])

for k := 1 to N/2

dot_product := dot_product + x[k]*y[k]

end

end

Рис. 10.18. Программа с передачей сообщений для вычисления скалярного произведения векторов на двух процессорах

Далее процедура do_dot просто вычисляет скалярное произведение N/2 эле­ментов. Граничные значения цикла для обоих процессоров одинаковы, так как ка­ждый использует данные из собственной памяти. Функция передачи сообщений иллюстрируется еще одним действием, выполняемым, когда процессор заверша­ет процедуру do_dot. Чтобы программа с идентификатором 0 могла вычислить и напечатать результирующее скалярное произведение, программа с идентификато­ром 1 должна прислать ей свое скалярное произведение. Программа с идентифи­катором 0 принимает его во временный буфер temp.


<< назад вперед >>