उपयोग-परिभाषित श्रृंखला
कंप्यूटर विज्ञान के अन्तर्गत , एक उपयोग-परिभाषा श्रृंखला (यू डी चेन) एक डेटा संरचना है जिसमें एक चर (प्रोग्रामिंग) का उपयोग, यू, और उस चर के सभी परिभाषाएं, जो किसी अन्य हस्तक्षेप की परिभाषा के बिना उस उपयोग तक पहुंच सकते हैं। एक यू डी चेन का तात्पर्य सामान्यतः एक चर के लिए कुछ मूल्य का प्रदत्त कार्य (कंप्यूटर विज्ञान) होता है।
यूडी चेन का एक समकक्ष परिभाषा-उपयोग श्रृंखला (डी यू चेन) है, जिसमें एक चर की परिभाषा, डी, और सभी उपयोग, यू, उस परिभाषा से बिना किसी अन्य हस्तक्षेप परिभाषा के पहुंच योग्य होते हैं।
यू डी और डी यू दोनों श्रृंखलाएं डेटा प्रवाह विश्लेषण के रूप में जाने वाले स्थिर कोड विश्लेषण के एक रूप का उपयोग करके बनाई गई हैं। किसी प्रोग्राम या सबप्रोग्राम के लिए यूज़-डीफ़ और डीफ़-यूज़ चेन को जानना कई संकलक अनुकूलन के लिए एक शर्त है, जिसमें निरंतर प्रचार और सामान्य उप-अभिव्यक्ति उन्मूलन सम्मिलित है।
उद्देश्य
यूज-डिफाइन या डिफाइन-यूज चेन बनाना सजीवता विश्लेषण का एक कदम है, ताकि सभी चर राशियों के तार्किक अभिवेदन को कोड के जरिए पहचाना और ट्रैक किया जा सके।
कोड के निम्नलिखित स्निपेट पर विचार करें:
int x = 0; /* A */
x = x + y; /* B */
/* 1, some uses of x */
x = 35; /* C */
/* 2, some more uses of x */
ध्यान दें कि x को तीन बिंदुओं (चिह्नित A, B और C) पर एक मान दिया गया है। हालाँकि, "1" चिह्नित बिंदु पर, x के लिए उपयोग-डेफ श्रृंखला को इंगित करना चाहिए कि इसका वर्तमान मान लाइन B से आया होगा (और लाइन B पर इसका मान लाइन A से आया होगा)।इसके विपरीत, "2" चिह्नित बिंदु पर, x के लिए उपयोग-डेफ श्रृंखला इंगित करती है कि इसका वर्तमान मान लाइन सी से आया होगा। चूंकि ब्लॉक 2 में x का मान ब्लॉक 1 या इससे पहले की किसी भी परिभाषा पर निर्भर नहीं करता है, x वहाँ एक भिन्न चर भी हो सकता है; व्यावहारिक रूप से बोलना, यह एक भिन्न चर है - इसे x2 कहते हैं।
int x = 0; /* A */
x = x + y; /* B */
/* 1, some uses of x */
int x2 = 35; /* C */
/* 2, some uses of x2 */
x को दो अलग-अलग चर राशियों में विभाजित करने की प्रक्रिया को लाइव रेंज स्प्लिटिंग कहा जाता है। स्टैटिक सिंगल असाइनमेंट फॉर्म भी देखें।
व्यवस्थापन
विवरण की सूची विवरण के बीच एक मजबूत क्रम निर्धारित करती है।
- निम्नलिखित परिपाटियों का उपयोग करते हुए कथनों को लेबल किया गया है: , जहाँ i एक पूर्णांक है ; और n बुनियादी ब्लॉक में विवरण की संख्या है
- चर राशि को इटैलिक में पहचाना जाता है(जैसे, वी, यू और टी)
- प्रत्येक चर को संदर्भ या दायरे में एक परिभाषा माना जाता है। (स्थिर एकल प्रदत्त कार्य फॉर्म में, यूज-डिफाइन चेन स्पष्ट हैं क्योंकि प्रत्येक चेन में एक ही तत्व होता है।)
एक चर के लिए, जैसे v, इसकी घोषणा की पहचान V (इटैलिक कैपिटल लेटर) के रूप में की जाती है, और संक्षेप में, इसकी घोषणा के रूप में पहचान की जाती है सामान्य तौर पर, एक चर की घोषणा बाहरी दायरे में हो सकती है (उदाहरण के लिए, एक वैश्विक चर)।
एक चर की परिभाषा
जब एक चर, v, एक प्रदत्त कार्य स्टेटमेंट के समीकरण के बाईं ओर और दाईं ओर होता है, जैसे कि , तब v की एक परिभाषा है। प्रत्येक चर (v) की घोषणा (V) (या आरंभीकरण) द्वारा कम से कम एक परिभाषा है।
एक चर का प्रयोग
यदि चर, v, कथन के दाएँ पक्ष में है , एक बयान है, मैं <जे और के साथ , कि यह v की परिभाषा है और इसका उपयोग at है (या, संक्षेप में, जब एक चर, v, एक कथन के दाएँ पक्ष पर है , तो v का कथन पर उपयोग है
निष्पादन
कथनों की सूची के क्रमिक कार्यान्वयन पर विचार करें, , और अब कथन पर गणना के रूप में क्या देखा जा सकता है,:
- बयान पर एक परिभाषा i <j के साथ j पर 'जीवित' है, अगर इसका किसी कथन पर उपयोग होता है k≥ 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 अलग-अलग चरों की कल्पना कर सकते हैं
<वाक्यविन्यास लैंग = सी लाइन>
[डी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) { अगर (सी> डी) सी = सी - डी; अन्य डी = डी - सी; } } वापसी सी;
} </वाक्यविन्यास हाइलाइट>
उपयोग-डीईएफ़ (या यू डी ) श्रृंखला बनाने की विधि
- कथन में परिभाषाएँ निर्धारित करें
- प्रत्येक के लिए i में , लाइव परिभाषाएँ खोजें जिनका उपयोग कथन में किया गया है
- परिभाषाओं और उपयोगों के बीच संबंध बनाएं
- स्टेटमेंट सम्मुच्चय करें , परिभाषा कथन के रूप में
- पिछली परिभाषाओं को मारें
इस एल्गोरिथम के साथ, दो चीजें पूरी होती हैं:
- एक निर्देशित विश्वकोश ग्राफ (DAG) चर उपयोगों और परिभाषाओं पर बनाया गया है। डीएजी प्रदत्त कार्य कथनों के साथ-साथ आंशिक आदेश (इसलिए विवरण के बीच समानता) के बीच डेटा निर्भरता निर्दिष्ट करता है।
- कब बयान तक पहुँच गया है, तो लाइव चर प्रदत्त कार्य की एक सूची है। यदि केवल एक प्रदत्त कार्य लाइव है, उदाहरण के लिए, निरंतर प्रसार का उपयोग किया जा सकता है।
श्रेणी:संकलक अनुकूलन श्रेणी:डेटा प्रवाह विश्लेषण