Algoritmo parallelo - Ordinamento
L'ordinamento è un processo di disposizione degli elementi in un gruppo in un ordine particolare, cioè, ordine crescente, ordine decrescente, ordine alfabetico, ecc. Qui discuteremo quanto segue:
- Ordinamento enumerazione
- Ordinamento di trasposizione pari-dispari
- Ordinamento unione parallela
- Ordinamento iper rapido
Ordinare un elenco di elementi è un'operazione molto comune. Un algoritmo di ordinamento sequenziale potrebbe non essere abbastanza efficiente quando dobbiamo ordinare un enorme volume di dati. Pertanto, gli algoritmi paralleli vengono utilizzati nell'ordinamento.
Ordinamento enumerazione
L'ordinamento per enumerazione è un metodo per disporre tutti gli elementi in un elenco trovando la posizione finale di ogni elemento in un elenco ordinato. Viene fatto confrontando ogni elemento con tutti gli altri elementi e trovando il numero di elementi di valore inferiore.
Pertanto, per due elementi qualsiasi, a i e a j uno qualsiasi dei seguenti casi deve essere vero:
- a i <a j
- a i > a j
- a i = a j
Algoritmo
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
Ordinamento di trasposizione pari-dispari
L'ordinamento con trasposizione pari-dispari si basa sulla tecnica Bubble Sort. Confronta due numeri adiacenti e li scambia, se il primo numero è maggiore del secondo numero per ottenere un elenco in ordine crescente. Il caso opposto si applica a una serie in ordine decrescente. L'ordinamento della trasposizione pari-dispari opera in due fasi:odd phase e even phase. In entrambe le fasi, i processi scambiano numeri con il numero adiacente a destra.
Algoritmo
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
Ordinamento unione parallela
Unisci prima l'ordinamento divide l'elenco non ordinato in sotto-elenchi più piccoli possibile, lo confronta con l'elenco adiacente e lo unisce in un ordine ordinato. Implementa molto bene il parallelismo seguendo l'algoritmo divide et impera.
Algoritmo
procedureparallelmergesort(id, n, data, newdata)
begin
data = sequentialmergesort(data)
for dim = 1 to n
data = parallelmerge(id, dim, data)
endfor
newdata = data
end
Ordinamento iper rapido
L'ordinamento rapido iper è un'implementazione dell'ordinamento rapido su hypercube. I suoi passaggi sono i seguenti:
- Dividi l'elenco non ordinato tra ogni nodo.
- Ordina ogni nodo localmente.
- Dal nodo 0, trasmetti il valore mediano.
- Dividi ogni elenco a livello locale, quindi scambia le metà nella dimensione più alta.
- Ripetere i passaggi 3 e 4 in parallelo finché la dimensione non raggiunge 0.
Algoritmo
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