बिटोनिक सॉर्टर

बिटोनिक मर्जसॉर्ट सॉर्टिंग के लिए एक समानांतर एल्गोरिदम है। इसका उपयोग छँटाई नेटवर्क  के निर्माण के लिए एक निर्माण विधि के रूप में भी किया जाता है। एल्गोरिथ्म  क्यों बैच  द्वारा तैयार किया गया था। परिणामी सॉर्टिंग नेटवर्क से मिलकर बनता है $$O(n\log^2(n))$$ तुलनित्र और की देरी है $$O(\log^2(n))$$, कहाँ $$n$$ क्रमबद्ध की जाने वाली वस्तुओं की संख्या है। यह इसे आर्किटेक्चर पर बड़ी संख्या में तत्वों को सॉर्ट करने के लिए एक लोकप्रिय विकल्प बनाता है जिसमें लॉकस्टेप में चलने वाली बड़ी संख्या में समानांतर निष्पादन इकाइयां शामिल होती हैं, जैसे कि एक विशिष्ट जीपीयू।

एक क्रमबद्ध अनुक्रम एक नीरस रूप से गैर-घटता (या गैर-बढ़ता) अनुक्रम है। एक बिटोनिक अनुक्रम एक अनुक्रम है $$x_0 \leq \cdots \leq x_k \geq \cdots \geq x_{n-1}$$ कुछ के लिए $$k, 0 \leq k < n$$, या ऐसे अनुक्रम का एक गोलाकार बदलाव।

जटिलता
होने देना $$p = \lfloor \log_2 n \rfloor$$ और $$q = \lceil \log_2 n \rceil$$.

निर्माण एल्गोरिदम से यह स्पष्ट है कि समानांतर तुलनाओं के राउंड की संख्या दी गई है $$q(q+1)/2$$.

यह तुलनित्रों की संख्या का अनुसरण करता है $$c$$ घिरा है $$2 ^{p-1} \cdot p (p+1) /2 \leq c \leq \lfloor {n/2} \rfloor \cdot q (q+1) /2 $$ (जो इसके लिए सटीक मान स्थापित करता है $$c$$ कब $$n$$ 2) की शक्ति है।

हालाँकि तुलनाओं की पूर्ण संख्या आम तौर पर बैचर के विषम-सम प्रकार से अधिक होती है, लेकिन बिटोनिक प्रकार में लगातार कई ऑपरेशन संदर्भ के स्थानीयता को बनाए रखते हैं, जिससे कार्यान्वयन अधिक कैश-अनुकूल और आमतौर पर व्यवहार में अधिक कुशल हो जाता है।

एल्गोरिदम कैसे काम करता है
निम्नलिखित 16 इनपुट वाला एक बिटोनिक सॉर्टिंग नेटवर्क है:

16 नंबर बाएं छोर पर इनपुट के रूप में प्रवेश करते हैं, 16 क्षैतिज तारों में से प्रत्येक के साथ स्लाइड करते हैं, और दाएं छोर पर आउटपुट पर बाहर निकलते हैं। नेटवर्क को तत्वों को क्रमबद्ध करने के लिए डिज़ाइन किया गया है, जिसमें नीचे सबसे बड़ी संख्या है।

तीर तुलनित्र हैं. जब भी दो संख्याएँ एक तीर के दोनों सिरों तक पहुँचती हैं, तो उनकी तुलना यह सुनिश्चित करने के लिए की जाती है कि तीर बड़ी संख्या की ओर इशारा करता है। यदि वे क्रम से बाहर हैं, तो उन्हें बदल दिया जाता है। रंगीन बक्से केवल चित्रण के लिए हैं और एल्गोरिदम पर उनका कोई प्रभाव नहीं पड़ता है।

प्रत्येक लाल बॉक्स की संरचना समान होती है: शीर्ष आधे में प्रत्येक इनपुट की तुलना नीचे के आधे हिस्से में संबंधित इनपुट से की जाती है, जिसमें सभी तीर नीचे (गहरा लाल) या सभी ऊपर (हल्का लाल) इंगित करते हैं। यदि इनपुट एक बिटोनिक अनुक्रम बनाता है (एक एकल गैर-घटता क्रम जिसके बाद एक एकल गैर-बढ़ता क्रम या इसके विपरीत), तो आउटपुट दो बिटोनिक अनुक्रम बनाएगा। आउटपुट का शीर्ष आधा हिस्सा बिटोनिक होगा, और निचला आधा बिटोनिक होगा, शीर्ष आधे का प्रत्येक तत्व निचले आधे के प्रत्येक तत्व (गहरे लाल के लिए) या इसके विपरीत (हल्के लाल के लिए) से कम या उसके बराबर होगा। यह प्रमेय स्पष्ट नहीं है, लेकिन Sorting_network#Zero-one_principle|zero-one सिद्धांत का उपयोग करके विभिन्न इनपुट की तुलना कैसे की जा सकती है, इसके सभी मामलों पर सावधानीपूर्वक विचार करके सत्यापित किया जा सकता है, जहां एक बिटोनिक अनुक्रम 0s और 1s का एक अनुक्रम है जिसमें शामिल है दो 10 या 01 अनुवर्ती से अधिक नहीं।

लाल डिब्बे मिलकर नीले और हरे डिब्बे बनाते हैं। ऐसे प्रत्येक बॉक्स की संरचना समान होती है: एक लाल बॉक्स पूरे इनपुट अनुक्रम पर लागू होता है, फिर परिणाम के प्रत्येक आधे हिस्से पर, फिर उनमें से प्रत्येक परिणाम के प्रत्येक आधे पर, और इसी तरह। सभी तीर नीचे की ओर (नीला) या सभी ऊपर की ओर (हरा) इंगित करते हैं। इस संरचना को तितली नेटवर्क के रूप में जाना जाता है। यदि इस बॉक्स में इनपुट बिटोनिक होता है, तो आउटपुट पूरी तरह से बढ़ते क्रम (नीला) या घटते क्रम (हरा) में सॉर्ट किया जाएगा। यदि कोई संख्या नीले या हरे बॉक्स में प्रवेश करती है, तो पहला लाल बॉक्स उसे सूची के सही आधे हिस्से में क्रमबद्ध कर देगा। फिर यह एक छोटे लाल बॉक्स से होकर गुजरेगा जो इसे उस आधे हिस्से के भीतर सूची के सही तिमाही में क्रमबद्ध करता है। यह तब तक जारी रहता है जब तक इसे बिल्कुल सही स्थिति में क्रमबद्ध नहीं कर लिया जाता। इसलिए, हरे या नीले बॉक्स का आउटपुट पूरी तरह से सॉर्ट किया जाएगा।

हरे और नीले बक्से मिलकर संपूर्ण सॉर्टिंग नेटवर्क बनाते हैं। इनपुट के किसी भी मनमाने अनुक्रम के लिए, यह उन्हें सबसे नीचे सबसे बड़े के साथ, सही ढंग से क्रमबद्ध करेगा। प्रत्येक हरे या नीले बॉक्स का आउटपुट एक क्रमबद्ध अनुक्रम होगा, इसलिए आसन्न सूचियों की प्रत्येक जोड़ी का आउटपुट बिटोनिक होगा, क्योंकि शीर्ष वाला नीला है और नीचे वाला हरा है। नीले और हरे बक्सों का प्रत्येक स्तंभ एन क्रमबद्ध अनुक्रम लेता है और उन्हें एन/2 बिटोनिक अनुक्रम बनाने के लिए जोड़े में जोड़ता है, जिसे एन/2 क्रमबद्ध अनुक्रम बनाने के लिए उस कॉलम के बक्सों द्वारा क्रमबद्ध किया जाता है। यह प्रक्रिया प्रत्येक इनपुट के साथ शुरू होती है जिसे एक तत्व की क्रमबद्ध सूची माना जाता है, और सभी कॉलमों के माध्यम से तब तक जारी रहता है जब तक कि अंतिम उन्हें एकल, क्रमबद्ध सूची में विलय नहीं कर देता। क्योंकि अंतिम चरण नीला था, इस अंतिम सूची में सबसे नीचे सबसे बड़ा तत्व होगा।

वैकल्पिक प्रतिनिधित्व
ऊपर दिए गए चित्र में प्रत्येक हरा बॉक्स, नीले बॉक्स के समान ही कार्य करता है, लेकिन विपरीत दिशा में सॉर्ट करता है। इसलिए, प्रत्येक हरे बॉक्स को एक नीले बॉक्स से बदला जा सकता है और उसके बाद एक क्रॉसओवर लगाया जा सकता है, जहां सभी तार विपरीत स्थिति में चले जाते हैं। यह सभी तीरों को एक ही दिशा इंगित करने की अनुमति देगा, लेकिन क्षैतिज रेखाओं को सीधा होने से रोकेगा। हालाँकि, एक समान क्रॉसओवर को किसी भी लाल ब्लॉक से आउटपुट के निचले आधे हिस्से के दाईं ओर रखा जा सकता है, और सॉर्ट अभी भी सही ढंग से काम करेगा, क्योंकि बिटोनिक अनुक्रम का रिवर्स अभी भी बिटोनिक है। यदि किसी लाल बॉक्स के पहले और बाद में एक क्रॉसओवर है, तो इसे आंतरिक रूप से पुन: व्यवस्थित किया जा सकता है ताकि दोनों क्रॉसओवर रद्द हो जाएं, जिससे तार फिर से सीधे हो जाएं। इसलिए, निम्नलिखित आरेख ऊपर वाले के बराबर है, जहां प्रत्येक हरा बॉक्स एक नीला और एक क्रॉसओवर बन गया है, और प्रत्येक नारंगी बॉक्स एक लाल बॉक्स है जो दो ऐसे क्रॉसओवर को अवशोषित करता है:

तीर के निशान नहीं खींचे गए हैं, क्योंकि प्रत्येक तुलनित्र एक ही दिशा में क्रमबद्ध होता है। नीले और लाल ब्लॉक पहले की तरह ही कार्य करते हैं। नारंगी ब्लॉक लाल ब्लॉक के बराबर हैं जहां अनुक्रम क्रम इसके इनपुट के निचले आधे हिस्से और इसके आउटपुट के निचले आधे हिस्से के लिए उलटा होता है। यह बिटोनिक सॉर्टिंग नेटवर्क का सबसे आम प्रतिनिधित्व है। पिछली व्याख्या के विपरीत, क्योंकि तत्व तार्किक रूप से क्रमबद्ध रहते हैं, इस प्रतिनिधित्व को गैर-शक्ति-दो मामले में विस्तारित करना आसान है (जहां प्रत्येक तुलना-और-स्वैप किसी भी मामले को अनदेखा करता है जहां बड़ा सूचकांक सीमा से बाहर है)।

उदाहरण कोड
जब सरणी की लंबाई दो की शक्ति होती है, तो बिटोनिक मर्जसॉर्ट का रिकर्सन-मुक्त कार्यान्वयन निम्नलिखित है:

यह भी देखें

 * बैचर विषम-सम मर्जसॉर्ट
 * जोड़ीवार छँटाई नेटवर्क

संदर्भ
<संदर्भ />

बाहरी संबंध

 * A discussion of this algorithm
 * Reference code at NIST
 * Tutorial with animated pictures and working code