समानांतर एल्गोरिदम - विश्लेषण
एक एल्गोरिथ्म का विश्लेषण हमें यह निर्धारित करने में मदद करता है कि एल्गोरिथ्म उपयोगी है या नहीं। आमतौर पर, एक एल्गोरिथ्म का विश्लेषण उसके निष्पादन समय के आधार पर किया जाता है(Time Complexity) और अंतरिक्ष की मात्रा (Space Complexity) इसकी जरूरत है।
चूँकि हमारे पास परिष्कृत मेमोरी डिवाइस उचित कीमत पर उपलब्ध हैं, इसलिए भंडारण स्थान अब कोई समस्या नहीं है। इसलिए, अंतरिक्ष जटिलता को इतना महत्व नहीं दिया जाता है।
समानांतर एल्गोरिदम को कंप्यूटर की गणना की गति में सुधार करने के लिए डिज़ाइन किया गया है। समानांतर एल्गोरिदम का विश्लेषण करने के लिए, हम आम तौर पर निम्नलिखित मापदंडों पर विचार करते हैं -
- समय जटिलता (निष्पादन समय),
- उपयोग किए गए प्रोसेसर की कुल संख्या, और
- कुल लागत।
समय जटिलता
समानांतर एल्गोरिदम विकसित करने के पीछे मुख्य कारण एक एल्गोरिथ्म की गणना समय को कम करना था। इस प्रकार, एल्गोरिथ्म के निष्पादन समय का मूल्यांकन करना इसकी दक्षता का विश्लेषण करने में अत्यंत महत्वपूर्ण है।
किसी समस्या को हल करने के लिए एल्गोरिथ्म द्वारा लिए गए समय के आधार पर निष्पादन का समय मापा जाता है। कुल निष्पादन समय की गणना उस क्षण से की जाती है जब एल्गोरिथ्म उस क्षण को निष्पादित करना शुरू कर देता है जो इसे बंद कर देता है। यदि सभी प्रोसेसर एक ही समय में निष्पादन शुरू या समाप्त नहीं करते हैं, तो एल्गोरिथ्म का कुल निष्पादन समय वह क्षण होता है जब पहले प्रोसेसर ने उस क्षण के लिए अपना निष्पादन शुरू किया था जब अंतिम प्रोसेसर अपना निष्पादन रोक देता है।
एक एल्गोरिथ्म की समय जटिलता को तीन श्रेणियों में वर्गीकृत किया जा सकता है
Worst-case complexity - जब किसी दिए गए इनपुट के लिए एल्गोरिदम द्वारा आवश्यक समय की मात्रा होती है maximum।
Average-case complexity - जब किसी दिए गए इनपुट के लिए एल्गोरिदम द्वारा आवश्यक समय की मात्रा होती है average।
Best-case complexity - जब किसी दिए गए इनपुट के लिए एल्गोरिदम द्वारा आवश्यक समय की मात्रा होती है minimum।
असममित विश्लेषण
एक एल्गोरिथ्म की जटिलता या दक्षता वांछित आउटपुट प्राप्त करने के लिए एल्गोरिदम द्वारा निष्पादित चरणों की संख्या है। अपने सैद्धांतिक विश्लेषण में एक एल्गोरिथ्म की जटिलता की गणना करने के लिए असममित विश्लेषण किया जाता है। असममित विश्लेषण में, एल्गोरिथ्म की जटिलता फ़ंक्शन की गणना करने के लिए इनपुट की एक बड़ी लंबाई का उपयोग किया जाता है।
Note - Asymptoticएक ऐसी स्थिति है जहां एक रेखा वक्र से मिलने के लिए झुकती है, लेकिन वे प्रतिच्छेद नहीं करती हैं। यहाँ रेखा और वक्र एक दूसरे के लिए विषम है।
गति के लिए उच्च सीमा और कम सीमा का उपयोग करके एल्गोरिथ्म के लिए सबसे तेज़ और सबसे संभव निष्पादन समय का वर्णन करने का सबसे आसान तरीका एसिम्पोटिक है। इसके लिए, हम निम्नलिखित सूचनाओं का उपयोग करते हैं -
- बिग ओ संकेतन
- ओमेगा संकेतन
- थीटा संकेतन
बिग ओ संकेतन
गणित में, बिग ओ अंकन का उपयोग कार्यों की स्पर्शोन्मुख विशेषताओं का प्रतिनिधित्व करने के लिए किया जाता है। यह एक सरल और सटीक विधि में बड़े इनपुट के लिए एक फ़ंक्शन के व्यवहार का प्रतिनिधित्व करता है। यह एक एल्गोरिथ्म के निष्पादन समय के ऊपरी हिस्से का प्रतिनिधित्व करने की एक विधि है। यह उस समय की सबसे लंबी मात्रा का प्रतिनिधित्व करता है जिसे एल्गोरिथ्म अपने निष्पादन को पूरा करने में ले सकता है। समारोह -
f (n) = O (g (n))
अगर वहाँ सकारात्मक स्थिरांक मौजूद है c तथा n0 ऐसा है कि f(n) ≤ c * g(n) सबके लिए n कहाँ पे n ≥ n0।
ओमेगा संकेतन
ओमेगा संकेतन एक एल्गोरिथ्म के निष्पादन समय के निचले हिस्से का प्रतिनिधित्व करने की एक विधि है। समारोह -
f (n) = Ω (g (n))
अगर वहाँ सकारात्मक स्थिरांक मौजूद है c तथा n0 ऐसा है कि f(n) ≥ c * g(n) सबके लिए n कहाँ पे n ≥ n0।
थीटा संकेतन
थीटा अंकन एक एल्गोरिथम के निष्पादन समय के निचले बाउंड और ऊपरी बाउंड दोनों का प्रतिनिधित्व करने की एक विधि है। समारोह -
f (n) = θ (g (n))
अगर वहाँ सकारात्मक स्थिरांक मौजूद है c1, c2, तथा n0 ऐसे कि c1 * g (n) c f (n) * c2 * g (n) सभी के लिए n कहाँ पे n ≥ n0।
एक एल्गोरिथ्म का स्पीडअप
एक समानांतर एल्गोरिदम का प्रदर्शन इसकी गणना करके निर्धारित किया जाता है speedup। स्पीडअप को समानांतर एल्गोरिथम के सबसे खराब-निष्पादन निष्पादन समय के लिए किसी विशेष समस्या के लिए सबसे तेजी से ज्ञात अनुक्रमिक एल्गोरिदम के सबसे खराब-निष्पादन निष्पादन समय के अनुपात के रूप में परिभाषित किया गया है।
प्रयुक्त प्रोसेसर की संख्या
उपयोग किए जाने वाले प्रोसेसर की संख्या समानांतर एल्गोरिथम की दक्षता का विश्लेषण करने के लिए एक महत्वपूर्ण कारक है। कंप्यूटर खरीदने, बनाए रखने और चलाने की लागत की गणना की जाती है। किसी समस्या को हल करने के लिए एल्गोरिथ्म द्वारा उपयोग किए जाने वाले प्रोसेसर की संख्या से अधिक, अधिक महंगा परिणाम प्राप्त होता है।
कुल लागत
एक समानांतर एल्गोरिदम की कुल लागत समय की जटिलता और उस विशेष एल्गोरिथ्म में उपयोग किए जाने वाले प्रोसेसर की संख्या है।
कुल लागत = समय जटिलता × प्रयुक्त प्रोसेसर की संख्या
इसलिए efficiency एक समानांतर एल्गोरिथ्म का है -