निर्देश स्तर समांतरता: Difference between revisions
No edit summary |
No edit summary |
||
(7 intermediate revisions by 5 users not shown) | |||
Line 1: | Line 1: | ||
[[File:Atanasoff-Berry Computer at Durhum Center.jpg|thumb|अटानासॉफ़-बेरी कंप्यूटर, समानांतर प्रसंस्करण वाला पहला कंप्यूटर<ref>{{Cite web|url=http://mason.gmu.edu/~montecin/computer-hist-web.htm|title=कंप्यूटिंग का इतिहास|website=mason.gmu.edu|access-date=2019-03-24}}</ref>]]निर्देश स्तर समांतरता (ILP) एक [[Index.php?title=अभिकलित्र क्रमादेश|अभिकलित्र क्रमादेश]] में सेट किए गए निर्देश के अनुक्रम का [[Index.php?title=समानांतर अभिकलन|समानांतर अभिकलन]] या एक साथ निष्पादन है। अधिक विशेष रूप से निर्देश स्तर समांतरता इस समानांतर निष्पादन के प्रति चरण चलने वाले निर्देशों की औसत संख्या को संदर्भित करता है।<ref>{{cite journal |last1=Goossens |first1=Bernard |last2=Langlois |first2=Philippe |last3=Parello |first3=David |last4=Petit |first4=Eric |title=PerPI: A Tool to Measure Instruction Level Parallelism |journal=Applied Parallel and Scientific Computing |series=Lecture Notes in Computer Science |date=2012 |volume=7133 |pages=270–281 |doi=10.1007/978-3-642-28151-8_27|isbn=978-3-642-28150-1 |s2cid=26665479 |url=https://hal-lirmm.ccsd.cnrs.fr/lirmm-01349703/document}}</ref>{{rp|5}} | [[File:Atanasoff-Berry Computer at Durhum Center.jpg|thumb|अटानासॉफ़-बेरी कंप्यूटर, समानांतर प्रसंस्करण वाला पहला कंप्यूटर<ref>{{Cite web|url=http://mason.gmu.edu/~montecin/computer-hist-web.htm|title=कंप्यूटिंग का इतिहास|website=mason.gmu.edu|access-date=2019-03-24}}</ref>]]निर्देश स्तर समांतरता (ILP) एक [[Index.php?title=अभिकलित्र क्रमादेश|अभिकलित्र क्रमादेश]] में सेट किए गए निर्देश के अनुक्रम का [[Index.php?title=समानांतर अभिकलन|समानांतर अभिकलन]] या एक साथ निष्पादन है। अधिक विशेष रूप से निर्देश स्तर समांतरता इस समानांतर निष्पादन के प्रति चरण चलने वाले निर्देशों की औसत संख्या को संदर्भित करता है।<ref>{{cite journal |last1=Goossens |first1=Bernard |last2=Langlois |first2=Philippe |last3=Parello |first3=David |last4=Petit |first4=Eric |title=PerPI: A Tool to Measure Instruction Level Parallelism |journal=Applied Parallel and Scientific Computing |series=Lecture Notes in Computer Science |date=2012 |volume=7133 |pages=270–281 |doi=10.1007/978-3-642-28151-8_27|isbn=978-3-642-28150-1 |s2cid=26665479 |url=https://hal-lirmm.ccsd.cnrs.fr/lirmm-01349703/document}}</ref>{{rp|5}} | ||
== चर्चा == | == चर्चा == | ||
निर्देश स्तर समांतरता को संगामिति (अभिकलित्र विज्ञान) के साथ भ्रमित नहीं होना चाहिए। निर्देश स्तर समांतरता में एक [[Index.php?title=प्रक्रिया (अभिकलन)|प्रक्रिया (अभिकलन)]] के निष्पादन का एकल विशिष्ट [[Index.php?title=थ्रेड (अभिकलन)|थ्रेड (अभिकलन)]] होता है। दूसरी ओर, संगामिति में एक केंद्रीय प्रसंस्करण इकाई के कोर में एक सख्त विकल्प में, या सही समानांतरता में कई थ्रेड्स का समनुदेशित | निर्देश स्तर समांतरता को संगामिति (अभिकलित्र विज्ञान) के साथ भ्रमित नहीं होना चाहिए। निर्देश स्तर समांतरता में एक [[Index.php?title=प्रक्रिया (अभिकलन)|प्रक्रिया (अभिकलन)]] के निष्पादन का एकल विशिष्ट [[Index.php?title=थ्रेड (अभिकलन)|थ्रेड (अभिकलन)]] होता है। दूसरी ओर, संगामिति में एक केंद्रीय प्रसंस्करण इकाई के कोर में एक सख्त विकल्प में, या सही समानांतरता में कई थ्रेड्स का समनुदेशित सम्मलित होता है, यदि पर्याप्त सीपीयू कोर हैं, आदर्श रूप से प्रत्येक रन करने योग्य थ्रेड के लिए एक कोर है। | ||
अनुदेश-स्तर समानता के दो दृष्टिकोण हैं: [[कंप्यूटर हार्डवेयर]] और [[ सॉफ़्टवेयर ]] | अनुदेश-स्तर समानता के दो दृष्टिकोण हैं: [[कंप्यूटर हार्डवेयर]] और [[ सॉफ़्टवेयर | सॉफ़्टवेयर ।]] | ||
हार्डवेयर स्तर गतिशील समानता पर काम करता है, जबकि सॉफ्टवेयर स्तर स्थिर समानता पर काम करता है। गतिशील समानांतरता का मतलब है कि संसाधित्र कार्यावधि पर तय करता है कि कौन से निर्देश समानांतर में निष्पादित किए जाएं, जबकि स्थैतिक समानांतरता का मतलब है कि [[ संकलक ]] तय करता है कि कौन से निर्देश समानांतर में निष्पादित किए जाएं।<ref>{{cite book |title=Computer Architecture: A Quantitative Approach|url=https://archive.org/details/computerarchitec00patt|url-access=registration|first1=John L.|last1=Hennessy|first2=David A.|last2=Patterson}}</ref>{{clarify|date=January 2015}} [[पेंटियम]] संसाधित्र समांतर निष्पादन के गतिशील अनुक्रम पर काम करता है, लेकिन [[इटेनियम]] संसाधित्र स्थिर स्तर समानांतरता पर काम करता है। | हार्डवेयर स्तर गतिशील समानता पर काम करता है, जबकि सॉफ्टवेयर स्तर स्थिर समानता पर काम करता है। गतिशील समानांतरता का मतलब है कि संसाधित्र कार्यावधि पर तय करता है कि कौन से निर्देश समानांतर में निष्पादित किए जाएं, जबकि स्थैतिक समानांतरता का मतलब है कि [[ संकलक ]] तय करता है कि कौन से निर्देश समानांतर में निष्पादित किए जाएं।<ref>{{cite book |title=Computer Architecture: A Quantitative Approach|url=https://archive.org/details/computerarchitec00patt|url-access=registration|first1=John L.|last1=Hennessy|first2=David A.|last2=Patterson}}</ref>{{clarify|date=January 2015}} [[पेंटियम]] संसाधित्र समांतर निष्पादन के गतिशील अनुक्रम पर काम करता है, लेकिन [[इटेनियम]] संसाधित्र स्थिर स्तर समानांतरता पर काम करता है। | ||
Line 17: | Line 16: | ||
m = e * f | m = e * f | ||
</syntaxhighlight> | </syntaxhighlight> | ||
संक्रिया 3 संक्रिया 1 और 2 के परिणामों पर निर्भर करता है, इसलिए इसकी गणना तब तक नहीं की जा सकती जब तक कि दोनों पूरे नहीं हो जाते। | संक्रिया 3 संक्रिया 1 और 2 के परिणामों पर निर्भर करता है, इसलिए इसकी गणना तब तक नहीं की जा सकती जब तक कि दोनों पूरे नहीं हो जाते। चूंकि, संक्रिया 1 और 2 किसी अन्य संक्रिया पर निर्भर नहीं हैं, इसलिए उनकी गणना एक साथ की जा सकती है। यदि हम मानते हैं कि प्रत्येक संक्रिया को एक इकाई समय में पूरा किया जा सकता है, तो इन तीन निर्देशों को 3/2 का निर्देश स्तर समांतरता देते हुए कुल दो इकाइयों में पूरा किया जा सकता है। | ||
संकलक और केंद्रीय प्रक्रिया इकाई अभिकल्पक का एक लक्ष्य जितना संभव हो उतना निर्देश स्तर समांतरता की पहचान करना और उसका लाभ उठाना है। साधारण | संकलक और केंद्रीय प्रक्रिया इकाई अभिकल्पक का एक लक्ष्य जितना संभव हो उतना निर्देश स्तर समांतरता की पहचान करना और उसका लाभ उठाना है। साधारण क्रमादेश आमतौर पर अनुक्रमिक निष्पादन मॉडल के अनुसार लिखे जाते हैं जहां निर्देश एक के बाद एक और क्रमादेशक द्वारा निर्दिष्ट क्रम में निष्पादित होते हैं। आईएलपी संकलक और संसाधित्र को कई निर्देशों के निष्पादन को अधिव्यापन करने या निर्देशों को निष्पादित करने के क्रम को बदलने की अनुमति देता है। | ||
कार्यक्रमों में कितना निर्देश स्तर समांतरता | कार्यक्रमों में कितना निर्देश स्तर समांतरता सम्मलित है, यह [[बहु]]त ही विशिष्ट अनुप्रयोग है। कुछ क्षेत्रों में, जैसे कि आलेखी और [[वैज्ञानिक कंप्यूटिंग|वैज्ञानिक अभिकलन]] में राशि बहुत बड़ी हो सकती है। चूंकि, [[Index.php?title=कूटलेखन|कूटलेखन]] जैसे कार्यभार बहुत कम समानता प्रदर्शित कर सकते हैं। | ||
आईएलपी का फायदा उठाने के लिए उपयोग की जाने वाली सूक्ष्म-वास्तुक तकनीकों में | आईएलपी का फायदा उठाने के लिए उपयोग की जाने वाली सूक्ष्म-वास्तुक तकनीकों में सम्मलित हैं: | ||
* [[Index.php?title=निर्देश अनुप्रक्रमण|निर्देश अनुप्रक्रमण]] जहां कई निर्देशों का निष्पादन आंशिक रूप से अधिव्यापन किया जा सकता है। | * [[Index.php?title=निर्देश अनुप्रक्रमण|निर्देश अनुप्रक्रमण]] जहां कई निर्देशों का निष्पादन आंशिक रूप से अधिव्यापन किया जा सकता है। | ||
*सुपरस्क्लेर निष्पादन, [[बहुत लंबा निर्देश शब्द]], और बारीकी से संबंधित [[स्पष्ट रूप से समानांतर निर्देश कंप्यूटिंग|स्पष्ट रूप से समानांतर निर्देश अभिकलन]] अवधारणाएं, जिसमें समानांतर में कई निर्देशों को निष्पादित करने के लिए एकाधिक निष्पादन इकाइयों का उपयोग किया जाता है। | *सुपरस्क्लेर निष्पादन, [[बहुत लंबा निर्देश शब्द]], और बारीकी से संबंधित [[स्पष्ट रूप से समानांतर निर्देश कंप्यूटिंग|स्पष्ट रूप से समानांतर निर्देश अभिकलन]] अवधारणाएं, जिसमें समानांतर में कई निर्देशों को निष्पादित करने के लिए एकाधिक निष्पादन इकाइयों का उपयोग किया जाता है। | ||
*आउट-ऑफ़-ऑर्डर निष्पादन जहां निर्देश किसी भी क्रम में निष्पादित होते हैं जो डेटा निर्भरताओं का उल्लंघन नहीं करता है। ध्यान दें कि यह तकनीक | *आउट-ऑफ़-ऑर्डर निष्पादन जहां निर्देश किसी भी क्रम में निष्पादित होते हैं जो डेटा निर्भरताओं का उल्लंघन नहीं करता है। ध्यान दें कि यह तकनीक अनुप्रक्रमण और [[ सुपरस्कालर ]] निष्पादन दोनों से स्वतंत्र है। [[आउट-ऑफ-ऑर्डर निष्पादन]] के वर्तमान कार्यान्वयन [[रन टाइम (कार्यक्रम जीवनचक्र चरण)|कार्यावधि (कार्यक्रम जीवनचक्र चरण)]] (अर्थात, जबकि कार्यक्रम निष्पादित हो रहा है और संकलक से किसी भी सहायता के बिना) सामान्य कार्यक्रमों से आईएलपी निकालें। एक विकल्प यह है कि इस समानता को [[संकलन समय]] पर निकाला जाए और किसी तरह इस जानकारी को हार्डवेयर तक पहुँचाया जाए। आउट-ऑफ-ऑर्डर निष्पादन तकनीक को स्केल करने की जटिलता के कारण, उद्योग ने निर्देश सेटों की फिर से जांच की है जो प्रति निर्देश कई स्वतंत्र संचालन को स्पष्ट रूप से कोडन करते हैं। | ||
*रजिस्टर का नाम बदलना जो एक ऐसी तकनीक को संदर्भित करता है जिसका उपयोग उन संक्रियाों द्वारा [[आवंटन रजिस्टर करें]] पुन: उपयोग द्वारा लगाए गए | *रजिस्टर का नाम बदलना जो एक ऐसी तकनीक को संदर्भित करता है जिसका उपयोग उन संक्रियाों द्वारा [[आवंटन रजिस्टर करें]] पुन: उपयोग द्वारा लगाए गए क्रमादेश संचालन के अनावश्यक क्रमांकन से बचने के लिए किया जाता है, जिसका उपयोग आउट-ऑफ-ऑर्डर निष्पादन को सक्षम करने के लिए किया जाता है। | ||
*[[ | *[[Index.php?title=कल्पित निष्पादन|कल्पित निष्पादन]] जो निश्चित होने से पहले पूर्ण निर्देशों या निर्देशों के कुछ हिस्सों के निष्पादन की अनुमति देता है कि यह निष्पादन होना चाहिए या नहीं। कल्पित निष्पादन का एक सामान्य रूप से उपयोग किया जाने वाला रूप नियंत्रण प्रवाह कल्पित निष्पादन है जहां नियंत्रण प्रवाह निर्देश के लक्ष्य निर्धारित होने से पहले नियंत्रण प्रवाह निर्देश (जैसे, एक शाखा) के निर्देशों को निष्पादित किया जाता है। कल्पित निष्पादन के कई अन्य रूप प्रस्तावित किए गए हैं और [[Index.php?title=मूल्य पूर्वानुमान|मूल्य पूर्वानुमान]], [[Index.php?title=स्मृति निर्भरता पूर्वानुमान|स्मृति निर्भरता पूर्वानुमान]] और [[Index.php?title=कैश विलंबता पूर्वानुमान|कैश विलंबता पूर्वानुमान]] द्वारा संचालित कल्पित निष्पादन सहित उपयोग में हैं। | ||
* [[शाखा भविष्यवाणी]] जिसका उपयोग नियंत्रण निर्भरताओं को हल करने के लिए रोकने से बचने के लिए किया जाता है। | * [[शाखा भविष्यवाणी|शाखा पूर्वानुमान]] जिसका उपयोग नियंत्रण निर्भरताओं को हल करने के लिए रोकने से बचने के लिए किया जाता है। कल्पित निष्पादन के साथ शाखा पूर्वानुमान का उपयोग किया जाता है। | ||
यह ज्ञात है कि निर्देश स्तर समांतरता का संकलक और हार्डवेयर समर्थन दोनों द्वारा | यह ज्ञात है कि निर्देश स्तर समांतरता का संकलक और हार्डवेयर समर्थन दोनों द्वारा चूषित किया जाता है, लेकिन संकलक संकलन-समय के अनुकूलन द्वारा हार्डवेयर को क्रमादेश में अंतर्निहित और अंतर्निहित निर्देश स्तर समांतरता भी प्रदान करता है। कार्यक्रमों में उपलब्ध निर्देश स्तर समांतरता निकालने के लिए कुछ अनुकूलन तकनीकों में निर्देश अनुसूचीकरण, आवंटन/नाम बदलने का पंजीकरण, और मेमोरी अभिगम इष्टमीकरण सम्मलित होंगे। | ||
[[डेटाफ्लो | [[Index.php?title=डेटाफ्लो संरचना|डेटाफ्लो संरचना]] संरचना का एक अन्य वर्ग है जहां निर्देश स्तर समांतरता स्पष्ट रूप से निर्दिष्ट है, हाल के उदाहरण के लिए TRIPS संरचना देखें। | ||
हाल के वर्षों में, निर्देश स्तर समांतरता तकनीकों का उपयोग संसाधित्र | हाल के वर्षों में, निर्देश स्तर समांतरता तकनीकों का उपयोग संसाधित्र संक्रियात्मक आवृत्ति और मेमोरी अभिगम समय के बीच बढ़ती असमानता के बावजूद प्रदर्शन में सुधार प्रदान करने के लिए किया गया है (आरंभिकी निर्देश स्तर समांतरता अभिकलन जैसे आईबीएम सिस्टम / 360 मॉडल 91 ने निर्देश स्तर समांतरता तकनीकों का उपयोग निर्देश स्तर समांतरता तकनीकों का उपयोग किया है। अपेक्षाकृत छोटी रजिस्टर फ़ाइल)। वर्तमान में, मुख्य मेमोरी के लिए एक कैश मिस पेनल्टी में कई सैकड़ों सीपीयू चक्र खर्च होते हैं। जबकि सिद्धांत रूप में इस तरह की स्मृति विलंबता को सहन करने के लिए निर्देश स्तर समांतरता का उपयोग करना संभव है, संबद्ध संसाधन और बिजली अपव्यय लागत अनुपातहीन हैं। इसके अतिरिक्त, जटिलता और अधिकांशत: अंतर्निहित हार्डवेयर संरचनाओं की विलंबता के परिणामस्वरूप ऑपरेटिंग आवृत्ति कम हो जाती है और किसी भी लाभ को कम कर देती है। इसलिए, उपरोक्त तकनीक सीपीयू को ऑफ-चिप डेटा के लिए रुकने से रोकने के लिए अपर्याप्त सिद्ध होती है। इसके अतिरिक्त, उद्योग समानांतरता के उच्च स्तर का दोहन करने की ओर बढ़ रहा है जिसका उपयोग बहुप्रक्रमण और [[Index.php?title=बहु सूत्रण|बहु सूत्रण]] जैसी तकनीकों के माध्यम से किया जा सकता है।<ref>[https://web.archive.org/web/20140616035336/http://www.csl.cornell.edu/~sam/papers/cf04.pdf Reflections of the Memory Wall]</ref> | ||
Line 59: | Line 58: | ||
{{CPU technologies}} | {{CPU technologies}} | ||
{{DEFAULTSORT:Instruction Level Parallelism}} | {{DEFAULTSORT:Instruction Level Parallelism}} | ||
[[Category: | [[Category:All Wikipedia articles written in American English|Instruction Level Parallelism]] | ||
[[Category:Created On 07/05/2023]] | [[Category:Collapse templates|Instruction Level Parallelism]] | ||
[[Category:Created On 07/05/2023|Instruction Level Parallelism]] | |||
[[Category:Lua-based templates|Instruction Level Parallelism]] | |||
[[Category:Machine Translated Page|Instruction Level Parallelism]] | |||
[[Category:Navigational boxes| ]] | |||
[[Category:Navigational boxes without horizontal lists|Instruction Level Parallelism]] | |||
[[Category:Pages with script errors|Instruction Level Parallelism]] | |||
[[Category:Sidebars with styles needing conversion|Instruction Level Parallelism]] | |||
[[Category:Template documentation pages|Documentation/doc]] | |||
[[Category:Templates Vigyan Ready|Instruction Level Parallelism]] | |||
[[Category:Templates generating microformats|Instruction Level Parallelism]] | |||
[[Category:Templates that add a tracking category|Instruction Level Parallelism]] | |||
[[Category:Templates that are not mobile friendly|Instruction Level Parallelism]] | |||
[[Category:Templates that generate short descriptions|Instruction Level Parallelism]] | |||
[[Category:Templates using TemplateData|Instruction Level Parallelism]] | |||
[[Category:Use American English from March 2019|Instruction Level Parallelism]] | |||
[[Category:Webarchive template wayback links|Instruction Level Parallelism]] | |||
[[Category:Wikipedia articles needing clarification from January 2015|Instruction Level Parallelism]] | |||
[[Category:Wikipedia metatemplates|Instruction Level Parallelism]] | |||
[[Category:निर्देश प्रसंस्करण|Instruction Level Parallelism]] | |||
[[Category:समानांतर कंप्यूटिंग|Instruction Level Parallelism]] |
Latest revision as of 12:58, 27 October 2023
निर्देश स्तर समांतरता (ILP) एक अभिकलित्र क्रमादेश में सेट किए गए निर्देश के अनुक्रम का समानांतर अभिकलन या एक साथ निष्पादन है। अधिक विशेष रूप से निर्देश स्तर समांतरता इस समानांतर निष्पादन के प्रति चरण चलने वाले निर्देशों की औसत संख्या को संदर्भित करता है।[2]: 5
चर्चा
निर्देश स्तर समांतरता को संगामिति (अभिकलित्र विज्ञान) के साथ भ्रमित नहीं होना चाहिए। निर्देश स्तर समांतरता में एक प्रक्रिया (अभिकलन) के निष्पादन का एकल विशिष्ट थ्रेड (अभिकलन) होता है। दूसरी ओर, संगामिति में एक केंद्रीय प्रसंस्करण इकाई के कोर में एक सख्त विकल्प में, या सही समानांतरता में कई थ्रेड्स का समनुदेशित सम्मलित होता है, यदि पर्याप्त सीपीयू कोर हैं, आदर्श रूप से प्रत्येक रन करने योग्य थ्रेड के लिए एक कोर है।
अनुदेश-स्तर समानता के दो दृष्टिकोण हैं: कंप्यूटर हार्डवेयर और सॉफ़्टवेयर ।
हार्डवेयर स्तर गतिशील समानता पर काम करता है, जबकि सॉफ्टवेयर स्तर स्थिर समानता पर काम करता है। गतिशील समानांतरता का मतलब है कि संसाधित्र कार्यावधि पर तय करता है कि कौन से निर्देश समानांतर में निष्पादित किए जाएं, जबकि स्थैतिक समानांतरता का मतलब है कि संकलक तय करता है कि कौन से निर्देश समानांतर में निष्पादित किए जाएं।[3][clarification needed] पेंटियम संसाधित्र समांतर निष्पादन के गतिशील अनुक्रम पर काम करता है, लेकिन इटेनियम संसाधित्र स्थिर स्तर समानांतरता पर काम करता है।
निम्नलिखित कार्यक्रम पर विचार करें:
e = a + b
f = c + d
m = e * f
संक्रिया 3 संक्रिया 1 और 2 के परिणामों पर निर्भर करता है, इसलिए इसकी गणना तब तक नहीं की जा सकती जब तक कि दोनों पूरे नहीं हो जाते। चूंकि, संक्रिया 1 और 2 किसी अन्य संक्रिया पर निर्भर नहीं हैं, इसलिए उनकी गणना एक साथ की जा सकती है। यदि हम मानते हैं कि प्रत्येक संक्रिया को एक इकाई समय में पूरा किया जा सकता है, तो इन तीन निर्देशों को 3/2 का निर्देश स्तर समांतरता देते हुए कुल दो इकाइयों में पूरा किया जा सकता है।
संकलक और केंद्रीय प्रक्रिया इकाई अभिकल्पक का एक लक्ष्य जितना संभव हो उतना निर्देश स्तर समांतरता की पहचान करना और उसका लाभ उठाना है। साधारण क्रमादेश आमतौर पर अनुक्रमिक निष्पादन मॉडल के अनुसार लिखे जाते हैं जहां निर्देश एक के बाद एक और क्रमादेशक द्वारा निर्दिष्ट क्रम में निष्पादित होते हैं। आईएलपी संकलक और संसाधित्र को कई निर्देशों के निष्पादन को अधिव्यापन करने या निर्देशों को निष्पादित करने के क्रम को बदलने की अनुमति देता है।
कार्यक्रमों में कितना निर्देश स्तर समांतरता सम्मलित है, यह बहुत ही विशिष्ट अनुप्रयोग है। कुछ क्षेत्रों में, जैसे कि आलेखी और वैज्ञानिक अभिकलन में राशि बहुत बड़ी हो सकती है। चूंकि, कूटलेखन जैसे कार्यभार बहुत कम समानता प्रदर्शित कर सकते हैं।
आईएलपी का फायदा उठाने के लिए उपयोग की जाने वाली सूक्ष्म-वास्तुक तकनीकों में सम्मलित हैं:
- निर्देश अनुप्रक्रमण जहां कई निर्देशों का निष्पादन आंशिक रूप से अधिव्यापन किया जा सकता है।
- सुपरस्क्लेर निष्पादन, बहुत लंबा निर्देश शब्द, और बारीकी से संबंधित स्पष्ट रूप से समानांतर निर्देश अभिकलन अवधारणाएं, जिसमें समानांतर में कई निर्देशों को निष्पादित करने के लिए एकाधिक निष्पादन इकाइयों का उपयोग किया जाता है।
- आउट-ऑफ़-ऑर्डर निष्पादन जहां निर्देश किसी भी क्रम में निष्पादित होते हैं जो डेटा निर्भरताओं का उल्लंघन नहीं करता है। ध्यान दें कि यह तकनीक अनुप्रक्रमण और सुपरस्कालर निष्पादन दोनों से स्वतंत्र है। आउट-ऑफ-ऑर्डर निष्पादन के वर्तमान कार्यान्वयन कार्यावधि (कार्यक्रम जीवनचक्र चरण) (अर्थात, जबकि कार्यक्रम निष्पादित हो रहा है और संकलक से किसी भी सहायता के बिना) सामान्य कार्यक्रमों से आईएलपी निकालें। एक विकल्प यह है कि इस समानता को संकलन समय पर निकाला जाए और किसी तरह इस जानकारी को हार्डवेयर तक पहुँचाया जाए। आउट-ऑफ-ऑर्डर निष्पादन तकनीक को स्केल करने की जटिलता के कारण, उद्योग ने निर्देश सेटों की फिर से जांच की है जो प्रति निर्देश कई स्वतंत्र संचालन को स्पष्ट रूप से कोडन करते हैं।
- रजिस्टर का नाम बदलना जो एक ऐसी तकनीक को संदर्भित करता है जिसका उपयोग उन संक्रियाों द्वारा आवंटन रजिस्टर करें पुन: उपयोग द्वारा लगाए गए क्रमादेश संचालन के अनावश्यक क्रमांकन से बचने के लिए किया जाता है, जिसका उपयोग आउट-ऑफ-ऑर्डर निष्पादन को सक्षम करने के लिए किया जाता है।
- कल्पित निष्पादन जो निश्चित होने से पहले पूर्ण निर्देशों या निर्देशों के कुछ हिस्सों के निष्पादन की अनुमति देता है कि यह निष्पादन होना चाहिए या नहीं। कल्पित निष्पादन का एक सामान्य रूप से उपयोग किया जाने वाला रूप नियंत्रण प्रवाह कल्पित निष्पादन है जहां नियंत्रण प्रवाह निर्देश के लक्ष्य निर्धारित होने से पहले नियंत्रण प्रवाह निर्देश (जैसे, एक शाखा) के निर्देशों को निष्पादित किया जाता है। कल्पित निष्पादन के कई अन्य रूप प्रस्तावित किए गए हैं और मूल्य पूर्वानुमान, स्मृति निर्भरता पूर्वानुमान और कैश विलंबता पूर्वानुमान द्वारा संचालित कल्पित निष्पादन सहित उपयोग में हैं।
- शाखा पूर्वानुमान जिसका उपयोग नियंत्रण निर्भरताओं को हल करने के लिए रोकने से बचने के लिए किया जाता है। कल्पित निष्पादन के साथ शाखा पूर्वानुमान का उपयोग किया जाता है।
यह ज्ञात है कि निर्देश स्तर समांतरता का संकलक और हार्डवेयर समर्थन दोनों द्वारा चूषित किया जाता है, लेकिन संकलक संकलन-समय के अनुकूलन द्वारा हार्डवेयर को क्रमादेश में अंतर्निहित और अंतर्निहित निर्देश स्तर समांतरता भी प्रदान करता है। कार्यक्रमों में उपलब्ध निर्देश स्तर समांतरता निकालने के लिए कुछ अनुकूलन तकनीकों में निर्देश अनुसूचीकरण, आवंटन/नाम बदलने का पंजीकरण, और मेमोरी अभिगम इष्टमीकरण सम्मलित होंगे।
डेटाफ्लो संरचना संरचना का एक अन्य वर्ग है जहां निर्देश स्तर समांतरता स्पष्ट रूप से निर्दिष्ट है, हाल के उदाहरण के लिए TRIPS संरचना देखें।
हाल के वर्षों में, निर्देश स्तर समांतरता तकनीकों का उपयोग संसाधित्र संक्रियात्मक आवृत्ति और मेमोरी अभिगम समय के बीच बढ़ती असमानता के बावजूद प्रदर्शन में सुधार प्रदान करने के लिए किया गया है (आरंभिकी निर्देश स्तर समांतरता अभिकलन जैसे आईबीएम सिस्टम / 360 मॉडल 91 ने निर्देश स्तर समांतरता तकनीकों का उपयोग निर्देश स्तर समांतरता तकनीकों का उपयोग किया है। अपेक्षाकृत छोटी रजिस्टर फ़ाइल)। वर्तमान में, मुख्य मेमोरी के लिए एक कैश मिस पेनल्टी में कई सैकड़ों सीपीयू चक्र खर्च होते हैं। जबकि सिद्धांत रूप में इस तरह की स्मृति विलंबता को सहन करने के लिए निर्देश स्तर समांतरता का उपयोग करना संभव है, संबद्ध संसाधन और बिजली अपव्यय लागत अनुपातहीन हैं। इसके अतिरिक्त, जटिलता और अधिकांशत: अंतर्निहित हार्डवेयर संरचनाओं की विलंबता के परिणामस्वरूप ऑपरेटिंग आवृत्ति कम हो जाती है और किसी भी लाभ को कम कर देती है। इसलिए, उपरोक्त तकनीक सीपीयू को ऑफ-चिप डेटा के लिए रुकने से रोकने के लिए अपर्याप्त सिद्ध होती है। इसके अतिरिक्त, उद्योग समानांतरता के उच्च स्तर का दोहन करने की ओर बढ़ रहा है जिसका उपयोग बहुप्रक्रमण और बहु सूत्रण जैसी तकनीकों के माध्यम से किया जा सकता है।[4]
यह भी देखें
संदर्भ
- ↑ "कंप्यूटिंग का इतिहास". mason.gmu.edu. Retrieved 2019-03-24.
- ↑ Goossens, Bernard; Langlois, Philippe; Parello, David; Petit, Eric (2012). "PerPI: A Tool to Measure Instruction Level Parallelism". Applied Parallel and Scientific Computing. Lecture Notes in Computer Science. 7133: 270–281. doi:10.1007/978-3-642-28151-8_27. ISBN 978-3-642-28150-1. S2CID 26665479.
- ↑ Hennessy, John L.; Patterson, David A. Computer Architecture: A Quantitative Approach.
- ↑ Reflections of the Memory Wall
अग्रिम पठन
- Aiken, Alex; Banerjee, Utpal; Kejariwal, Arun; Nicolau, Alexandru (2016-11-30). Instruction Level Parallelism. Professional Computing (1 ed.). Springer. ISBN 978-1-4899-7795-3. ISBN 1-4899-7795-3. (276 pages)