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