Algoritma Paralel - Perkalian Matriks
Matriks adalah sekumpulan data numerik dan non-numerik yang disusun dalam jumlah baris dan kolom yang tetap. Perkalian matriks merupakan desain perkalian penting dalam komputasi paralel. Di sini kita akan membahas implementasi perkalian matriks pada berbagai jaringan komunikasi seperti mesh dan hypercube. Mesh dan hypercube memiliki konektivitas jaringan yang lebih tinggi, sehingga memungkinkan algoritme yang lebih cepat daripada jaringan lain seperti jaringan ring.
Jaringan Mesh
Topologi dimana sekumpulan node membentuk grid berdimensi-p disebut topologi mesh. Di sini, semua tepi sejajar dengan sumbu kisi dan semua node yang berdekatan dapat berkomunikasi satu sama lain.
Jumlah total node = (jumlah node dalam baris) × (jumlah node dalam kolom)
Jaringan mesh dapat dievaluasi menggunakan faktor-faktor berikut -
- Diameter
- Lebar biseksi
Diameter - Dalam jaringan mesh, terpanjang distanceantara dua node adalah diameternya. Memiliki jaringan mesh berdimensi-pkP node memiliki diameter p(k–1).
Bisection width - Lebar biseksi adalah jumlah minimum tepi yang perlu dikeluarkan dari jaringan untuk membagi jaringan mata jaring menjadi dua bagian.
Perkalian Matriks Menggunakan Jaringan Mesh
Kami telah mempertimbangkan model SIMD jaringan mesh 2D yang memiliki koneksi sampul. Kami akan merancang algoritma untuk mengalikan dua array n × n menggunakan n 2 prosesor dalam jumlah waktu tertentu.
Matriks A dan B masing-masing memiliki unsur a ij dan b ij . Elemen pemrosesan PE ij mewakili a ij dan b ij . Susunlah matriks A dan B sedemikian rupa sehingga setiap prosesor memiliki sepasang elemen untuk dikalikan. Unsur-unsur matriks A akan bergerak ke arah kiri dan unsur-unsur matriks B akan bergerak ke arah atas. Perubahan posisi elemen dalam matriks A dan B ini menghadirkan setiap elemen pemrosesan, PE, pasangan nilai baru untuk dikalikan.
Langkah-langkah dalam Algoritma
- Buat dua matriks berbeda-beda.
- Hitung semua hasil kali, a ik × b kj
- Hitung jumlah saat langkah 2 selesai.
Algoritma
Procedure MatrixMulti
Begin
for k = 1 to n-1
for all Pij; where i and j ranges from 1 to n
ifi is greater than k then
rotate a in left direction
end if
if j is greater than k then
rotate b in the upward direction
end if
for all Pij ; where i and j lies between 1 and n
compute the product of a and b and store it in c
for k= 1 to n-1 step 1
for all Pi;j where i and j ranges from 1 to n
rotate a in left direction
rotate b in the upward direction
c=c+aXb
End
Jaringan Hypercube
Hypercube adalah konstruksi n-dimensi yang ujung-ujungnya tegak lurus satu sama lain dan memiliki panjang yang sama. Hiperkub berdimensi-n juga dikenal sebagai kubus-n atau kubus berdimensi-n.
Fitur Hypercube dengan node 2 k
- Diameter = k
- Lebar biseksi = 2 k – 1
- Jumlah tepi = k
Perkalian Matriks menggunakan Jaringan Hypercube
Spesifikasi umum jaringan Hypercube -
Membiarkan N = 2mmenjadi jumlah prosesor. Biarkan prosesor menjadi P 0, P 1 … ..P N-1 .
Misalkan i dan i b adalah dua bilangan bulat, 0 <i, i b <N-1 dan representasi binernya hanya berbeda pada posisi b, 0 <b <k – 1.
Mari kita perhatikan dua matriks n × n, matriks A dan matriks B.
Step 1- Elemen matriks A dan matriks B ditempatkan pada prosesor n 3 sedemikian sehingga prosesor pada posisi i, j, k akan memiliki a ji dan b ik .
Step 2 - Semua prosesor dalam posisi (i, j, k) menghitung produk
C (i, j, k) = A (i, j, k) × B (i, j, k)
Step 3 - Jumlah C (0, j, k) = ΣC (i, j, k) untuk 0 ≤ i ≤ n-1, dimana 0 ≤ j, k <n – 1.
Blok Matriks
Block Matrix atau matriks yang dipartisi adalah matriks yang setiap elemennya sendiri merepresentasikan matriks individual. Bagian individual ini dikenal sebagai ablock atau sub-matrix.
Contoh
Pada Gambar (a), X adalah matriks blok dimana A, B, C, D adalah matriks itu sendiri. Gambar (f) menunjukkan matriks total.
Perkalian Matriks Blok
Ketika dua matriks blok adalah matriks persegi, maka matriks tersebut dikalikan seperti kita melakukan perkalian matriks sederhana. Sebagai contoh,