समानांतर रैंडम एक्सेस मशीनें
Parallel Random Access Machines (PRAM)एक मॉडल है, जिसे अधिकांश समानांतर एल्गोरिदम के लिए माना जाता है। यहां, कई प्रोसेसर मेमोरी के सिंगल ब्लॉक से जुड़े होते हैं। एक PRAM मॉडल में शामिल हैं -
इसी प्रकार के प्रोसेसर का एक सेट।
सभी प्रोसेसर एक सामान्य मेमोरी यूनिट साझा करते हैं। प्रोसेसर केवल साझा मेमोरी के माध्यम से आपस में संवाद कर सकते हैं।
एक मेमोरी एक्सेस यूनिट (MAU) प्रोसेसर को एकल साझा मेमोरी के साथ जोड़ती है।
यहाँ, n प्रोसेसर की संख्या पर स्वतंत्र संचालन कर सकते हैं nसमय की एक विशेष इकाई में डेटा की संख्या। इसके परिणामस्वरूप विभिन्न प्रोसेसरों द्वारा एक ही मेमोरी लोकेशन का एक साथ उपयोग किया जा सकता है।
इस समस्या को हल करने के लिए, PRAM मॉडल पर निम्नलिखित बाधाओं को लागू किया गया है -
Exclusive Read Exclusive Write (EREW) - यहां किसी भी दो प्रोसेसर को एक ही समय में एक ही मेमोरी लोकेशन से पढ़ने या लिखने की अनुमति नहीं है।
Exclusive Read Concurrent Write (ERCW) - यहां किसी भी दो प्रोसेसर को एक ही मेमोरी लोकेशन से एक ही समय में पढ़ने की अनुमति नहीं है, लेकिन एक ही समय में एक ही मेमोरी लोकेशन पर लिखने की अनुमति है।
Concurrent Read Exclusive Write (CREW) - यहां सभी प्रोसेसरों को एक ही मेमोरी लोकेशन से एक ही समय में पढ़ने की अनुमति है, लेकिन एक ही समय में एक ही मेमोरी लोकेशन पर लिखने की अनुमति नहीं है।
Concurrent Read Concurrent Write (CRCW) - सभी प्रोसेसर को एक ही समय में एक ही मेमोरी स्थान से पढ़ने या लिखने की अनुमति है।
PRAM मॉडल को लागू करने के कई तरीके हैं, लेकिन सबसे प्रमुख हैं -
- साझा स्मृति मॉडल
- संदेश पासिंग मॉडल
- डेटा समानांतर मॉडल
साझा स्मृति मॉडल
साझा मेमोरी पर जोर दिया गया है control parallelism की तुलना में data parallelism। साझा मेमोरी मॉडल में, कई प्रोसेस अलग-अलग प्रोसेसर पर स्वतंत्र रूप से निष्पादित होते हैं, लेकिन वे एक आम मेमोरी स्पेस साझा करते हैं। किसी भी प्रोसेसर गतिविधि के कारण, यदि किसी मेमोरी स्थान में कोई परिवर्तन होता है, तो यह बाकी प्रोसेसर के लिए दिखाई देता है।
जैसा कि कई प्रोसेसर एक ही मेमोरी लोकेशन तक पहुंचते हैं, ऐसा हो सकता है कि किसी विशेष समय पर, एक से अधिक प्रोसेसर एक ही मेमोरी लोकेशन तक पहुंच रहे हों। मान लीजिए कि कोई उस स्थान को पढ़ रहा है और दूसरा उस स्थान पर लिख रहा है। यह भ्रम पैदा कर सकता है। इससे बचने के लिए, कुछ नियंत्रण तंत्र, जैसेlock / semaphore, आपसी बहिष्कार सुनिश्चित करने के लिए लागू किया गया है।
साझा मेमोरी प्रोग्रामिंग निम्नलिखित में लागू की गई है -
Thread libraries- थ्रेड लाइब्रेरी नियंत्रण के कई थ्रेड्स की अनुमति देता है जो समान मेमोरी लोकेशन में समवर्ती रूप से चलते हैं। थ्रेड लाइब्रेरी एक इंटरफ़ेस प्रदान करता है जो सबरूटीन की लाइब्रेरी के माध्यम से मल्टीथ्रेडिंग का समर्थन करता है। इसमें सबरूटीन होते हैं
- धागे बनाना और नष्ट करना
- धागे का समयबद्ध निष्पादन
- धागे के बीच डेटा और संदेश पारित करना
- धागा संदर्भों को सहेजना और पुनर्स्थापित करना
थ्रेड पुस्तकालयों के उदाहरणों में शामिल हैं - सोलारिस के लिए सोलारिसटीएम थ्रेड्स, लिनक्स में लागू किए गए पॉसिक्स थ्रेड्स, विंडोज एनटी और विंडोज 2000 में उपलब्ध विन्डोज़ थ्रेड्स, और जावाटीएम थ्रेड्स मानक जावाटीएम डेवलपमेंट किट (जेडडीके) के हिस्से के रूप में।
Distributed Shared Memory (DSM) Systems- डीएसएम सिस्टम हार्डवेयर समर्थन के बिना साझा मेमोरी प्रोग्रामिंग को लागू करने के लिए शिथिल युग्मित वास्तुकला पर साझा स्मृति का एक अमूर्त निर्माण करते हैं। वे मानक पुस्तकालयों को लागू करते हैं और आधुनिक ऑपरेटिंग सिस्टम में मौजूद उन्नत उपयोगकर्ता-स्तरीय मेमोरी प्रबंधन सुविधाओं का उपयोग करते हैं। उदाहरणों में ट्रेड मार्क सिस्टम, मुनिन, आईवीवाई, शास्ता, ब्रेज़ोस और कश्मीरी शामिल हैं।
Program Annotation Packages- यह समान मेमोरी एक्सेस विशेषताओं वाले आर्किटेक्चर पर लागू किया गया है। प्रोग्राम एनोटेशन पैकेज का सबसे उल्लेखनीय उदाहरण OpenMP है। OpenMP कार्यात्मक समानता को लागू करता है। यह मुख्य रूप से छोरों के समानांतरकरण पर केंद्रित है।
साझा मेमोरी की अवधारणा साझा मेमोरी सिस्टम का निम्न-स्तरीय नियंत्रण प्रदान करती है, लेकिन यह थकाऊ और गलत है। यह एप्लिकेशन प्रोग्रामिंग की तुलना में सिस्टम प्रोग्रामिंग के लिए अधिक लागू है।
साझा मेमोरी प्रोग्रामिंग के गुण
ग्लोबल एड्रेस स्पेस मेमोरी के लिए उपयोगकर्ता के अनुकूल प्रोग्रामिंग दृष्टिकोण देता है।
सीपीयू में मेमोरी की निकटता के कारण, प्रक्रियाओं के बीच डेटा साझाकरण तेज और समान है।
प्रक्रियाओं के बीच डेटा के संचार को स्पष्ट रूप से निर्दिष्ट करने की आवश्यकता नहीं है।
प्रक्रिया-संचार ओवरहेड नगण्य है।
इसे सीखना बहुत आसान है।
साझा मेमोरी प्रोग्रामिंग के लाभ
- यह पोर्टेबल नहीं है।
- डेटा इलाके का प्रबंधन करना बहुत मुश्किल है।
संदेश पासिंग मॉडल
संदेश का वितरण वितरित मेमोरी सिस्टम में सबसे अधिक इस्तेमाल किया जाने वाला समानांतर प्रोग्रामिंग दृष्टिकोण है। यहां, प्रोग्रामर को समानता का निर्धारण करना होगा। इस मॉडल में, सभी प्रोसेसर की अपनी स्थानीय मेमोरी यूनिट होती है और वे संचार नेटवर्क के माध्यम से डेटा का आदान-प्रदान करते हैं।
प्रोसेसर आपस में संचार के लिए संदेश-पासिंग लाइब्रेरी का उपयोग करते हैं। भेजे जा रहे डेटा के साथ, संदेश में निम्नलिखित घटक शामिल हैं -
प्रोसेसर का पता जिससे संदेश भेजा जा रहा है;
भेजने वाले प्रोसेसर में डेटा की मेमोरी लोकेशन का पता शुरू करना;
डेटा भेजने का डेटा प्रकार;
भेजने वाले डेटा का डेटा आकार;
प्रोसेसर का पता जिस पर संदेश भेजा जा रहा है;
प्राप्त करने वाले प्रोसेसर में डेटा के लिए स्मृति स्थान का पता शुरू करना।
प्रोसेसर निम्नलिखित तरीकों में से किसी भी एक दूसरे के साथ संवाद कर सकते हैं -
- बिंदु से बिंदु संचार
- सामूहिक संचार
- संदेश पासिंग इंटरफ़ेस
बिंदु से बिंदु संचार
पॉइंट-टू-पॉइंट संचार संदेश पास करने का सबसे सरल रूप है। यहां, संदेश भेजने वाले प्रोसेसर से एक संदेश प्राप्त करने वाले प्रोसेसर को निम्नलिखित में से किसी भी स्थानांतरण मोड से भेजा जा सकता है -
Synchronous mode - अगला संदेश केवल एक पुष्टिकरण प्राप्त होने के बाद भेजा जाता है कि संदेश के अनुक्रम को बनाए रखने के लिए इसका पिछला संदेश दिया गया है।
Asynchronous mode - अगला संदेश भेजने के लिए, पिछले संदेश की डिलीवरी की पुष्टि की आवश्यकता नहीं है।
सामूहिक संचार
सामूहिक संचार में संदेश पारित करने के लिए दो से अधिक प्रोसेसर शामिल हैं। निम्नलिखित मोड सामूहिक संचार की अनुमति देते हैं -
Barrier - बैरियर मोड संभव है अगर संचार में शामिल सभी प्रोसेसर एक विशेष बॉक (जिसे ज्ञात हो barrier block) संदेश पारित करने के लिए।
Broadcast - प्रसारण दो प्रकार का होता है -
One-to-all - यहाँ, एक सिंगल ऑपरेशन वाला एक प्रोसेसर अन्य सभी प्रोसेसर को एक ही संदेश भेजता है।
All-to-all - यहां, सभी प्रोसेसर अन्य सभी प्रोसेसर को संदेश भेजते हैं।
प्रसारित संदेश तीन प्रकार के हो सकते हैं -
Personalized - अद्वितीय संदेश सभी अन्य गंतव्य प्रोसेसर को भेजे जाते हैं।
Non-personalized - सभी गंतव्य प्रोसेसर एक ही संदेश प्राप्त करते हैं।
Reduction - प्रसारण को कम करने में, समूह का एक प्रोसेसर समूह के अन्य सभी प्रोसेसर से सभी संदेशों को एकत्र करता है और उन्हें एक एकल संदेश के साथ जोड़ देता है जिसे समूह के सभी अन्य प्रोसेसर एक्सेस कर सकते हैं।
संदेश पास करने का गुण
- समानता के निम्न-स्तरीय नियंत्रण प्रदान करता है;
- यह पोर्टेबल है;
- कम त्रुटि वाले प्रवण;
- समानांतर सिंक्रनाइज़ेशन और डेटा वितरण में कम ओवरहेड।
संदेश पासिंग के लाभ
समानांतर साझा-मेमोरी कोड की तुलना में, संदेश-पासिंग कोड को आमतौर पर अधिक सॉफ्टवेयर ओवरहेड की आवश्यकता होती है।
संदेश पासिंग लाइब्रेरी
कई संदेश-पासिंग लाइब्रेरी हैं। यहां, हम दो सबसे अधिक उपयोग किए जाने वाले संदेश-पुस्तकालयों पर चर्चा करेंगे -
- संदेश पासिंग इंटरफ़ेस (MPI)
- समानांतर वर्चुअल मशीन (PVM)
संदेश पासिंग इंटरफ़ेस (MPI)
यह वितरित मेमोरी सिस्टम में सभी समवर्ती प्रक्रियाओं के बीच संचार प्रदान करने के लिए एक सार्वभौमिक मानक है। आमतौर पर उपयोग किए जाने वाले समानांतर कंप्यूटिंग प्लेटफार्मों में से अधिकांश संदेश पासिंग इंटरफ़ेस का कम से कम एक कार्यान्वयन प्रदान करते हैं। इसे पूर्वनिर्धारित कार्यों के संग्रह के रूप में लागू किया गया हैlibrary और C, C ++, फोरट्रान, इत्यादि भाषाओं से कॉल किया जा सकता है। MPIs अन्य संदेश पासिंग लाइब्रेरी की तुलना में तेज और पोर्टेबल दोनों हैं।
Merits of Message Passing Interface
केवल साझा मेमोरी आर्किटेक्चर या वितरित मेमोरी आर्किटेक्चर पर चलता है;
प्रत्येक प्रोसेसर के अपने स्थानीय चर होते हैं;
बड़े साझा मेमोरी कंप्यूटर की तुलना में, वितरित मेमोरी कंप्यूटर कम महंगे हैं।
Demerits of Message Passing Interface
- समानांतर एल्गोरिथ्म के लिए अधिक प्रोग्रामिंग परिवर्तन आवश्यक हैं;
- कभी-कभी डिबग करना मुश्किल होता है; तथा
- नोड्स के बीच संचार नेटवर्क में अच्छा प्रदर्शन नहीं करता है।
समानांतर वर्चुअल मशीन (PVM)
PVM एक पोर्टेबल मैसेज पासिंग सिस्टम है, जो एक ही वर्चुअल मशीन बनाने के लिए अलग-अलग विषम होस्ट मशीनों को जोड़ने के लिए डिज़ाइन किया गया है। यह एकल प्रबंधनीय समानांतर कंप्यूटिंग संसाधन है। सुपरकंडक्टिविटी अध्ययन, आणविक गतिशीलता सिमुलेशन और मैट्रिक्स एल्गोरिदम जैसी बड़ी कम्प्यूटेशनल समस्याओं को कई कंप्यूटरों की मेमोरी और कुल शक्ति का उपयोग करके अधिक लागत को प्रभावी ढंग से हल किया जा सकता है। यह असंगत कंप्यूटर आर्किटेक्चर के नेटवर्क में सभी संदेश रूटिंग, डेटा रूपांतरण, कार्य शेड्यूलिंग का प्रबंधन करता है।
Features of PVM
- स्थापित करने और कॉन्फ़िगर करने में बहुत आसान;
- एकाधिक उपयोगकर्ता एक ही समय में पीवीएम का उपयोग कर सकते हैं;
- एक उपयोगकर्ता कई अनुप्रयोगों को निष्पादित कर सकता है;
- यह एक छोटा पैकेज है;
- सी, सी ++, फोरट्रान का समर्थन करता है;
- पीवीएम कार्यक्रम के दिए गए रन के लिए, उपयोगकर्ता मशीनों के समूह का चयन कर सकते हैं;
- यह एक संदेश-पासिंग मॉडल है,
- प्रक्रिया-आधारित संगणना;
- विषम वास्तुकला का समर्थन करता है।
डेटा समानांतर प्रोग्रामिंग
डेटा समानांतर प्रोग्रामिंग मॉडल का प्रमुख फोकस एक साथ सेट किए गए डेटा पर संचालन करने पर है। डेटा सेट को कुछ संरचना में व्यवस्थित किया जाता है जैसे कि सरणी, हाइपरक्यूब, आदि। प्रोसेसर समान डेटा संरचना पर सामूहिक रूप से संचालन करते हैं। प्रत्येक कार्य एक ही डेटा संरचना के एक अलग विभाजन पर किया जाता है।
यह प्रतिबंधात्मक है, क्योंकि सभी एल्गोरिदम को डेटा समानता के संदर्भ में निर्दिष्ट नहीं किया जा सकता है। यही कारण है कि डेटा समानता सार्वभौमिक नहीं है।
डेटा समानांतर भाषाएं प्रोसेसर को डेटा अपघटन और मैपिंग को निर्दिष्ट करने में मदद करती हैं। इसमें डेटा वितरण स्टेटमेंट भी शामिल है जो प्रोग्रामर को डेटा पर नियंत्रण रखने की अनुमति देता है - उदाहरण के लिए, कौन सा डेटा किस प्रोसेसर पर जाएगा - प्रोसेसर के भीतर संचार की मात्रा को कम करने के लिए।