समानांतर कंप्यूटिंग

मुक्त ज्ञानकोश विकिपीडिया से
नेविगेशन पर जाएँ खोज पर जाएँ

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


समानांतर कंप्यूटरों को उस स्तर के अनुसार वर्गीकृत किया जा सकता है जिस स्तर पर हार्डवेयर मल्टी-कोर और मल्टी-प्रोसेसर के साथ एक सिंगल मशीन के भीतर कई प्रोसेसिंग एलिमेंट वाले कंप्यूटर का समर्थन करता है। , जबकि क्लस्टर, MPPs, और [ग्रिड कंप्यूटिंग | ग्रिड]] एक ही कार्य को करने के लिए कई कंप्यूटरों का उपयोग करते हैं। विशिष्ट कार्यों में तेजी लाने के लिए, पारंपरिक प्रोसेसर के साथ विशिष्ट समानांतर कंप्यूटर आर्किटेक्चर का उपयोग कभी-कभी किया जाता है।

कुछ मामलों में समानतावाद प्रोग्रामर के लिए पारदर्शी होता है, जैसे कि बिट-लेवल या इंस्ट्रक्शन-लेवल समानता में, लेकिन स्पष्ट रूप से समानांतर एल्गोरिथ्म, विशेष रूप से वे जो संगामिति का उपयोग करते हैं, [[क्रमिक एल्गोरिथ्म] की तुलना में लिखना अधिक कठिन होता है। ]], [२] क्योंकि संगामिति संभावित सॉफ्टवेयर बग के कई नए वर्गों का परिचय देती है, जिनमें से दौड़ हालत सबसे आम हैं। संचार और तादात्म्य के बीच अलग-अलग उपकार आमतौर पर इष्टतम समानांतर कार्यक्रम प्रदर्शन प्राप्त करने के लिए सबसे बड़ी बाधाओं में से कुछ हैं।


पृष्ठभूमि

परंपरागत रूप से, कंप्यूटर सॉफ्टवेयर धारावाहिक संगणना के लिए लिखा गया है। एक समस्या को हल करने के लिए, एल्गोरिथ्म का निर्माण और निर्देशों की एक धारा प्रवाह के रूप में लागू किया जाता है। ये निर्देश एक केंद्रीय प्रसंस्करण इकाई पर एक कंप्यूटर पर निष्पादित किए जाते हैं। एक समय में केवल एक ही निर्देश निष्पादित हो सकता है - उस निर्देश के समाप्त होने के बाद, अगला एक निष्पादित होता है। [३]

दूसरी ओर, समानांतर कंप्यूटिंग, एक समस्या को हल करने के लिए एक साथ कई प्रसंस्करण तत्वों का उपयोग करता है। यह समस्या को स्वतंत्र भागों में तोड़कर पूरा किया जाता है ताकि प्रत्येक प्रसंस्करण तत्व एल्गोरिदम के अपने हिस्से को एक साथ दूसरों के साथ निष्पादित कर सके। प्रसंस्करण तत्व विविधतापूर्ण हो सकते हैं और इसमें कई प्रोसेसर के साथ एकल कंप्यूटर, कई नेटवर्क वाले कंप्यूटर, विशेष हार्डवेयर या उपरोक्त में से कोई भी संसाधन शामिल हो सकते हैं। [३] ऐतिहासिक रूप से समानांतर कंप्यूटिंग का उपयोग वैज्ञानिक कंप्यूटिंग के लिए किया गया था। वैज्ञानिक समस्याओं का अनुकरण, विशेष रूप से प्राकृतिक और इंजीनियरिंग विज्ञान में, जैसे मौसम विज्ञान। इसने समानांतर हार्डवेयर और सॉफ्टवेयर के डिजाइन के साथ-साथ उच्च प्रदर्शन कंप्यूटिंग का नेतृत्व किया। [४]

बिजली की खपत की समस्या से निपटने के लिए और प्रमुख केंद्रीय प्रसंस्करण इकाई (सीपीयू या प्रोसेसर) निर्माताओं ने कई कोर के साथ बिजली कुशल प्रोसेसर का उत्पादन शुरू किया। कोर प्रोसेसर की कंप्यूटिंग इकाई है और मल्टी-कोर प्रोसेसर में प्रत्येक कोर स्वतंत्र होता है और समान मेमोरी को समवर्ती रूप से एक्सेस कर सकता है। मल्टी-कोर प्रोसेसर ने डेस्कटॉप कंप्यूटर में समानांतर कंप्यूटिंग लाई है। इस प्रकार धारावाहिक कार्यक्रमों का समानांतरकरण एक मुख्यधारा का प्रोग्रामिंग कार्य बन गया है। 2012 में क्वाड-कोर प्रोसेसर डेस्कटॉप कंप्यूटर के लिए मानक बन गया, जबकि सर्वर] में 10 और 12 कोर प्रोसेसर हैं। मूर के नियम से यह अनुमान लगाया जा सकता है कि प्रति प्रोसेसर कोर की संख्या हर १ months-२४ महीने में दोगुनी हो जाएगी। इसका मतलब यह हो सकता है कि 2020 के बाद एक विशिष्ट प्रोसेसर में दर्जनों या सैकड़ों कोर होंगे। [५]


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