समानांतर एल्गोरिदम - सॉर्टिंग
सॉर्टिंग एक विशेष क्रम में एक समूह में तत्वों को व्यवस्थित करने की एक प्रक्रिया है, अर्थात, आरोही क्रम, अवरोही क्रम, वर्णमाला क्रम, आदि। यहां हम निम्नलिखित पर चर्चा करेंगे -
- गणन क्रमबद्ध करें
- ऑड-इवन ट्रांसपोज़िशन सॉर्ट
- समानांतर मर्ज सॉर्ट
- हाइपर क्विक सॉर्ट
तत्वों की सूची को क्रमबद्ध करना एक बहुत ही सामान्य ऑपरेशन है। अनुक्रमिक सॉर्टिंग एल्गोरिथ्म पर्याप्त कुशल नहीं हो सकता है जब हमें डेटा की एक बड़ी मात्रा को सॉर्ट करना होगा। इसलिए, समानांतर एल्गोरिदम का उपयोग छँटाई में किया जाता है।
गणन क्रमबद्ध करें
गणना प्रकार एक सूची में सभी तत्वों की अंतिम स्थिति का पता लगाकर सूची में सभी तत्वों को व्यवस्थित करने की एक विधि है। यह प्रत्येक तत्व की सभी अन्य तत्वों के साथ तुलना करके और छोटे मूल्य वाले तत्वों की संख्या का पता लगाने के द्वारा किया जाता है।
इसलिए, किसी भी दो तत्वों के लिए, i और j में से किसी एक को निम्नलिखित में से कोई एक सत्य होना चाहिए -
- एक मैं एक < j
- ए i > ए जे
- a i = a j
कलन विधि
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
ऑड-इवन ट्रांसपोज़िशन सॉर्ट
Odd-Even Transposition Sort, Bubble Sort तकनीक पर आधारित है। यह दो आसन्न संख्याओं की तुलना करता है और उन्हें स्विच करता है, यदि पहला नंबर आरोही क्रम सूची प्राप्त करने के लिए दूसरे नंबर से अधिक है। विपरीत क्रम एक अवरोही क्रम श्रृंखला के लिए लागू होता है। ऑड-इवन ट्रांसपोज़िशन सॉर्ट दो चरणों में संचालित होता है -odd phase तथा even phase। दोनों चरणों में, सही में उनके आसन्न संख्या के साथ संख्याओं का आदान-प्रदान करता है।
कलन विधि
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
समानांतर मर्ज सॉर्ट
मर्ज सॉर्ट पहले अनसुलझी सूची को सबसे छोटी संभव उप-सूचियों में विभाजित करता है, इसे आसन्न सूची के साथ तुलना करता है, और इसे क्रमबद्ध क्रम में विलय करता है। यह विभाजन का अनुसरण करके समानता को बहुत अच्छी तरह से लागू करता है और एल्गोरिथ्म को जीतता है।
कलन विधि
procedureparallelmergesort(id, n, data, newdata)
begin
data = sequentialmergesort(data)
for dim = 1 to n
data = parallelmerge(id, dim, data)
endfor
newdata = data
end
हाइपर क्विक सॉर्ट
हाइपर क्विक सॉर्ट हाइपरक्यूब पर त्वरित सॉर्ट का कार्यान्वयन है। इसके चरण इस प्रकार हैं -
- प्रत्येक नोड के बीच अनसुलझी सूची को विभाजित करें।
- प्रत्येक नोड को स्थानीय रूप से सॉर्ट करें।
- नोड 0 से, माध्य मान को प्रसारित करें।
- प्रत्येक सूची को स्थानीय रूप से विभाजित करें, फिर सबसे अधिक आयाम में हिस्सों का आदान-प्रदान करें।
- आयाम 0 तक पहुंचने तक समानांतर में चरण 3 और 4 को दोहराएं।
कलन विधि
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