Algoritma Paralel - Penyortiran
Pengurutan adalah proses menyusun elemen-elemen dalam suatu kelompok dalam urutan tertentu, yaitu urutan naik, urutan turun, urutan abjad, dll. Berikut ini kita akan bahas -
- Urutan Pencacahan
- Jenis Transposisi Genap-Ganjil
- Urutan Gabungan Paralel
- Urutan Cepat Hyper
Menyortir daftar elemen adalah operasi yang sangat umum. Algoritme pengurutan berurutan mungkin tidak cukup efisien ketika kita harus mengurutkan data dalam jumlah besar. Oleh karena itu, algoritma paralel digunakan dalam pengurutan.
Urutan Pencacahan
Enumeration sort adalah metode menyusun semua elemen dalam daftar dengan mencari posisi akhir setiap elemen dalam daftar yang diurutkan. Ini dilakukan dengan membandingkan setiap elemen dengan semua elemen lainnya dan menemukan jumlah elemen yang memiliki nilai lebih kecil.
Oleh karena itu, untuk dua elemen, a i dan a j, salah satu kasus berikut harus benar -
- a i <a j
- a i > a j
- a i = a j
Algoritma
procedure ENUM_SORTING (n)
begin
for each process P1,j do
C[j] := 0;
for each process Pi, j do
if (A[i] < A[j]) or A[i] = A[j] and i < j) then
C[j] := 1;
else
C[j] := 0;
for each process P1, j do
A[C[j]] := A[j];
end ENUM_SORTING
Jenis Transposisi Genap-Ganjil
Urutan Transposisi Genap-Ganjil didasarkan pada teknik Jenis Gelembung. Ini membandingkan dua nomor yang berdekatan dan mengubahnya, jika nomor pertama lebih besar dari nomor kedua untuk mendapatkan daftar urutan naik. Kasus sebaliknya berlaku untuk rangkaian urutan turun. Jenis transposisi Genap-Ganjil beroperasi dalam dua fase -odd phase dan even phase. Dalam kedua fase tersebut, proses pertukaran nomor dengan nomor yang berdekatan di sebelah kanan.
Algoritma
procedure ODD-EVEN_PAR (n)
begin
id := process's label
for i := 1 to n do
begin
if i is odd and id is odd then
compare-exchange_min(id + 1);
else
compare-exchange_max(id - 1);
if i is even and id is even then
compare-exchange_min(id + 1);
else
compare-exchange_max(id - 1);
end for
end ODD-EVEN_PAR
Urutan Gabungan Paralel
Merge sort first membagi daftar yang tidak diurutkan menjadi sub-daftar terkecil, membandingkannya dengan daftar yang berdekatan, dan menggabungkannya dalam urutan yang diurutkan. Ini mengimplementasikan paralelisme dengan sangat baik dengan mengikuti algoritma divide and conquer.
Algoritma
procedureparallelmergesort(id, n, data, newdata)
begin
data = sequentialmergesort(data)
for dim = 1 to n
data = parallelmerge(id, dim, data)
endfor
newdata = data
end
Urutan Cepat Hyper
Hyper quick sort adalah implementasi quick sort pada hypercube. Langkah-langkahnya adalah sebagai berikut -
- Bagilah daftar yang tidak diurutkan di antara setiap node.
- Urutkan setiap node secara lokal.
- Dari node 0, siarkan nilai median.
- Pisahkan setiap daftar secara lokal, lalu tukarkan bagiannya di dimensi tertinggi.
- Ulangi langkah 3 dan 4 secara paralel hingga dimensinya mencapai 0.
Algoritma
procedure HYPERQUICKSORT (B, n)
begin
id := process’s label;
for i := 1 to d do
begin
x := pivot;
partition B into B1 and B2 such that B1 ≤ x < B2;
if ith bit is 0 then
begin
send B2 to the process along the ith communication link;
C := subsequence received along the ith communication link;
B := B1 U C;
endif
else
send B1 to the process along the ith communication link;
C := subsequence received along the ith communication link;
B := B2 U C;
end else
end for
sort B using sequential quicksort;
end HYPERQUICKSORT