कॉल ग्राफ: Difference between revisions
No edit summary |
No edit summary |
||
| (9 intermediate revisions by 4 users not shown) | |||
| Line 1: | Line 1: | ||
[[File:A Call Graph generated by pycallgraph.png|thumb|पायथन में एक साधारण कंप्यूटर प्रोग्राम के लिए उत्पन्न कॉल ग्राफ़।]]कॉल ग्राफ़ (जिसे कॉल मल्टीग्राफ़ के रूप में भी जाना जाता है<ref>{{cite journal |last1=Callahan |first1=D. |last2=Carle |first2=A. |last3=Hall |first3=M.W. |last4=Kennedy |first4=K. |title=Constructing the procedure call multigraph |journal=IEEE Transactions on Software Engineering |date=April 1990 |volume=16 |issue=4 |pages=483–487 |doi=10.1109/32.54302}}</ref><ref name="KhedkerSanyal2009">{{cite book|author1=Uday Khedker|author2=Amitabha Sanyal|author3=Bageshri Sathe|title=Data Flow Analysis: Theory and Practice|year=2009|publisher=CRC Press|isbn=978-0-8493-3251-7|page=234}}</ref>) एक [[नियंत्रण-प्रवाह ग्राफ]] है,<ref name="Jalote1997">{{cite book|author=Pankaj Jalote|title=An Integrated Approach to Software Engineering|year=1997|publisher=Springer Science & Business Media|isbn=978-0-387-94899-7|page=[https://archive.org/details/integratedapproa0000jalo/page/372 372]|url-access=registration|url=https://archive.org/details/integratedapproa0000jalo/page/372}}</ref> जो एक [[कंप्यूटर प्रोग्राम]] में [[Index.php?title=सबरूटीन्स|सबरूटीन्स]] के बीच कॉलिंग संबंधों का प्रतिनिधित्व करता है। प्रत्येक नोड एक प्रक्रिया का प्रतिनिधित्व करता है और प्रत्येक | [[File:A Call Graph generated by pycallgraph.png|thumb|पायथन में एक साधारण कंप्यूटर प्रोग्राम के लिए उत्पन्न कॉल ग्राफ़।]]कॉल ग्राफ़ (जिसे कॉल मल्टीग्राफ़ के रूप में भी जाना जाता है<ref>{{cite journal |last1=Callahan |first1=D. |last2=Carle |first2=A. |last3=Hall |first3=M.W. |last4=Kennedy |first4=K. |title=Constructing the procedure call multigraph |journal=IEEE Transactions on Software Engineering |date=April 1990 |volume=16 |issue=4 |pages=483–487 |doi=10.1109/32.54302}}</ref><ref name="KhedkerSanyal2009">{{cite book|author1=Uday Khedker|author2=Amitabha Sanyal|author3=Bageshri Sathe|title=Data Flow Analysis: Theory and Practice|year=2009|publisher=CRC Press|isbn=978-0-8493-3251-7|page=234}}</ref>) यह एक [[नियंत्रण-प्रवाह ग्राफ]] है,<ref name="Jalote1997">{{cite book|author=Pankaj Jalote|title=An Integrated Approach to Software Engineering|year=1997|publisher=Springer Science & Business Media|isbn=978-0-387-94899-7|page=[https://archive.org/details/integratedapproa0000jalo/page/372 372]|url-access=registration|url=https://archive.org/details/integratedapproa0000jalo/page/372}}</ref> जो एक [[कंप्यूटर प्रोग्राम]] में [[Index.php?title=सबरूटीन्स|सबरूटीन्स]] के बीच कॉलिंग संबंधों का प्रतिनिधित्व करता है। प्रत्येक नोड एक प्रक्रिया का प्रतिनिधित्व करता है और प्रत्येक आधार पर (एफ, जी) इंगित कर एफ कॉल प्रक्रिया को इस प्रकार, ग्राफ में एक [[चक्र (ग्राफ सिद्धांत)]] पुनरावर्ती प्रक्रिया कॉल को इंगित करता है। | ||
== बुनियादी अवधारणाएँ == | == बुनियादी अवधारणाएँ == | ||
कॉल ग्राफ़ गतिशील या स्थिर हो सकते हैं।<ref>{{cite journal |last1=Ryder |first1=B.G. |title=Constructing the Call Graph of a Program |journal=IEEE Transactions on Software Engineering |date=May 1979 |volume=SE-5 |issue=3 |pages=216–226 |doi=10.1109/tse.1979.234183}}</ref> डायनेमिक कॉल ग्राफ़ प्रोग्राम के निष्पादन का एक रिकॉर्ड है, उदाहरण के लिए एक प्रोफाइलर द्वारा आउटपुट के रूप में। इस प्रकार, एक डायनेमिक कॉल ग्राफ़ सटीक हो सकता है, परंतु एकमात्र प्रोग्राम के एक रन का वर्णन करता है। एक स्थिर कॉल ग्राफ़ जिसका उद्देश्य प्रोग्राम के हर संभव रन का प्रतिनिधित्व करना है। सटीक स्थैतिक कॉल ग्राफ़ एक [[अनिर्णीत समस्या]] है, इसलिए स्थैतिक कॉल ग्राफ़ एल्गोरिदम सामान्यतः अतिरेक हैं। अर्थात्, होने वाले प्रत्येक कॉल संबंध को ग्राफ़ में दर्शाया जाता है, और संभवतः कुछ कॉल संबंध भी होते हैं जो प्रोग्राम के वास्तविक रन में कभी नहीं | कॉल ग्राफ़ गतिशील या स्थिर हो सकते हैं।<ref>{{cite journal |last1=Ryder |first1=B.G. |title=Constructing the Call Graph of a Program |journal=IEEE Transactions on Software Engineering |date=May 1979 |volume=SE-5 |issue=3 |pages=216–226 |doi=10.1109/tse.1979.234183}}</ref> डायनेमिक कॉल ग्राफ़ प्रोग्राम के निष्पादन का एक रिकॉर्ड है, उदाहरण के लिए एक प्रोफाइलर द्वारा आउटपुट के रूप में। इस प्रकार, एक डायनेमिक कॉल ग्राफ़ सटीक हो सकता है, परंतु एकमात्र प्रोग्राम के एक रन का वर्णन करता है। एक स्थिर कॉल ग्राफ़ जिसका उद्देश्य प्रोग्राम के हर संभव रन का प्रतिनिधित्व करना है। सटीक स्थैतिक कॉल ग्राफ़ एक [[अनिर्णीत समस्या]] है, इसलिए स्थैतिक कॉल ग्राफ़ एल्गोरिदम सामान्यतः अतिरेक हैं। अर्थात्, होने वाले प्रत्येक कॉल संबंध को ग्राफ़ में दर्शाया जाता है, और संभवतः कुछ कॉल संबंध भी होते हैं जो प्रोग्राम के वास्तविक रन में कभी नहीं होते है। | ||
सटीकता की अलग-अलग डिग्री का प्रतिनिधित्व करने के लिए कॉल ग्राफ़ को परिभाषित किया जा सकता है। अधिक सटीक कॉल ग्राफ़ अधिक सटीक रूप से वास्तविक प्रोग्राम के व्यवहार का अनुमान लगाता है, गणना करने में अधिक समय लेने और स्टोर करने के लिए अधिक मेमोरी की योग्यता पर। सबसे सटीक कॉल ग्राफ़ पूरी तरह से संदर्भ-संवेदनशील है, जिसका अर्थ है कि प्रत्येक प्रक्रिया के लिए, ग्राफ़ में प्रत्येक [[कॉल स्टैक]] के लिए एक अलग नोड होता है जिसके साथ प्रक्रिया को सक्रिय किया जा सकता है। एक पूरी तरह से संदर्भ-संवेदनशील कॉल ग्राफ़ को कॉलिंग संदर्भ ट्री कहा जाता है। इसकी गतिशील रूप से सुगमता से गणना की जा सकती है, चूंकि इसमें बड़ी मात्रा में मेमोरी लग सकती है। [[कॉलिंग कॉन्टेक्स्ट ट्री]] की सामान्यतः स्टेटिक रूप से गणना नहीं की जाती है, चूंकि एक बड़े प्रोग्राम के लिए इसमें बहुत अधिक समय लगेगा। कम से कम सटीक कॉल ग्राफ़ संदर्भ-असंवेदनशील है, जिसका अर्थ है कि प्रत्येक प्रक्रिया के लिए एकमात्र नोड है। | सटीकता की अलग-अलग डिग्री का प्रतिनिधित्व करने के लिए कॉल ग्राफ़ को परिभाषित किया जा सकता है। अधिक सटीक कॉल ग्राफ़ अधिक सटीक रूप से वास्तविक प्रोग्राम के व्यवहार का अनुमान लगाता है, गणना करने में अधिक समय लेने और स्टोर करने के लिए अधिक मेमोरी की योग्यता पर। सबसे सटीक कॉल ग्राफ़ पूरी तरह से संदर्भ-संवेदनशील है, जिसका अर्थ है कि प्रत्येक प्रक्रिया के लिए, ग्राफ़ में प्रत्येक [[कॉल स्टैक]] के लिए एक अलग नोड होता है जिसके साथ प्रक्रिया को सक्रिय किया जा सकता है। एक पूरी तरह से संदर्भ-संवेदनशील कॉल ग्राफ़ को कॉलिंग संदर्भ ट्री कहा जाता है। इसकी गतिशील रूप से सुगमता से गणना की जा सकती है, चूंकि इसमें बड़ी मात्रा में मेमोरी लग सकती है। [[कॉलिंग कॉन्टेक्स्ट ट्री]] की सामान्यतः स्टेटिक रूप से गणना नहीं की जाती है, चूंकि एक बड़े प्रोग्राम के लिए इसमें बहुत अधिक समय लगेगा। कम से कम सटीक कॉल ग्राफ़ संदर्भ-असंवेदनशील है, जिसका अर्थ है कि प्रत्येक प्रक्रिया के लिए एकमात्र नोड है। | ||
| Line 22: | Line 22: | ||
* कॉलग्रिंड : [[Index.php?title=वेलग्रिंड|वेलग्रिंड]] का हिस्सा है। | * कॉलग्रिंड : [[Index.php?title=वेलग्रिंड|वेलग्रिंड]] का हिस्सा है। | ||
* [https://केचेग्रिंड.github.io/html/Home.html केचेग्रिंड] : कॉलग्रिंड द्वारा उत्पन्न डेटा के आधार पर कॉल ग्राफ़ बनाने और उनका विश्लेषण करने के लिए शक्तिशाली उपकरण होता है। | * [https://केचेग्रिंड.github.io/html/Home.html केचेग्रिंड] : कॉलग्रिंड द्वारा उत्पन्न डेटा के आधार पर कॉल ग्राफ़ बनाने और उनका विश्लेषण करने के लिए शक्तिशाली उपकरण होता है। | ||
* मैक ओएस एक्स एक्टिविटी मॉनिटर: ऐप्पल जीयूआई प्रोसेस मॉनिटर एक्टिविटी मॉनिटर में एक अंतर्निहित कॉल ग्राफ़ जनरेटर है जो प्रक्रियाओं का प्रतिरूप ले सकता है और कॉल ग्राफ़ वापस कर सकता है। यह फ़ंक्शन एकमात्र [[Index.php?title=मैक ओएस एक्स|मैक ओएस एक्स]] | * मैक ओएस एक्स एक्टिविटी मॉनिटर: ऐप्पल जीयूआई प्रोसेस मॉनिटर एक्टिविटी मॉनिटर में एक अंतर्निहित कॉल ग्राफ़ जनरेटर है जो प्रक्रियाओं का प्रतिरूप ले सकता है और कॉल ग्राफ़ वापस कर सकता है। यह फ़ंक्शन एकमात्र [[Index.php?title=मैक ओएस एक्स|मैक ओएस एक्स]] लेपर्ड में उपलब्ध है। | ||
* ओपनपैट : इसमें सम्मलित है <code>नियंत्रण प्रवाह</code>उपकरण जो स्वचालित रूप से रनटाइम मापन से एक [[ग्राफ विज़ुअलाइज़ेशन]] कॉल-ग्राफ़ चित्र बनाता है। | * ओपनपैट : इसमें सम्मलित है <code>नियंत्रण प्रवाह</code>उपकरण जो स्वचालित रूप से रनटाइम मापन से एक [[ग्राफ विज़ुअलाइज़ेशन]] कॉल-ग्राफ़ चित्र बनाता है। | ||
* [https://github.com/google/पी प्रो पी प्रो], प्रोफ़ाइल डेटा के विज़ुअलाइज़ेशन और विश्लेषण के लिए ओपन सोर्स टूल, जिसका उपयोग [https://web.archive.org/web/20150904193554/http: ग्रफटूल ग्रफटूल] के संयोजन में किया जाता है। | * [https://github.com/google/पी प्रो पी प्रो], प्रोफ़ाइल डेटा के विज़ुअलाइज़ेशन और विश्लेषण के लिए ओपन सोर्स टूल, जिसका उपयोग [https://web.archive.org/web/20150904193554/http: ग्रफटूल ग्रफटूल] के संयोजन में किया जाता है। | ||
* [[एएमडी]] से कोड विश्लेषक (जीपीएल के तहत जारी) | * [[एएमडी]] से कोड विश्लेषक (जीपीएल के तहत जारी) | ||
* [http://makepp.sourceforge.net/gallery/ | * [http://makepp.sourceforge.net/gallery/ मेक-अपग्राफ मेक-अपग्राफ] मेक (सॉफ़्टवेयर)#आधुनिक संस्करणों के साथ किए गए बिल्ड के लिए एक निर्भरता ग्राफ़ जेनरेटर (मॉड्यूल स्तर पर) है। | ||
* [https://github.com/01org/IntelSEAPI/wiki Intel(R) सिंगल इवेंट एपीआई] (मुफ्त, ओपन-सोर्स) | * [https://github.com/01org/IntelSEAPI/wiki Intel(R) सिंगल इवेंट एपीआई] (मुफ्त, ओपन-सोर्स) | ||
==== एप्लिकेशन चलाए बिना कॉल ग्राफ़ प्राप्त करने के लिए स्थिर ==== | ==== एप्लिकेशन चलाए बिना कॉल ग्राफ़ प्राप्त करने के लिए स्थिर होना ==== | ||
; सी/सी ++ | ; सी/सी ++ | ||
* [[सोर्सट्रेल]] एक स्थिर कॉल ग्राफ बनाता है, जिसे उपयोगकर्ता द्वारा गतिशील रूप से खोजा जा सकता है। पायथन और जावा का भी समर्थन करता | * [[सोर्सट्रेल]] एक स्थिर कॉल ग्राफ बनाता है, जिसे उपयोगकर्ता द्वारा गतिशील रूप से खोजा जा सकता है। पायथन और जावा का भी समर्थन करता है। | ||
* [[ | * [[Index.php?title=डॉक्सिजन|डॉक्सिजन]] : स्टैटिक कॉल/इनहेरिटेंस आरेख उत्पन्न करने के लिए ग्राफ़विज़ का उपयोग करता है। | ||
* [[ | * [[Index.php?title=जीएनयू प्रवाह|जीएनयू प्रवाह]] : एक C प्रोग्राम का डायरेक्ट और इनवर्टेड कॉल ग्राफ़ उत्पन्न करने में सक्षम है। | ||
* [http://www.gson.org/egypt/ | * [http://www.gson.org/egypt/ ईजिप्ट ईजिप्ट] : एक छोटी सी [[पर्ल]] स्क्रिप्ट जो सी प्रोग्राम के स्टेटिक कॉल ग्राफ को उत्पन्न करने के लिए जीसीसी और [[ग्रप्ह्वइज़]] का उपयोग करती है। | ||
* [http://www.analizo.org/ एनालिज़ो]: स्रोत कोड मेट्रिक्स की गणना करता है, निर्भरता ग्राफ उत्पन्न करता है। | * [http://www.analizo.org/ एनालिज़ो]: स्रोत कोड मेट्रिक्स की गणना करता है, निर्भरता ग्राफ उत्पन्न करता है। | ||
* [https://www.vim.org/scripts/script.php?script_id=2368 | * [https://www.vim.org/scripts/script.php?script_id=2368 सीसी ट्री सीसी ट्री] : नेटिव [[विम (पाठ संपादक)]] प्लगइन जो सीएस कोप डेटाबेस को पढ़कर स्टेटिक कॉल ग्राफ़ प्रदर्शित कर सकता है। सी कार्यक्रमों के लिए काम करता है। | ||
* [https://github.com/petersenna/codeviz | * [https://github.com/petersenna/codeviz कोडविज़ कोडविज़] : एक स्थिर कॉल ग्राफ जनरेटर (कार्यक्रम नहीं चलाया जाता है)। जीएनयू कंपाइलर संग्रह के पैच के रूप में लागू किया गया; सी और सी ++ प्रोग्राम के लिए काम करता है। | ||
* [http://toolchainguru.blogspot.com/2011/03/c-calltrees-in-bash-revisited.html | * [http://toolchainguru.blogspot.com/2011/03/c-calltrees-in-bash-revisited.html कॉलट्री.श कॉलट्री.श] : बैश शेल फंक्शंस जो [[सीस्कोप]], ग्राफविज़ और डॉट-रेंडरिंग टूल्स के प्रतिरूप को एक साथ जोड़ते हैं ऊपर, नीचे, और/या आपके द्वारा निर्दिष्ट सी कार्यों के बीच कॉलर और कैली संबंधों को प्रदर्शित करने के लिए। | ||
* [https://sourceforge.net/projects/ | * [https://sourceforge.net/projects/टेसेट्री/ टेसेट्री] : कॉलट्री.श की तरह, यह सीस्कोप और ग्राफविज़ को जोड़ता है, परंतु यह बैश स्क्रिप्ट के अतिरिक्त निष्पादन योग्य है। | ||
; | ;गो | ||
* [https://github.com/ofabry/ | * [https://github.com/ofabry/गो-कॉलवीज़ गो-कॉलवीज़] : गो प्रोग्राम के लिए एक इंटरैक्टिव कॉल ग्राफ़ जनरेटर जिसका आउटपुट ग्राफ़विज़ के साथ अंकित किया जा सकता है। | ||
बहु भाषा | बहु भाषा | ||
* [https://github.com/koknat/ | * [https://github.com/koknat/कॉलग्राफ कॉलग्राफ] : ऑक, बैश, बेसिक, डार्ट, फोरट्रान, गो, लुआ, जावास्क्रिप्ट, जूलिया, कोटलिन, मैटलैब, पर्ल, पास्कल, पीएचपी के लिए ओपन-सोर्स कॉल ग्राफ जेनरेटर, अजगर, आर, राकू, रूबी, रस्ट, स्काला, स्विफ्ट, टीसीएल और टाइपस्क्रिप्ट। | ||
; | ;नेट | ||
* [[ | * [[Index.php?title=एन डिपेन्ड|एन डिपेन्ड]] : . नेट कोड के लिए एक स्थिर विश्लेषण टूल है। यह उपकरण बड़ी संख्या में कोड मेट्रिक्स का समर्थन करता है, निर्देशित ग्राफ़ और निर्भरता मैट्रिक्स का उपयोग करके निर्भरता के कल्पना की अनुमति देता है। | ||
'''पीएचपी, पर्ल और पायथन''' | |||
* [https://metacpan.org/module/ | * [https://metacpan.org/module/डेवेल :: एनवाईटीप्रोफ डेवेल :: एनवाईटीप्रोफ] : एक पर्ल प्रदर्शन विश्लेषक और कॉल चार्ट जनरेटर है। | ||
* [http://phpcallgraph.sourceforge.net/ | * [http://phpcallgraph.sourceforge.net/ पीएचपी कॉलग्राफ पीएचपी कॉलग्राफ] : पीएचपी प्रोग्राम के लिए एक कॉल ग्राफ़ जनरेटर जो ग्राफ़विज़ का उपयोग करता है। यह पीएचपी में लिखा गया है और इसके लिए कम से कम पीएचपी 5.2 की आवश्यकता है। | ||
* [http://pycallgraph.slowchop.com/ | * [http://pycallgraph.slowchop.com/पी वाई कॉलग्राफ पी वाई कॉलग्राफ] : पायथन प्रोग्राम के लिए एक कॉल ग्राफ़ जनरेटर जो ग्राफ़विज़ का उपयोग करता है। | ||
* [https://github.com/davidfraser/ | * [https://github.com/davidfraser/प्यान प्यान] : ग्राफ़विज़ का उपयोग करने वाले पायथन प्रोग्राम के लिए एक स्थिर कॉल ग्राफ़ जनरेटर करता है। | ||
* [https://github.com/jrfonseca/ | * [https://github.com/jrfonseca/जीप्रो2डाट जीप्रो2डाट] : पायथन में लिखा गया एक कॉल ग्राफ़ जनरेटर जो कई भाषाओं/रनटाइम्स के लिए प्रोफाइलिंग डेटा को ग्राफ़विज़ कॉलग्राफ़ में परिवर्तित करता है। | ||
* [https://github.com/scottrogowski/ | * [https://github.com/scottrogowski/कोड2फ्लो कोड2फ्लो]: पायथन और जावास्क्रिप्ट प्रोग्राम के लिए एक कॉल ग्राफ़ जनरेटर जो ग्राफ़विज़ का उपयोग करता है। | ||
* [https://github.com/carlsborg/ | * [https://github.com/carlsborg/आरसीवीज आरसीवीज] : ग्राफ़विज़ के साथ रनटाइम-जेनरेट किए गए कॉल ग्राफ़ को प्रस्तुत करने के लिए पायथन मॉड्यूल। प्रत्येक नोड एक फ़ंक्शन के आह्वान का प्रतिनिधित्व करता है जिसमें इसे पास किए गए पैरामीटर और वापसी मान होता है। | ||
; | ;एक्स क्वेरी | ||
* [https://en. | * [https://en.विकिबुक्सs.org/wiki/एक्स क्वेरी/कॉल_ग्राफ एक्स क्वेरी विकिबुक्स से एक्स क्वेरी कॉल ग्राफ़]: एक्स क्वेरी फ़ंक्शन मॉड्यूल के लिए एक कॉल ग्राफ़ जनरेटर जो ग्राफ़विज़ का उपयोग करता है। | ||
=== | === प्रप्राइइटेरी कॉल ग्राफ जनरेटर === | ||
; [[एलडीआरए टेस्टबेड]]: कॉल ग्राफ़ सहित असंख्य रिपोर्ट के साथ होस्ट और एम्बेडेड सॉफ़्टवेयर दोनों के लिए स्थिर और गतिशील विश्लेषण | ; [[एलडीआरए टेस्टबेड]]: कॉल ग्राफ़ सहित असंख्य रिपोर्ट के साथ होस्ट और एम्बेडेड सॉफ़्टवेयर दोनों के लिए स्थिर और गतिशील विश्लेषण इंजन होता है। | ||
; [[परियोजना विश्लेषक]]: विजुअल बेसिक कोड के लिए स्टेटिक कोड एनालाइजर और कॉल ग्राफ जनरेटर | ; [[परियोजना विश्लेषक]]: विजुअल बेसिक कोड के लिए स्टेटिक कोड एनालाइजर और कॉल ग्राफ जनरेटर है। | ||
; [[दृश्य विशेषज्ञ]]: | ; [[दृश्य विशेषज्ञ]]: ओरेकल डेटाबेस PL/SQL, [[Index.php?title=माइक्रोसॉफ्ट एसक्यूएल सर्वर|माइक्रोसॉफ्ट एसक्यूएल सर्वर]] [[Index.php?title=ट्रैनसैक्ट-एसक्यूएल|ट्रैनसैक्ट-एसक्यूएल]], C शार्प (प्रोग्रामिंग लैंग्वेज)|C# और [[Index.php?title=पॉवर बिल्डर|पॉवर बिल्डर]] कोड के लिए [[स्थैतिक कार्यक्रम विश्लेषण]] और कॉल ग्राफ़ जनरेटर है। | ||
; [[ | ; [[Index.php?title=वी ट्यून|वी ट्यून]]: कॉल ग्राफ़ और निष्पादन आँकड़े दिखाने के लिए इंस्ट्रूमेंटिंग प्रोफाइलर होता है। | ||
; [[डीएमएस सॉफ्टवेयर रीइंजीनियरिंग टूलकिट]]: सी, जावा और कोबोल के लिए स्थिर पूरे कार्यक्रम वैश्विक कॉल ग्राफ निष्कर्षण के साथ अनुकूलन कार्यक्रम विश्लेषण उपकरण | ; [[डीएमएस सॉफ्टवेयर रीइंजीनियरिंग टूलकिट]]: सी, जावा और कोबोल के लिए स्थिर पूरे कार्यक्रम वैश्विक कॉल ग्राफ निष्कर्षण के साथ अनुकूलन कार्यक्रम विश्लेषण उपकरण है। | ||
=== अन्य, संबंधित उपकरण === | === अन्य, संबंधित उपकरण === | ||
; ग्राफ़विज़ : किसी भी ग्राफ़ (कॉल ग्राफ़ सहित) के पाठ प्रतिनिधित्व को चित्र में बदल देता है। | ; ग्राफ़विज़ : किसी भी ग्राफ़ (कॉल ग्राफ़ सहित) के पाठ प्रतिनिधित्व को चित्र में बदल देता है। | ||
; [[ | ; [[Index.php?title=टी सॉर्ट|टी सॉर्ट]]: कमांड-लाइन यूटिलिटी जो एक टोपोलॉजिकल टी सॉर्ट करती है। | ||
== सैम्पल ग्राफ == | |||
स्वयं का विश्लेषण करने वाले gprof से उत्पन्न एक सैम्पल कॉल ग्राफ़: | |||
<pre> | |||
index called name |index called name | |||
72384/72384 sym_id_parse [54] | 1508/1508 cg_dfn [15] | |||
[3] 72384 match [3] |[13] 1508 pre_visit [13] | |||
---------------------- |---------------------- | |||
4/9052 cg_tally [32] | 1508/1508 cg_assemble [38] | |||
3016/9052 hist_print [49] |[14] 1508 propagate_time [14] | |||
6032/9052 propagate_flags [52] |---------------------- | |||
[4] 9052 sym_lookup [4] | 2 cg_dfn [15] | |||
---------------------- | 1507/1507 cg_assemble [38] | |||
5766/5766 core_create_function_syms [41]|[15] 1507+2 cg_dfn [15] | |||
[5] 5766 core_sym_class [5] | 1509/1509 is_numbered [9] | |||
---------------------- | 1508/1508 is_busy [11] | |||
24/1537 parse_spec [19] | 1508/1508 pre_visit [13] | |||
1513/1537 core_create_function_syms [41]| 1508/1508 post_visit [12] | |||
[6] 1537 sym_init [6] | 2 cg_dfn [15] | |||
---------------------- |---------------------- | |||
1511/1511 core_create_function_syms [41]| 1505/1505 hist_print [49] | |||
[7] 1511 get_src_info [7] |[16] 1505 print_line [16] | |||
---------------------- | 2/9 print_name_only [25] | |||
2/1510 arc_add [31] |---------------------- | |||
1508/1510 cg_assemble [38] | 1430/1430 core_create_function_syms [41] | |||
[8] 1510 arc_lookup [8] |[17] 1430 source_file_lookup_path [17] | |||
---------------------- |---------------------- | |||
1509/1509 cg_dfn [15] | 24/24 sym_id_parse [54] | |||
[9] 1509 is_numbered [9] |[18] 24 parse_id [18] | |||
---------------------- | 24/24 parse_spec [19] | |||
1508/1508 propagate_flags [52] |---------------------- | |||
[10] 1508 inherit_flags [10] | 24/24 parse_id [18] | |||
---------------------- |[19] 24 parse_spec [19] | |||
1508/1508 cg_dfn [15] | 24/1537 sym_init [6] | |||
[11] 1508 is_busy [11] |---------------------- | |||
---------------------- | 24/24 main [1210] | |||
1508/1508 cg_dfn [15] |[20] 24 sym_id_add [20] | |||
[12] 1508 post_visit [12] | | |||
</pre> | |||
== यह भी देखें == | == यह भी देखें == | ||
| Line 121: | Line 130: | ||
==संदर्भ== | ==संदर्भ== | ||
{{Reflist}} | {{Reflist}} | ||
[[Category:Created On 17/02/2023]] | [[Category:Created On 17/02/2023]] | ||
[[Category:Machine Translated Page]] | |||
[[Category:Pages with script errors]] | |||
[[Category:Templates Vigyan Ready]] | |||
[[Category:ग्राफ डेटा संरचनाएं]] | |||
[[Category:दस्तावेज़ जनरेटर]] | |||
[[Category:संकलक निर्माण]] | |||
[[Category:स्थैतिक कार्यक्रम विश्लेषण]] | |||
Latest revision as of 10:51, 7 March 2023
कॉल ग्राफ़ (जिसे कॉल मल्टीग्राफ़ के रूप में भी जाना जाता है[1][2]) यह एक नियंत्रण-प्रवाह ग्राफ है,[3] जो एक कंप्यूटर प्रोग्राम में सबरूटीन्स के बीच कॉलिंग संबंधों का प्रतिनिधित्व करता है। प्रत्येक नोड एक प्रक्रिया का प्रतिनिधित्व करता है और प्रत्येक आधार पर (एफ, जी) इंगित कर एफ कॉल प्रक्रिया को इस प्रकार, ग्राफ में एक चक्र (ग्राफ सिद्धांत) पुनरावर्ती प्रक्रिया कॉल को इंगित करता है।
बुनियादी अवधारणाएँ
कॉल ग्राफ़ गतिशील या स्थिर हो सकते हैं।[4] डायनेमिक कॉल ग्राफ़ प्रोग्राम के निष्पादन का एक रिकॉर्ड है, उदाहरण के लिए एक प्रोफाइलर द्वारा आउटपुट के रूप में। इस प्रकार, एक डायनेमिक कॉल ग्राफ़ सटीक हो सकता है, परंतु एकमात्र प्रोग्राम के एक रन का वर्णन करता है। एक स्थिर कॉल ग्राफ़ जिसका उद्देश्य प्रोग्राम के हर संभव रन का प्रतिनिधित्व करना है। सटीक स्थैतिक कॉल ग्राफ़ एक अनिर्णीत समस्या है, इसलिए स्थैतिक कॉल ग्राफ़ एल्गोरिदम सामान्यतः अतिरेक हैं। अर्थात्, होने वाले प्रत्येक कॉल संबंध को ग्राफ़ में दर्शाया ज