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,