अनुदेश पथ की लंबाई: Difference between revisions
(Created page with "{{Short description|Number of machine code instructions required to execute a section of a computer program}} {{Unreferenced|date=November 2016}} कंप्यूटर...") |
m (14 revisions imported from alpha:अनुदेश_पथ_की_लंबाई) |
||
(13 intermediate revisions by 2 users not shown) | |||
Line 1: | Line 1: | ||
{{Short description|Number of machine code instructions required to execute a section of a computer program}} | {{Short description|Number of machine code instructions required to execute a section of a computer program}} | ||
[[कंप्यूटर प्रदर्शन|कंप्यूटर परफॉरमेंस]] में, '''इंस्ट्रक्शन पाथ लेंथ''' [[कंप्यूटर प्रोग्राम]] के सेक्शन को एक्सीक्यूट करने के लिए रिक्वायर्ड [[मशीन कोड]] इंस्ट्रक्शंस की संख्या है। पूर्ण प्रोग्राम के लिए टोटल पाथ लेंथ को किसी विशेष [[कंप्यूटर हार्डवेयर]] पर [[कलन विधि|एल्गोरिदम]] के परफॉरमेंस का मिज़र माना जा सकता है। सिंपल कंडीशनल इंस्ट्रक्शन की पाथ लेंथ सामान्यतः 2 के समान मानी जाती है, प्रथम इंस्ट्रक्शन अपेक्षा करने के लिए एवं दूसरा इंस्ट्रक्शन पर्टिकुलर कंडीशन सेटिस्फाई होने पर ब्रांच लेने के लिए होता है। पाथ लेंथ निर्धारित करते समय प्रत्येक इंस्ट्रक्शन को एक्सीक्यूट करने में लगने वाले समय को सामान्यतः ध्यान में नहीं रखा जाता है एवं इसलिए पाथ लेंथ किसी भी अर्थ में पूर्ण होने के अतिरिक्त सापेक्ष परफॉरमेंस का संकेत मात्र है। | |||
[[कंप्यूटर प्रदर्शन]] में, | |||
[[बेंचमार्क प्रोग्राम]] | [[बेंचमार्क प्रोग्राम]] एक्सीक्यूट करते समय, अधिकांश इंस्ट्रक्शन पाथ लेंथ सामान्यतः प्रोग्राम के इनर लूप के अंदर होती है। | ||
[[कैश (कंप्यूटिंग)]] | [[कैश (कंप्यूटिंग)|कैश]] के प्रारम्भ से पूर्व, पाथ लेंथ रनिंग टाइम का अप्प्रोक्सिमेशन था, किन्तु कैश के साथ आधुनिक सीपीयू में, यह अधिक त्रुटिपूर्ण अनुमान हो सकता है, जब डेटा कैश में नहीं होता है तो कुछ लोड इंस्ट्रक्शंस में हंड्रेड साइकल्स लगते हैं, या कैश में होने पर तीव्रता बढ़ती हैं (यहां तक कि लूप में दूसरे राउंड में भी वही इंस्ट्रक्शन होते हैं)। | ||
== | ==असेंबली प्रोग्राम== | ||
चूँकि, | चूँकि, सामान्यतः, असेंबली अनुदेशों एवं मशीन अनुदेशों के मध्य संबंध होता है, इंस्ट्रक्शन पाथ लेंथ को प्रायः किसी फ़ंक्शन या कोड के विशेष सेक्शन को एक्सीक्यूट करने के लिए आवश्यक असेंबली अनुदेशों की संख्या के रूप में लिया जाता है। 1,000 प्रविष्टियों की [[छँटाई|अवर्गीकृत]] सूची पर साधारण लुकअप टेबल एक्सीक्यूट करने के लिए संभवतः 2,000 मशीन अनुदेशों की आवश्यकता हो सकती है (औसतन, इनपुट मानों का समान वितरण मानते हुए), जबकि [[बाइनरी खोज एल्गोरिदम|बाइनरी शोध एल्गोरिदम]] का उपयोग करके सॉर्टिंग सूची पर समान लुकअप करने के लिए केवल 40 मशीन अनुदेशों की आवश्यकता हो सकती है, जो अधिक महत्वपूर्ण बचत है। इंस्ट्रक्शन पाथ लेंथ के संदर्भ में व्यक्त, इस [[सॉफ्टवेयर मीट्रिक]] को इस उदाहरण में 50 के बड़े कारक से कम किया जाएगा{{snd}}यही कारण है कि कम पथ लंबाई की आवश्यकता वाले एल्गोरिदम के श्रेष्ठ विकल्प की अपेक्षा में वास्तविक इंस्ट्रक्शन समय माध्यमिक विचार हो सकता है। | ||
किसी असेंबली | किसी असेंबली लैंग्वेज प्रोग्राम की इंस्ट्रक्शन पाथ लेंथ सामान्यतः उस प्रोग्राम के लिए कोड की स्रोत लाइनों की संख्या से अधिक भिन्न होती है, क्योंकि इंस्ट्रक्शन पाथ लेंथ में दिए गए इनपुट के लिए एक्सीक्यूट नियंत्रण प्रवाह में केवल कोड सम्मिलित होता है एवं इसमें वह कोड सम्मिलित नहीं होता है जो विशेष इनपुट, या पहुंच योग्य कोड के लिए प्रासंगिक नहीं है। | ||
== | ==हाई लेवल लैंग्वेज (एचएलएल) प्रोग्राम== | ||
चूँकि | चूँकि हाई लेवल लैंग्वेज में लिखा गया कथन चर संख्या के कई मशीन इंस्ट्रक्शन उत्पन्न कर सकता है, उदाहरण के लिए, इंस्ट्रक्शन सेट सिम्युलेटर के अभाव में इंस्ट्रक्शन पाथ लेंथ निर्धारित करना सदैव संभव नहीं होता है{{snd}}जो सिमुलेशन के समयान 'एक्सीक्यूट' अनुदेशों की संख्या की गणना कर सकता है। यदि हाई लेवल लैंग्वेज 'असेंबली सूची' का समर्थन करती है एवं वैकल्पिक रूप से तत्पर करती है, तो कभी-कभी इस सूची की शोध करके इंस्ट्रक्शन पाथ लेंथ का अनुमान लगाना संभव होता है। | ||
== | ==इंस्ट्रक्शन पाथ लेंथ निर्धारित करने वाले फैक्टर्स== | ||
* इन-लाइन कोड | * इन-लाइन कोड के प्रति समान कथन वाले फ़ंक्शन, प्रक्रिया या विधि से कॉल करने और लौटने के ओवरहेड्स है। | ||
* [[साहचर्य सरणी]] में वस्तुओं का क्रम | * [[साहचर्य सरणी|अवर्गीकृत लुकअप सूची]] में वस्तुओं का क्रम लम्बे शोधों से बचने के लिए सबसे अधिक बार आने वाली वस्तुओं को पूर्व रखा जाना चाहिए। | ||
* एल्गोरिदम का चयन{{snd}} [[अनुक्रमित खोज]], बाइनरी | * एल्गोरिदम का चयन{{snd}}[[अनुक्रमित खोज|अनुक्रमित शोध]], बाइनरी शोध या रैखिक शोध है। | ||
* | * नवीन सिरे से गणना करें एवं पूर्व की गई गणना को बनाए रखें ([[संस्मरण]]){{snd}}कई समष्टि पुनरावृत्तियों को कम कर सकता है। | ||
* | * कुछ तालिकाओं को मेमोरी में पढ़ें एवं बाहरी तालिकाओं को प्रत्येक बार नवीन सिरे से पढ़ें{{snd}}इनपुट/आउटपुट फ़ंक्शन कॉल के माध्यम से उच्च पथ लंबाई से बचना है। | ||
== | ==इंस्ट्रक्शन पाथ लेंथ का उपयोग== | ||
उपरोक्त से, यह | उपरोक्त से, यह विचार किया जा सकता है कि इंस्ट्रक्शन पाथ लेंथ के ज्ञान का उपयोग किया जा सकता है: | ||
* किसी भी | * किसी भी लैंग्वेज में प्रोग्राम के लिए समग्र पाथ लेंथ को मिनीमाइज करने के लिए उपयुक्त एल्गोरिदम का चयन किया जाता है। | ||
* किसी प्रोग्राम | * यह मॉनिटर करने के लिए इसका उपयोग किया जाता है कि किसी प्रोग्राम को किसी भी लैंग्वेज में कितने उचित प्रकार से [[अनुकूलन (कंप्यूटर विज्ञान)|ऑप्टिमाइज़]] किया गया है। | ||
* यह निर्धारित करने के लिए कि किसी एचएलएल | * इसका उपयोग यह निर्धारित करने के लिए किया जाता है कि किसी एचएलएल लैंग्वेज के लिए विशेष एचएलएल स्टेटमेंट्स कितने एफिशिएंट हैं। | ||
* | * ओवरआल कंप्यूटर परफॉरमेंस के अप्प्रोक्सिमेट मिज़र के रूप में इसका उपयोग किया जा सकता है। | ||
==बाहरी संबंध== | ==बाहरी संबंध== | ||
* [https://books.google.com/books?id=R7Frpn3g9AEC&dq=%22instruction+path+length%22&pg=PP1] | * [https://books.google.com/books?id=R7Frpn3g9AEC&dq=%22instruction+path+length%22&pg=PP1] कंप्यूटर आर्किटेक्चर जॉन एल. हेनेसी, डेविड ए. पैटरसन, डेविड गोल्डबर्ग, क्रस्टे असानोविक द्वारा | ||
* [http://www.vm.ibm.com/perf/reports/zvm/html/gloss.html] IBM – | * [http://www.vm.ibm.com/perf/reports/zvm/html/gloss.html] IBM – आईबीएम - प्रदर्शन प्रतिबंधों की शब्दावली | ||
[[Category: एल्गोरिदम का विश्लेषण]] [[Category: सॉफ्टवेयर अनुकूलन]] | [[Category: एल्गोरिदम का विश्लेषण]] [[Category: सॉफ्टवेयर अनुकूलन]] | ||
Line 39: | Line 38: | ||
[[Category: Machine Translated Page]] | [[Category: Machine Translated Page]] | ||
[[Category:Created On 25/07/2023]] | [[Category:Created On 25/07/2023]] | ||
[[Category:Vigyan Ready]] |
Latest revision as of 22:17, 2 February 2024
कंप्यूटर परफॉरमेंस में, इंस्ट्रक्शन पाथ लेंथ कंप्यूटर प्रोग्राम के सेक्शन को एक्सीक्यूट करने के लिए रिक्वायर्ड मशीन कोड इंस्ट्रक्शंस की संख्या है। पूर्ण प्रोग्राम के लिए टोटल पाथ लेंथ को किसी विशेष कंप्यूटर हार्डवेयर पर एल्गोरिदम के परफॉरमेंस का मिज़र माना जा सकता है। सिंपल कंडीशनल इंस्ट्रक्शन की पाथ लेंथ सामान्यतः 2 के समान मानी जाती है, प्रथम इंस्ट्रक्शन अपेक्षा करने के लिए एवं दूसरा इंस्ट्रक्शन पर्टिकुलर कंडीशन सेटिस्फाई होने पर ब्रांच लेने के लिए होता है। पाथ लेंथ निर्धारित करते समय प्रत्येक इंस्ट्रक्शन को एक्सीक्यूट करने में लगने वाले समय को सामान्यतः ध्यान में नहीं रखा जाता है एवं इसलिए पाथ लेंथ किसी भी अर्थ में पूर्ण होने के अतिरिक्त सापेक्ष परफॉरमेंस का संकेत मात्र है।
बेंचमार्क प्रोग्राम एक्सीक्यूट करते समय, अधिकांश इंस्ट्रक्शन पाथ लेंथ सामान्यतः प्रोग्राम के इनर लूप के अंदर होती है।
कैश के प्रारम्भ से पूर्व, पाथ लेंथ रनिंग टाइम का अप्प्रोक्सिमेशन था, किन्तु कैश के साथ आधुनिक सीपीयू में, यह अधिक त्रुटिपूर्ण अनुमान हो सकता है, जब डेटा कैश में नहीं होता है तो कुछ लोड इंस्ट्रक्शंस में हंड्रेड साइकल्स लगते हैं, या कैश में होने पर तीव्रता बढ़ती हैं (यहां तक कि लूप में दूसरे राउंड में भी वही इंस्ट्रक्शन होते हैं)।
असेंबली प्रोग्राम
चूँकि, सामान्यतः, असेंबली अनुदेशों एवं मशीन अनुदेशों के मध्य संबंध होता है, इंस्ट्रक्शन पाथ लेंथ को प्रायः किसी फ़ंक्शन या कोड के विशेष सेक्शन को एक्सीक्यूट करने के लिए आवश्यक असेंबली अनुदेशों की संख्या के रूप में लिया जाता है। 1,000 प्रविष्टियों की अवर्गीकृत सूची पर साधारण लुकअप टेबल एक्सीक्यूट करने के लिए संभवतः 2,000 मशीन अनुदेशों की आवश्यकता हो सकती है (औसतन, इनपुट मानों का समान वितरण मानते हुए), जबकि बाइनरी शोध एल्गोरिदम का उपयोग करके सॉर्टिंग सूची पर समान लुकअप करने के लिए केवल 40 मशीन अनुदेशों की आवश्यकता हो सकती है, जो अधिक महत्वपूर्ण बचत है। इंस्ट्रक्शन पाथ लेंथ के संदर्भ में व्यक्त, इस सॉफ्टवेयर मीट्रिक को इस उदाहरण में 50 के बड़े कारक से कम किया जाएगा – यही कारण है कि कम पथ लंबाई की आवश्यकता वाले एल्गोरिदम के श्रेष्ठ विकल्प की अपेक्षा में वास्तविक इंस्ट्रक्शन समय माध्यमिक विचार हो सकता है।
किसी असेंबली लैंग्वेज प्रोग्राम की इंस्ट्रक्शन पाथ लेंथ सामान्यतः उस प्रोग्राम के लिए कोड की स्रोत लाइनों की संख्या से अधिक भिन्न होती है, क्योंकि इंस्ट्रक्शन पाथ लेंथ में दिए गए इनपुट के लिए एक्सीक्यूट नियंत्रण प्रवाह में केवल कोड सम्मिलित होता है एवं इसमें वह कोड सम्मिलित नहीं होता है जो विशेष इनपुट, या पहुंच योग्य कोड के लिए प्रासंगिक नहीं है।
हाई लेवल लैंग्वेज (एचएलएल) प्रोग्राम
चूँकि हाई लेवल लैंग्वेज में लिखा गया कथन चर संख्या के कई मशीन इंस्ट्रक्शन उत्पन्न कर सकता है, उदाहरण के लिए, इंस्ट्रक्शन सेट सिम्युलेटर के अभाव में इंस्ट्रक्शन पाथ लेंथ निर्धारित करना सदैव संभव नहीं होता है – जो सिमुलेशन के समयान 'एक्सीक्यूट' अनुदेशों की संख्या की गणना कर सकता है। यदि हाई लेवल लैंग्वेज 'असेंबली सूची' का समर्थन करती है एवं वैकल्पिक रूप से तत्पर करती है, तो कभी-कभी इस सूची की शोध करके इंस्ट्रक्शन पाथ लेंथ का अनुमान लगाना संभव होता है।
इंस्ट्रक्शन पाथ लेंथ निर्धारित करने वाले फैक्टर्स
- इन-लाइन कोड के प्रति समान कथन वाले फ़ंक्शन, प्रक्रिया या विधि से कॉल करने और लौटने के ओवरहेड्स है।
- अवर्गीकृत लुकअप सूची में वस्तुओं का क्रम लम्बे शोधों से बचने के लिए सबसे अधिक बार आने वाली वस्तुओं को पूर्व रखा जाना चाहिए।
- एल्गोरिदम का चयन – अनुक्रमित शोध, बाइनरी शोध या रैखिक शोध है।
- नवीन सिरे से गणना करें एवं पूर्व की गई गणना को बनाए रखें (संस्मरण) – कई समष्टि पुनरावृत्तियों को कम कर सकता है।
- कुछ तालिकाओं को मेमोरी में पढ़ें एवं बाहरी तालिकाओं को प्रत्येक बार नवीन सिरे से पढ़ें – इनपुट/आउटपुट फ़ंक्शन कॉल के माध्यम से उच्च पथ लंबाई से बचना है।
इंस्ट्रक्शन पाथ लेंथ का उपयोग
उपरोक्त से, यह विचार किया जा सकता है कि इंस्ट्रक्शन पाथ लेंथ के ज्ञान का उपयोग किया जा सकता है:
- किसी भी लैंग्वेज में प्रोग्राम के लिए समग्र पाथ लेंथ को मिनीमाइज करने के लिए उपयुक्त एल्गोरिदम का चयन किया जाता है।
- यह मॉनिटर करने के लिए इसका उपयोग किया जाता है कि किसी प्रोग्राम को किसी भी लैंग्वेज में कितने उचित प्रकार से ऑप्टिमाइज़ किया गया है।
- इसका उपयोग यह निर्धारित करने के लिए किया जाता है कि किसी एचएलएल लैंग्वेज के लिए विशेष एचएलएल स्टेटमेंट्स कितने एफिशिएंट हैं।
- ओवरआल कंप्यूटर परफॉरमेंस के अप्प्रोक्सिमेट मिज़र के रूप में इसका उपयोग किया जा सकता है।