उपयोग-परिभाषित श्रृंखला
This article does not cite any sources. (January 2023) (Learn how and when to remove this template message) |
कंप्यूटर विज्ञान के अन्तर्गत , एक उपयोग-परिभाषा श्रृंखला (यू डी चेन) एक डेटा संरचना है जिसमें एक चर (प्रोग्रामिंग) का उपयोग, यू, और उस चर के सभी परिभाषाएं, जो किसी अन्य हस्तक्षेप की परिभाषा के बिना उस उपयोग तक पहुंच सकते हैं। एक यू डी चेन का तात्पर्य सामान्यतः एक चर के लिए कुछ मूल्य का प्रदत्त कार्य (कंप्यूटर विज्ञान) होता है।
यूडी चेन का एक समकक्ष परिभाषा-उपयोग श्रृंखला (डी यू चेन) है, जिसमें एक चर की परिभाषा, डी, और सभी उपयोग, यू, उस परिभाषा से बिना किसी अन्य हस्तक्षेप परिभाषा के पहुंच योग्य होते हैं।
यूडी और डी यू दोनों श्रृंखलाएं डेटा प्रवाह विश्लेषण के रूप में जाने वाले स्थिर कोड विश्लेषण के एक रूप का उपयोग करके बनाई गई हैं। किसी प्रोग्राम या सबप्रोग्राम के लिए यूज़-डीफ़ और डीफ़-यूज़ चेन को जानना कई संकलक अनुकूलन के लिए एक शर्त है, जिसमें निरंतर प्रचार और सामान्य उप-अभिव्यक्ति उन्मूलन सम्मिलित है।
उद्देश्य
यूज-डिफाइन या डिफाइन-यूज चेन बनाना सजीवता विश्लेषण का एक कदम है, ताकि सभी चर राशियों के तार्किक अभिवेदन को कोड के जरिए पहचाना और ट्रैक किया जा सके।
कोड के निम्नलिखित स्निपेट पर विचार करें:
<वाक्यविन्यास प्रकाश लैंग = सी>
इंट एक्स = 0; /* ए */ एक्स = एक्स + वाई; /* बी */ /* 1, x के कुछ उपयोग */ एक्स = 35; /* सी */ /* 2, x के कुछ और उपयोग */
</वाक्यविन्यास हाइलाइट>
ध्यान दें कि x को तीन बिंदुओं (चिह्नित A, B और C) पर एक मान दिया गया है। हालाँकि, "1" चिह्नित बिंदु पर, x के लिए उपयोग-डेफ श्रृंखला को इंगित करना चाहिए कि इसका वर्तमान मान लाइन B से आया होगा (और लाइन B पर इसका मान लाइन A से आया होगा)।इसके विपरीत, "2" चिह्नित बिंदु पर, x के लिए उपयोग-डेफ श्रृंखला इंगित करती है कि इसका वर्तमान मान लाइन सी से आया होगा। चूंकि ब्लॉक 2 में x का मान ब्लॉक 1 या इससे पहले की किसी भी परिभाषा पर निर्भर नहीं करता है, x वहाँ एक भिन्न चर भी हो सकता है; व्यावहारिक रूप से बोलना, यह एक भिन्न चर है - इसे x2 कहते हैं।
<वाक्यविन्यास प्रकाश लैंग = सी>
इंट एक्स = 0; /* ए */ एक्स = एक्स + वाई; /* बी */ /* 1, x के कुछ उपयोग */ int x2 = 35; /* सी */ /* 2, x2 के कुछ उपयोग */
</वाक्यविन्यास हाइलाइट>
x को दो अलग-अलग चर राशियों में विभाजित करने की प्रक्रिया को लाइव रेंज स्प्लिटिंग कहा जाता है। स्टैटिक सिंगल असाइनमेंट फॉर्म भी देखें।
व्यवस्थापन
विवरण की सूची विवरण के बीच एक मजबूत क्रम निर्धारित करती है।
- निम्नलिखित परिपाटियों का उपयोग करते हुए कथनों को लेबल किया गया है: , जहाँ i एक पूर्णांक है ; और n बुनियादी ब्लॉक में विवरण की संख्या है
- चर राशि को इटैलिक में पहचाना जाता है(जैसे, वी, यू और टी)
- प्रत्येक चर को संदर्भ या दायरे में एक परिभाषा माना जाता है। (स्थिर एकल प्रदत्त कार्य फॉर्म में, यूज-डिफाइन चेन स्पष्ट हैं क्योंकि प्रत्येक चेन में एक ही तत्व होता है।)
एक चर के लिए, जैसे v, इसकी घोषणा की पहचान V (इटैलिक कैपिटल लेटर) के रूप में की जाती है, और संक्षेप में, इसकी घोषणा के रूप में पहचान की जाती है सामान्य तौर पर, एक चर की घोषणा बाहरी दायरे में हो सकती है (उदाहरण के लिए, एक वैश्विक चर)।
एक चर की परिभाषा
जब एक चर, v, एक प्रदत्त कार्य स्टेटमेंट के समीकरण के बाईं ओर और दाईं ओर होता है, जैसे कि , तब v की एक परिभाषा है। प्रत्येक चर (v) की घोषणा (V) (या आरंभीकरण) द्वारा कम से कम एक परिभाषा है।
एक चर का प्रयोग
यदि चर, v, कथन के दाएँ पक्ष में है , एक बयान है, मैं <जे और के साथ , कि यह v की परिभाषा है और इसका उपयोग at है (या, संक्षेप में, जब एक चर, v, एक कथन के दाएँ पक्ष पर है , तो v का कथन पर उपयोग है
निष्पादन
कथनों की सूची के क्रमिक कार्यान्वयन पर विचार करें, , और अब कथन पर गणना के रूप में क्या देखा जा सकता है,:
- बयान पर एक परिभाषा i <j के साथ j पर 'जीवित' है, अगर इसका किसी कथन पर उपयोग होता है के ≥ जे के साथ। बयान में जीवित परिभाषाओं का सम्मुच्चय i के रूप में दर्शाया गया है और जीवित परिभाषाओं की संख्या के रूप में . ( एक सरल लेकिन शक्तिशाली अवधारणा है: अंतरिक्ष जटिलता सिद्धांत में सैद्धांतिक और व्यावहारिक परिणाम, पहुंच जटिलता (I/O जटिलता), रजिस्टर आवंटन और स्मृति स्थानीयता शोषण पर आधारित हैं .)
- बयान पर एक परिभाषा पिछली सभी परिभाषाओं को मारता है ( k <i) के साथ समान चर के लिए।
== डीफ़-यूज़-चेन == के लिए कार्यान्वयन उदाहरण यह उदाहरण महत्तम सामान्य भाजक खोजने के लिए जावा एल्गोरिथम पर आधारित है। (यह समझना महत्वपूर्ण नहीं है कि यह फ़ंक्शन क्या करता है।)
<वाक्यविन्यास लैंग = सी लाइन> /**
* @param(a, b) विभाजक की गणना करने के लिए उपयोग किए जाने वाले मान। * @return a और b का महत्तम समापवर्तक है। */
इंट जीसीडी (इंट ए, इंट बी) {
इंट सी = ए; इंट डी = बी; अगर (सी == 0) वापसी घ; जबकि (डी! = 0) { अगर (सी> डी) सी = सी - डी; अन्य डी = डी - सी; } वापसी सी;
} </वाक्यविन्यास हाइलाइट>
वेरिएबल d के लिए सभी डीफ़-यूज़-चेन का पता लगाने के लिए, निम्न चरणों का पालन करें:
- पहली बार वेरिएबल को परिभाषित करने के लिए खोजें (एक्सेस लिखें)।
- इस मामले में यह है
d=b
(एल.7)
- इस मामले में यह है
- पहली बार वेरिएबल को पढ़ने के लिए खोजें।
- इस मामले में यह है
return d
# इस जानकारी को निम्न शैली में लिखें: [उस चर का नाम जिसके लिए आप एक डीफ़-यूज़-चेन बना रहे हैं, कंक्रीट राइट एक्सेस, कंक्रीट रीड एक्सेस] - इस मामले में यह है:
[d, d=b, return d]
- इस मामले में यह है
निम्नलिखित चरणों में इन चरणों को दोहराएं: प्रत्येक पढ़ने की पहुंच के साथ प्रत्येक लेखन पहुंच को संयोजित करें (लेकिन दूसरे तरीके से नहीं)।
परिणाम होना चाहिए: <वाक्यविन्यास लैंग = सी लाइन>
[डी, डी = बी, रिटर्न डी] [डी, डी=बी, जबकि(डी!=0)] [डी, डी = बी, अगर (सी> डी)] [डी, डी=बी, सी=सी-डी] [डी, डी=बी, डी=डी-सी] [डी, डी = डी-सी, जबकि (डी! = 0)] [डी, डी = डी-सी, अगर (सी> डी)] [डी, डी=डी-सी, सी=सी-डी] [डी, डी=डी-सी, डी=डी-सी]
</वाक्यविन्यास हाइलाइट> आपको ध्यान रखना होगा, यदि चर समय के अनुसार बदल जाता है।
उदाहरण के लिए: स्रोत कोड में पंक्ति 7 नीचे से पंक्ति 13 तक, d पुनर्परिभाषित / परिवर्तित नहीं किया गया है। लाइन 14 पर, d पुनर्परिभाषित किया जा सकता है। यही कारण है कि आपको इस राइट एक्सेस को फिर से जोड़ना होगा d सभी संभावित पठन पहुंचों के साथ जिन तक पहुंचा जा सकता है। इस स्थिति में, केवल पंक्ति 10 के बाद का कोड प्रासंगिक है। लाइन 7, उदाहरण के लिए, फिर से नहीं पहुँचा जा सकता। आपकी समझ के लिए, आप 2 अलग-अलग चरों की कल्पना कर सकते हैं d: <वाक्यविन्यास लैंग = सी लाइन>
[डी1, डी1=बी, रिटर्न डी1] [डी 1, डी 1 = बी, जबकि (डी 1! = 0)] [डी 1, डी 1 = बी, अगर (सी> डी 1)] [डी1, डी1=बी, सी=सी-डी1] [डी1, डी1=बी, डी1=डी1-सी] [डी2, डी2=डी2-सी, जबकि (डी2!=0)] [डी2, डी2=डी2-सी, अगर(सी>डी2)] [डी2, डी2=डी2-सी, सी=सी-डी2] [डी2, डी2=डी2-सी, डी2=डी2-सी]
</वाक्यविन्यास हाइलाइट>
नतीजतन, आपको ऐसा कुछ मिल सकता है। चर d1 द्वारा प्रतिस्थापित किया जाएगा b <वाक्यविन्यास लैंग = सी लाइन> /**
* @param(a, b) विभाजक की गणना करने के लिए उपयोग किए जाने वाले मान। * @return a और b का महत्तम समापवर्तक है। **/
इंट जीसीडी (इंट ए, इंट बी) {
इंट सी = ए; इंट डी; अगर (सी == 0) वापसी बी; अगर (बी! = 0) { अगर (सी> बी) { सी = सी - बी; डी = बी; } अन्य डी = बी - सी; जबकि (डी! = 0) { अगर (सी> डी) सी = सी - डी; अन्य डी = डी - सी; } } वापसी सी;
} </वाक्यविन्यास हाइलाइट>
उपयोग-डीईएफ़ (या ud) श्रृंखला बनाने की विधि
This section may be confusing or unclear to readers. (January 2007) (Learn how and when to remove this template message) |
- कथन में परिभाषाएँ निर्धारित करें
- प्रत्येक के लिए i में , लाइव परिभाषाएँ खोजें जिनका उपयोग कथन में किया गया है
- परिभाषाओं और उपयोगों के बीच संबंध बनाएं
- स्टेटमेंट सम्मुच्चय करें , परिभाषा कथन के रूप में
- पिछली परिभाषाओं को मारें
इस एल्गोरिथम के साथ, दो चीजें पूरी होती हैं:
- एक निर्देशित विश्वकोश ग्राफ (DAG) चर उपयोगों और परिभाषाओं पर बनाया गया है। डीएजी प्रदत्त कार्य कथनों के साथ-साथ आंशिक आदेश (इसलिए विवरण के बीच समानता) के बीच डेटा निर्भरता निर्दिष्ट करता है।
- कब बयान तक पहुँच गया है, तो लाइव वेरिएबल प्रदत्त कार्य की एक सूची है। यदि केवल एक प्रदत्त कार्य लाइव है, उदाहरण के लिए, निरंतर प्रसार का उपयोग किया जा सकता है।
श्रेणी:संकलक अनुकूलन श्रेणी:डेटा प्रवाह विश्लेषण