उपयोग-परिभाषित श्रृंखला: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
Line 5: Line 5:
यूडी चेन का एक समकक्ष परिभाषा-उपयोग श्रृंखला (डी यू चेन) है, जिसमें एक चर की परिभाषा, डी, और सभी उपयोग, यू, उस परिभाषा से बिना किसी अन्य हस्तक्षेप परिभाषा के पहुंच योग्य होते हैं।
यूडी चेन का एक समकक्ष परिभाषा-उपयोग श्रृंखला (डी यू चेन) है, जिसमें एक चर की परिभाषा, डी, और सभी उपयोग, यू, उस परिभाषा से बिना किसी अन्य हस्तक्षेप परिभाषा के पहुंच योग्य होते हैं।


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


== उद्देश्य ==
== उद्देश्य ==
Line 52: Line 52:
कथनों की सूची के क्रमिक कार्यान्वयन पर विचार करें, {{tmath|s(i)}}, और अब कथन पर गणना के रूप में क्या देखा जा सकता है,:
कथनों की सूची के क्रमिक कार्यान्वयन पर विचार करें, {{tmath|s(i)}}, और अब कथन पर गणना के रूप में क्या देखा जा सकता है,:


* बयान पर एक परिभाषा {{tmath|s(i)}} i <j के साथ j पर 'जीवित' है, अगर इसका किसी कथन पर उपयोग होता है {{tmath|s(k)}} के ≥ जे के साथ। बयान में जीवित परिभाषाओं का सम्मुच्चय i के रूप में दर्शाया गया है {{tmath|A(i)}} और जीवित परिभाषाओं की संख्या के रूप में <math>|A(i)|</math>.  ({{tmath|A(i)}} एक सरल लेकिन शक्तिशाली अवधारणा है: [[अंतरिक्ष जटिलता सिद्धांत]] में सैद्धांतिक और व्यावहारिक परिणाम, पहुंच जटिलता (I/O जटिलता), रजिस्टर आवंटन और स्मृति स्थानीयता शोषण पर आधारित हैं {{tmath|A(i)}}.)
* बयान पर एक परिभाषा {{tmath|s(i)}} i <j के साथ j पर 'जीवित' है, अगर इसका किसी कथन पर उपयोग होता है {{tmath|s(k)}} k≥ j के साथ। बयान में जीवित परिभाषाओं का सम्मुच्चय i के रूप में दर्शाया गया है {{tmath|A(i)}} और जीवित परिभाषाओं की संख्या के रूप में <math>|A(i)|</math>.  ({{tmath|A(i)}} एक सरल लेकिन शक्तिशाली अवधारणा है: [[अंतरिक्ष जटिलता सिद्धांत]] में सैद्धांतिक और व्यावहारिक परिणाम, पहुंच जटिलता (I/O जटिलता), रजिस्टर आवंटन और स्मृति स्थानीयता शोषण पर आधारित हैं {{tmath|A(i)}}.)
* बयान पर एक परिभाषा {{tmath|s(i)}} पिछली सभी परिभाषाओं को मारता है ({{tmath|s(k)}} k <i) के साथ समान चर के लिए।
* बयान पर एक परिभाषा {{tmath|s(i)}} पिछली सभी परिभाषाओं को मारता है ({{tmath|s(k)}} k <i) के साथ समान चर के लिए।


== डीफ़-यूज़-चेन == के लिए कार्यान्वयन उदाहरण
== डीफ़-यूज़-चेन == के लिए कार्यान्वयन उदाहरण
यह उदाहरण [[महत्तम सामान्य भाजक]] खोजने के लिए जावा एल्गोरिथम पर आधारित है। (यह समझना महत्वपूर्ण नहीं है कि यह फ़ंक्शन क्या करता है।)
यह उदाहरण [[महत्तम सामान्य भाजक]] खोजने के लिए जावा एल्गोरिथम पर आधारित है। (यह समझना महत्वपूर्ण नहीं है कि यह फ़ंक्शन क्या करता है।)


<वाक्यविन्यास लैंग = सी लाइन>
<वाक्यविन्यास लैंग = सी लाइन>
/**
/**
  * @param(a, b) विभाजक की गणना करने के लिए उपयोग किए जाने वाले मान।
  * @param(a, b) विभाजक की गणना करने के लिए उपयोग किए जाने वाले मान।
Line 76: Line 78:
     वापसी सी;
     वापसी सी;
}
}
</वाक्यविन्यास हाइलाइट>
</वाक्यविन्यास हाइलाइट>


वेरिएबल d के लिए सभी डीफ़-यूज़-चेन का पता लगाने के लिए, निम्न चरणों का पालन करें:
चर d के लिए सभी डीफ़-यूज़-चेन का पता लगाने के लिए, निम्न चरणों का पालन करें:


# पहली बार वेरिएबल को परिभाषित करने के लिए खोजें (एक्सेस लिखें)।
# पहली बार चर को परिभाषित करने के लिए खोजें (एक्सेस लिखें)।
#: इस मामले में यह है{{code|1=d=b}}(एल.7)
#: इस मामले में यह है{{code|1=d=b}}(एल.7)
# पहली बार वेरिएबल को पढ़ने के लिए खोजें।
# पहली बार चर को पढ़ने के लिए खोजें।
#: इस मामले में यह है{{code|1=return d}}# इस जानकारी को निम्न शैली में लिखें: [उस चर का नाम जिसके लिए आप एक डीफ़-यूज़-चेन बना रहे हैं, कंक्रीट राइट एक्सेस, कंक्रीट रीड एक्सेस]
#: इस मामले में यह है{{code|1=return d}}इस जानकारी को निम्न शैली में लिखें: [उस चर का नाम जिसके लिए आप एक डीफ़-यूज़-चेन बना रहे हैं, कंक्रीट राइट एक्सेस, कंक्रीट रीड एक्सेस]
#: इस मामले में यह है: {{code|1=[d, d=b, return d]}}
#: इस मामले में यह है: {{code|1=[d, d=b, return d]}}
निम्नलिखित चरणों में इन चरणों को दोहराएं: प्रत्येक पढ़ने की पहुंच के साथ प्रत्येक लेखन पहुंच को संयोजित करें (लेकिन दूसरे तरीके से नहीं)
निम्नलिखित चरणों में इन चरणों को दोहराएं: प्रत्येक पढ़ने की पहुंच के साथ प्रत्येक लेखन पहुंच को संयोजित करें (लेकिन दूसरे तरीके से नहीं)।स्वत: कोड अनुकूलन के लिए संकलन-समय कार्यक्रम विश्लेषण के तरीकों में सामान्यतः  नियंत्रण प्रवाह विश्लेषण सम्मिलित होता है, जिसमें संभावित निष्पादन प्रवाह पथों को मॉडल किया जाता है, और डेटा प्रवाह विश्लेषण, जिसमें डेटा रिलेशियोशिप्स को मॉडल किया जाता है। उपयोग-परिभाषा श्रृंखलाओं के माध्यम से एक कार्यक्रम में डेटा संबंधों का एक प्रतिनिधित्व, एक विशेष उदाहरण समस्या के आलोक में जांचा जाता है - "बेकार" संगणना का वैश्विक उन्मूलन। दो उन्मूलन एल्गोरिदम जो अलग-अलग संगठित उपयोग-परिभाषा श्रृंखलाओं का उपयोग करते हैं, प्रस्तुत किए जाते हैं और प्रवाह ग्राफ के दो विकट रूप से भिन्न परिवारों पर अंतरिक्ष जटिलता के लिए तुलना की जाती है। दोनों किस्मों की श्रृंखलाओं की गणना करने के लिए एल्गोरिदम भी विकसित किए गए हैं।


परिणाम होना चाहिए:
परिणाम होना चाहिए:
<वाक्यविन्यास लैंग = सी लाइन>
<वाक्यविन्यास लैंग = सी लाइन>
  [डी, डी = बी, रिटर्न डी]
  [डी, डी = बी, रिटर्न डी]
Line 99: Line 103:
  [डी, डी=डी-सी, डी=डी-सी]
  [डी, डी=डी-सी, डी=डी-सी]
</वाक्यविन्यास हाइलाइट>
</वाक्यविन्यास हाइलाइट>
आपको ध्यान रखना होगा, यदि चर समय के अनुसार बदल जाता है।
आपको ध्यान रखना होगा, यदि चर समय के अनुसार बदल जाता है।


उदाहरण के लिए: स्रोत कोड में पंक्ति 7 नीचे से पंक्ति 13 तक, {{mono|d}} पुनर्परिभाषित / परिवर्तित नहीं किया गया है।
उदाहरण के लिए: स्रोत कोड में पंक्ति 7 नीचे से पंक्ति 13 तक, {{mono|d}} पुनर्परिभाषित / परिवर्तित नहीं किया गया है।
लाइन 14 पर, {{mono|d}} पुनर्परिभाषित किया जा सकता है। यही कारण है कि आपको इस राइट एक्सेस को फिर से जोड़ना होगा {{mono|d}} सभी संभावित पठन पहुंचों के साथ जिन तक पहुंचा जा सकता है।
लाइन 14 पर, {{mono|d}} पुनर्परिभाषित किया जा सकता है। यही कारण है कि आपको इस राइट एक्सेस को फिर से जोड़ना होगा {{mono|d}} सभी संभावित पठन पहुंचों के साथ जिन तक पहुंचा जा सकता है।
इस स्थिति में, केवल पंक्ति 10 के बाद का कोड प्रासंगिक है। लाइन 7, उदाहरण के लिए, फिर से नहीं पहुँचा जा सकता। आपकी समझ के लिए, आप 2 अलग-अलग चरों की कल्पना कर सकते हैं {{mono|d}}:
 
इस स्थिति में, केवल पंक्ति 10 के बाद का कोड प्रासंगिक है। लाइन 7, उदाहरण के लिए, फिर से नहीं पहुँचा जा सकता। आपकी समझ के लिए, आप 2 अलग-अलग चरों की कल्पना कर सकते हैं  
 
<वाक्यविन्यास लैंग = सी लाइन>
<वाक्यविन्यास लैंग = सी लाइन>
  [डी1, डी1=बी, रिटर्न डी1]
  [डी1, डी1=बी, रिटर्न डी1]
Line 117: Line 125:


नतीजतन, आपको ऐसा कुछ मिल सकता है। चर {{mono|d1}} द्वारा प्रतिस्थापित किया जाएगा {{mono|b}}
नतीजतन, आपको ऐसा कुछ मिल सकता है। चर {{mono|d1}} द्वारा प्रतिस्थापित किया जाएगा {{mono|b}}
<वाक्यविन्यास लैंग = सी लाइन>
<वाक्यविन्यास लैंग = सी लाइन>
/**
/**
Line 145: Line 154:
</वाक्यविन्यास हाइलाइट>
</वाक्यविन्यास हाइलाइट>


== उपयोग-डीईएफ़ (या ud) श्रृंखला बनाने की विधि ==
== उपयोग-डीईएफ़ (या यू डी ) श्रृंखला बनाने की विधि ==
{{Confusing section|date=January 2007}}
{{Confusing section|date=January 2007}}
# कथन में परिभाषाएँ निर्धारित करें {{tmath|s(0)}}
# कथन में परिभाषाएँ निर्धारित करें {{tmath|s(0)}}
Line 156: Line 165:


# एक निर्देशित विश्वकोश ग्राफ (DAG) चर उपयोगों और परिभाषाओं पर बनाया गया है। डीएजी प्रदत्त कार्य कथनों के साथ-साथ [[आंशिक आदेश]] (इसलिए विवरण  के बीच समानता) के बीच डेटा निर्भरता निर्दिष्ट करता है।
# एक निर्देशित विश्वकोश ग्राफ (DAG) चर उपयोगों और परिभाषाओं पर बनाया गया है। डीएजी प्रदत्त कार्य कथनों के साथ-साथ [[आंशिक आदेश]] (इसलिए विवरण  के बीच समानता) के बीच डेटा निर्भरता निर्दिष्ट करता है।
#कब बयान {{tmath|s(i)}} तक पहुँच गया है, तो लाइव वेरिएबल प्रदत्त कार्य की एक सूची है। यदि केवल एक प्रदत्त कार्य लाइव है, उदाहरण के लिए, निरंतर प्रसार का उपयोग किया जा सकता है।
#कब बयान {{tmath|s(i)}} तक पहुँच गया है, तो लाइव चर प्रदत्त कार्य की एक सूची है। यदि केवल एक प्रदत्त कार्य लाइव है, उदाहरण के लिए, निरंतर प्रसार का उपयोग किया जा सकता है।


{{Compiler optimizations}}
{{Compiler optimizations}}

Revision as of 10:48, 25 February 2023

कंप्यूटर विज्ञान के अन्तर्गत , एक उपयोग-परिभाषा श्रृंखला (यू डी चेन) एक डेटा संरचना है जिसमें एक चर (प्रोग्रामिंग) का उपयोग, यू, और उस चर के सभी परिभाषाएं, जो किसी अन्य हस्तक्षेप की परिभाषा के बिना उस उपयोग तक पहुंच सकते हैं। एक यू डी चेन का तात्पर्य सामान्यतः एक चर के लिए कुछ मूल्य का प्रदत्त कार्य (कंप्यूटर विज्ञान) होता है।

यूडी चेन का एक समकक्ष परिभाषा-उपयोग श्रृंखला (डी यू चेन) है, जिसमें एक चर की परिभाषा, डी, और सभी उपयोग, यू, उस परिभाषा से बिना किसी अन्य हस्तक्षेप परिभाषा के पहुंच योग्य होते हैं।

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

उद्देश्य

यूज-डिफाइन या डिफाइन-यूज चेन बनाना सजीवता विश्लेषण का एक कदम है, ताकि सभी चर राशियों के तार्किक अभिवेदन को कोड के जरिए पहचाना और ट्रैक किया जा सके।

कोड के निम्नलिखित स्निपेट पर विचार करें:

<वाक्यविन्यास प्रकाश लैंग = सी>

इंट एक्स = 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 पर 'जीवित' है, अगर इसका किसी कथन पर उपयोग होता है k≥ j के साथ। बयान में जीवित परिभाषाओं का सम्मुच्चय i के रूप में दर्शाया गया है और जीवित परिभाषाओं की संख्या के रूप में . ( एक सरल लेकिन शक्तिशाली अवधारणा है: अंतरिक्ष जटिलता सिद्धांत में सैद्धांतिक और व्यावहारिक परिणाम, पहुंच जटिलता (I/O जटिलता), रजिस्टर आवंटन और स्मृति स्थानीयता शोषण पर आधारित हैं .)
  • बयान पर एक परिभाषा पिछली सभी परिभाषाओं को मारता है ( k <i) के साथ समान चर के लिए।

== डीफ़-यूज़-चेन == के लिए कार्यान्वयन उदाहरण

यह उदाहरण महत्तम सामान्य भाजक खोजने के लिए जावा एल्गोरिथम पर आधारित है। (यह समझना महत्वपूर्ण नहीं है कि यह फ़ंक्शन क्या करता है।)

<वाक्यविन्यास लैंग = सी लाइन>

/**

* @param(a, b) विभाजक की गणना करने के लिए उपयोग किए जाने वाले मान।
* @return a और b का महत्तम समापवर्तक है।
*/

इंट जीसीडी (इंट ए, इंट बी) {

   इंट सी = ए;
   इंट डी = बी;
   अगर (सी == 0)
       वापसी घ;
   जबकि (डी! = 0) {
       अगर (सी> डी)
           सी = सी - डी;
       अन्य
           डी = डी - सी;
   }
   वापसी सी;

}

</वाक्यविन्यास हाइलाइट>

चर d के लिए सभी डीफ़-यूज़-चेन का पता लगाने के लिए, निम्न चरणों का पालन करें:

  1. पहली बार चर को परिभाषित करने के लिए खोजें (एक्सेस लिखें)।
    इस मामले में यह हैd=b(एल.7)
  2. पहली बार चर को पढ़ने के लिए खोजें।
    इस मामले में यह है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) {
           अगर (सी> डी)
               सी = सी - डी;
           अन्य
               डी = डी - सी;
       }
   }
   वापसी सी;

} </वाक्यविन्यास हाइलाइट>

उपयोग-डीईएफ़ (या यू डी ) श्रृंखला बनाने की विधि

  1. कथन में परिभाषाएँ निर्धारित करें
  2. प्रत्येक के लिए i में , लाइव परिभाषाएँ खोजें जिनका उपयोग कथन में किया गया है
  3. परिभाषाओं और उपयोगों के बीच संबंध बनाएं
  4. स्टेटमेंट सम्मुच्चय करें , परिभाषा कथन के रूप में
  5. पिछली परिभाषाओं को मारें

इस एल्गोरिथम के साथ, दो चीजें पूरी होती हैं:

  1. एक निर्देशित विश्वकोश ग्राफ (DAG) चर उपयोगों और परिभाषाओं पर बनाया गया है। डीएजी प्रदत्त कार्य कथनों के साथ-साथ आंशिक आदेश (इसलिए विवरण के बीच समानता) के बीच डेटा निर्भरता निर्दिष्ट करता है।
  2. कब बयान तक पहुँच गया है, तो लाइव चर प्रदत्त कार्य की एक सूची है। यदि केवल एक प्रदत्त कार्य लाइव है, उदाहरण के लिए, निरंतर प्रसार का उपयोग किया जा सकता है।

श्रेणी:संकलक अनुकूलन श्रेणी:डेटा प्रवाह विश्लेषण