ग्राफ पुनर्लेखन: Difference between revisions

From Vigyanwiki
No edit summary
No edit summary
 
(4 intermediate revisions by 3 users not shown)
Line 1: Line 1:
{{Short description|Creating a new graph from an existing graph}}
{{Short description|Creating a new graph from an existing graph}}
[[कंप्यूटर विज्ञान]] में, ग्राफ़ परिवर्तन, या ग्राफ़ [[पुनर्लेखन]], एल्गोरिथम के मूल ग्राफ़ से एक नया ग्राफ़ (असतत गणित) बनाने की तकनीक से संबंधित है। इसमें [[सॉफ्टवेयर इंजीनियरिंग]] ([[सॉफ्टवेयर निर्माण]] और [[औपचारिक सत्यापन]]) से लेकर [[लेआउट एल्गोरिदम]] और '''पिक्चर जेनरेशन''' चित्र पीढ़ी तक कई एप्लिकेशन हैं।
[[कंप्यूटर विज्ञान]] में, ग्राफ़ परिवर्तन, या ग्राफ़ [[पुनर्लेखन]], एल्गोरिथम के मूल ग्राफ़ से नया ग्राफ़ (असतत गणित) बनाने की तकनीक से संबंधित है। इसमें [[सॉफ्टवेयर इंजीनियरिंग]] ([[सॉफ्टवेयर निर्माण]] और [[औपचारिक सत्यापन]]) से लेकर [[लेआउट एल्गोरिदम]] और चित्र पीढ़ी तक कई एप्लिकेशन हैं।


ग्राफ़ रूपान्तरण का उपयोग संगणना अमूर्त के रूप में किया जा सकता है। मूल विचार यह है कि यदि गणना की स्थिति को ग्राफ के रूप में प्रदर्शित किया जा सकता है, तो उस गणना में आगे के चरणों को उस ग्राफ पर परिवर्तन नियमों के रूप में प्रदर्शित किया जा सकता है। इस तरह के नियमों में एक मूल ग्राफ होता है, जिसे पूर्ण स्थिति में एक सबग्राफ से मिलान करना होता है, और एक प्रतिस्थापन ग्राफ, जो मिलान किए गए सबग्राफ को बदल देगा। '''मूल विचार यह है कि यदि गणना की स्थिति को ग्राफ के रूप में प्रदर्शित किया जा सकता है, तो उस गणना में आगे के चरणों को उस ग्राफ पर परिवर्तन नियमों के रूप में प्रदर्शित किया जा सकता है। इस तरह के नियमों में एक मूल ग्राफ होता है, जिसे पूर्ण स्थिति में एक सबग्राफ से मिलान करना होता है, और एक प्रतिस्थापन ग्राफ, जो मिलान किए गए सबग्राफ को बदल देगा।'''
ग्राफ़ रूपान्तरण का उपयोग संगणना अमूर्त के रूप में किया जा सकता है। मूल विचार यह है कि यदि गणना की स्थिति को ग्राफ के रूप में प्रदर्शित किया जा सकता है, तो उस गणना में आगे के चरणों को उस ग्राफ पर परिवर्तन नियमों के रूप में प्रदर्शित किया जा सकता है। इस तरह के नियमों में मूल ग्राफ होता है, जिसे पूर्ण स्थिति में सबग्राफ से मिलान करना होता है, और प्रतिस्थापन ग्राफ, जो मिलान किए गए सबग्राफ को बदल देगा।


औपचारिक रूप से, एक ग्राफ़ पुनर्लेखन प्रणाली में सामान्यतः फ़ॉर्म के ग्राफ़ पुनर्लेखन नियमों का एक सेट होता है <math>L \rightarrow R</math>, साथ <math>L</math> पैटर्न ग्राफ (या बायीं ओर) कहा जा रहा है और <math>R</math> प्रतिस्थापन ग्राफ (या नियम के दाहिने हाथ की ओर) कहा जा रहा है। पैटर्न ग्राफ की घटना ([[पैटर्न मिलान]], इस प्रकार [[सबग्राफ समरूपता समस्या]] को हल करना) की खोज करके और प्रतिस्थापन ग्राफ के एक उदाहरण द्वारा पाया गया घटना को बदलकर एक ग्राफ पुनर्लेखन नियम आयोजक ग्राफ पर प्रयुक्त किया जाता है। स्ट्रिंग-विनियमित ग्राफ़ व्याकरण जैसे लेबल किए गए ग्राफ़ के स्थितियों में पुनर्लेखन नियमों को और अधिक विनियमित किया जा सकता है।
औपचारिक रूप से ग्राफ़ पुनर्लेखन प्रणाली में सामान्यतः फ़ॉर्म के ग्राफ़ पुनर्लेखन नियमों का सम्मुचय होता है <math>L \rightarrow R</math>, साथ <math>L</math> पैटर्न ग्राफ (या बायीं ओर) कहा जा रहा है और <math>R</math> प्रतिस्थापन ग्राफ (या नियम के दाहिने हाथ की ओर) कहा जा रहा है। पैटर्न ग्राफ की घटना ([[पैटर्न मिलान]], इस प्रकार [[सबग्राफ समरूपता समस्या]] को हल करना) की खोज करके और प्रतिस्थापन ग्राफ के उदाहरण द्वारा पाया गया घटना को बदलकर ग्राफ पुनर्लेखन नियम आयोजक ग्राफ पर प्रयुक्त किया जाता है। स्ट्रिंग-विनियमित ग्राफ़ व्याकरण जैसे लेबल किए गए ग्राफ़ के स्थितियों में पुनर्लेखन नियमों को और अधिक विनियमित किया जा सकता है।


कभी-कभी ग्राफ़ व्याकरण का उपयोग 'ग्राफ़ पुनर्लेखन प्रणाली' के पर्याय के रूप में किया जाता है, विशेष रूप से [[औपचारिक भाषा]]ओं के संदर्भ में; अलग-अलग शब्दों का उपयोग निर्माण के लक्ष्य पर जोर देने के लिए किया जाता है, जैसे कुछ प्रारंभिक ग्राफ से सभी ग्राफों की गणना, यानी ग्राफ भाषा की पीढ़ी - किसी दिए गए स्थिति (आयोजक ग्राफ) को एक नए स्थिति में बदलने के अतिरिक्त।
कभी-कभी ग्राफ़ व्याकरण का उपयोग 'ग्राफ़ पुनर्लेखन प्रणाली' के पर्याय के रूप में किया जाता है, विशेष रूप से [[औपचारिक भाषा]]ओं के संदर्भ में; अलग-अलग शब्दों का उपयोग निर्माण के लक्ष्य पर जोर देने के लिए किया जाता है, जैसे कुछ प्रारंभिक ग्राफ से सभी ग्राफों की गणना, यानी ग्राफ भाषा की पीढ़ी - किसी दिए गए स्थिति (आयोजक ग्राफ) को नए स्थिति में बदलने के अतिरिक्त।


== ग्राफ़ पुनर्लेखन दृष्टिकोण ==
== ग्राफ़ पुनर्लेखन दृष्टिकोण ==
[[File:GraphRewriteExample color.png|thumb|शीर्ष: उदाहरण ग्राफ पुनर्लेखन नियम (कंपाइलर निर्माण से प्रोग्राम ऑप्टिमाइज़ेशन # असेंबली स्तर: 2 के साथ गुणा को जोड़कर)। नीचे: y=x*2 को y=x+x में अनुकूलित करने के लिए नियम का अनुप्रयोग।]]
[[File:GraphRewriteExample color.png|thumb|शीर्ष: उदाहरण ग्राफ पुनर्लेखन नियम (कंपाइलर निर्माण से प्रोग्राम ऑप्टिमाइज़ेशन असेंबली स्तर: 2 के साथ गुणा को जोड़कर)। नीचे: y=x*2 को y=x+x में अनुकूलित करने के लिए नियम का अनुप्रयोग।]]


=== बीजगणितीय दृष्टिकोण ===
=== बीजगणितीय दृष्टिकोण ===
ग्राफ़ पुनर्लेखन के लिए बीजगणितीय दृष्टिकोण [[श्रेणी सिद्धांत]] पर आधारित है। बीजगणितीय दृष्टिकोण को आगे उप-दृष्टिकोणों में विभाजित किया गया है, जिनमें से सबसे सामान्य हैं [[डबल पुशआउट ग्राफ पुनर्लेखन]] '''|डबल-पुशआउट''' (डीपीओ) दृष्टिकोण और [[सिंगल पुशआउट ग्राफ पुनर्लेखन]] '''|सिंगल-पुशआउट''' (एसपीओ) दृष्टिकोण। अन्य उप-दृष्टिकोणों में सेस्की-पुशआउट और पुलबैक दृष्टिकोण सम्मिलित हैं।
ग्राफ़ पुनर्लेखन के लिए बीजगणितीय दृष्टिकोण [[श्रेणी सिद्धांत]] पर आधारित है। बीजगणितीय दृष्टिकोण को आगे उप-दृष्टिकोणों में विभाजित किया गया है, जिनमें से सबसे सामान्य हैं [[डबल पुशआउट ग्राफ पुनर्लेखन]] (डीपीओ) दृष्टिकोण और [[सिंगल पुशआउट ग्राफ पुनर्लेखन]] (एसपीओ) दृष्टिकोण। अन्य उप-दृष्टिकोणों में सेस्की-पुशआउट और पुलबैक दृष्टिकोण सम्मिलित हैं।


डीपीओ दृष्टिकोण के दृष्टिकोण से एक ग्राफ़ पुनर्लेखन नियम ग्राफ़ की श्रेणी में [[morphism|रूपवाद]] की एक जोड़ी है और उनके बीच ग्राफ़ समरूपता है: <math>r = (L \leftarrow K \rightarrow R)</math>, लिखा भी है <math>L \supseteq K \subseteq R</math>, कहाँ <math>K \rightarrow L</math> [[इंजेक्शन]] है। ग्राफ K को अपरिवर्तनीय या कभी-कभी ग्लूइंग ग्राफ कहा जाता है। एक पुनर्लेखन कदम या एक आयोजक ग्राफ G के नियम R के आवेदन को दो [[पुशआउट (श्रेणी सिद्धांत)]] आरेखों द्वारा परिभाषित किया गया है जो दोनों एक ही आकारिकी में उत्पन्न होते हैं। <math>k\colon K\rightarrow D</math>, जहां D एक संदर्भ ग्राफ है (यह वह जगह है जहां नाम डबल-पुशआउट आता है)। एक और ग्राफ रूपवाद <math>m\colon L\rightarrow G</math> G में L की घटना को मॉडल करता है और इसे पैटर्न मिलान कहा जाता है। इसकी व्यावहारिक समझ यह है <math>L</math> एक सबग्राफ है जिससे मिलान किया जाता है <math>G</math> (सबग्राफ समरूपता समस्या देखें), और एक मैच मिलने के बाद, <math>L</math> से प्रतिस्थापित किया जाता है <math>R</math> आयोजक ग्राफ में <math>G</math> जहाँ <math>K</math> एक इंटरफ़ेस के रूप में कार्य करता है, जिसमें नियम प्रयुक्त करते समय संरक्षित नोड्स और किनारे होते हैं। लेखाचित्र <math>K</math> पैटर्न को इसके संदर्भ से मिलान करने के लिए संलग्न करने की आवश्यकता है: यदि यह खाली है, तो मैच केवल ग्राफ के पूरे जुड़े हुए घटक को निर्दिष्ट कर सकता है  <math>G</math>.
डीपीओ दृष्टिकोण के दृष्टिकोण से ग्राफ़ पुनर्लेखन नियम ग्राफ़ की श्रेणी में [[morphism|रूपवाद]] की जोड़ी है और उनके बीच ग्राफ़ समरूपता है: <math>r = (L \leftarrow K \rightarrow R)</math>, लिखा भी है <math>L \supseteq K \subseteq R</math>, कहाँ <math>K \rightarrow L</math> [[इंजेक्शन]] है। ग्राफ K को अपरिवर्तनीय या कभी-कभी ग्लूइंग ग्राफ कहा जाता है। पुनर्लेखन कदम या आयोजक ग्राफ G के नियम R के आवेदन को दो [[पुशआउट (श्रेणी सिद्धांत)]] आरेखों द्वारा परिभाषित किया गया है जो दोनों एक ही आकारिकी में उत्पन्न होते हैं। <math>k\colon K\rightarrow D</math>, जहां D संदर्भ ग्राफ है (यह वह जगह है जहां नाम डबल-पुशआउट आता है)। और ग्राफ रूपवाद <math>m\colon L\rightarrow G</math> G में L की घटना को मॉडल करता है और इसे पैटर्न मिलान कहा जाता है। इसकी व्यावहारिक समझ यह है <math>L</math> सबग्राफ है जिससे मिलान किया जाता है <math>G</math> (सबग्राफ समरूपता समस्या देखें), और मैच मिलने के बाद, <math>L</math> से प्रतिस्थापित किया जाता है <math>R</math> आयोजक ग्राफ में <math>G</math> जहाँ <math>K</math> इंटरफ़ेस के रूप में कार्य करता है, जिसमें नियम प्रयुक्त करते समय संरक्षित नोड्स और किनारे होते हैं। लेखाचित्र <math>K</math> पैटर्न को इसके संदर्भ से मिलान करने के लिए संलग्न करने की आवश्यकता है: यदि यह खाली है, तो मैच केवल ग्राफ के पूरे जुड़े हुए घटक को निर्दिष्ट कर सकता है।


इसके विपरीत एसपीओ दृष्टिकोण का एक ग्राफ पुनर्लेखन नियम लेबल किए गए मल्टीग्राफ और आंशिक मैपिंग की श्रेणी में एक एकल आकारिकी है जो मल्टीग्राफ संरचना को संरक्षित करता है: <math>r\colon L\rightarrow R</math>. इस प्रकार एक पुनर्लेखन चरण को एकल पुशआउट (श्रेणी सिद्धांत) आरेख द्वारा परिभाषित किया गया है। इसकी व्यावहारिक समझ डीपीओ दृष्टिकोण के समान है। अंतर यह है कि पुनर्लेखन चरण का परिणाम होने के कारण आयोजक ग्राफ G और ग्राफ G' के बीच कोई इंटरफ़ेस नहीं है।
इसके विपरीत एसपीओ दृष्टिकोण का ग्राफ पुनर्लेखन नियम लेबल किए गए मल्टीग्राफ और आंशिक मैपिंग की श्रेणी में एकल आकारिकी है जो मल्टीग्राफ संरचना को संरक्षित करता है: <math>r\colon L\rightarrow R</math>. इस प्रकार पुनर्लेखन चरण को एकल पुशआउट (श्रेणी सिद्धांत) आरेख द्वारा परिभाषित किया गया है। इसकी व्यावहारिक समझ डीपीओ दृष्टिकोण के समान है। अंतर यह है कि पुनर्लेखन चरण का परिणाम होने के कारण आयोजक ग्राफ G और ग्राफ G' के बीच कोई इंटरफ़ेस नहीं है।


व्यावहारिक दृष्टिकोण से, डीपीओ और एसपीओ के बीच मुख्य अंतर यह है कि वे आसन्न किनारों के साथ नोड्स को हटाने से कैसे निपटते हैं, विशेष रूप से, वे कैसे बचते हैं कि इस तरह के विलोपन लटकते किनारों को पीछे छोड़ सकते हैं। डीपीओ दृष्टिकोण केवल एक नोड को हटाता है जब नियम सभी आसन्न किनारों को भी हटाने को निर्दिष्ट करता है (किसी दिए गए मैच के लिए इस झूलने की स्थिति की जाँच की जा सकती है), जबकि एसपीओ दृष्टिकोण स्पष्ट विनिर्देश की आवश्यकता के बिना, आसन्न किनारों का निपटान करता है।
व्यावहारिक दृष्टिकोण से, डीपीओ और एसपीओ के बीच मुख्य अंतर यह है कि वे आसन्न किनारों के साथ नोड्स को हटाने से कैसे निपटते हैं, विशेष रूप से, वे कैसे बचते हैं कि इस तरह के विलोपन लटकते किनारों को पीछे छोड़ सकते हैं। डीपीओ दृष्टिकोण केवल नोड को हटाता है जब नियम सभी आसन्न किनारों को भी हटाने को निर्दिष्ट करता है (किसी दिए गए मैच के लिए इस झूलने की स्थिति की जाँच की जा सकती है), जबकि एसपीओ दृष्टिकोण स्पष्ट विनिर्देश की आवश्यकता के बिना, आसन्न किनारों का निपटारा करता है।


मुख्य रूप से बूलियन बीजगणित और मैट्रिसेस के बीजगणित पर आधारित ग्राफ पुनर्लेखन के लिए एक अन्य बीजगणितीय दृष्टिकोण भी है, जिसे मैट्रिक्स ग्राफ व्याकरण कहा जाता है।<ref>{{harvnb|Perez|2009}} covers this approach in detail.</ref>
मुख्य रूप से बूलियन बीजगणित और मैट्रिसेस के बीजगणित पर आधारित ग्राफ पुनर्लेखन के लिए अन्य बीजगणितीय दृष्टिकोण भी है, जिसे मैट्रिक्स ग्राफ व्याकरण कहा जाता है।<ref>{{harvnb|Perez|2009}} covers this approach in detail.</ref>




=== निर्धारित ग्राफ पुनर्लेखन ===
=== निर्धारित ग्राफ पुनर्लेखन ===
फिर भी ग्राफ़ पुनर्लेखन के लिए एक और दृष्टिकोण, जिसे निर्धारित ग्राफ़ पुनर्लेखन के रूप में जाना जाता है, [[तर्क]] और [[डेटाबेस सिद्धांत]] से निकला है।<ref>{{cite web |url=https://www.cs.indiana.edu/~vgucht/p24-gyssens.pdf |title=A Graph-Oriented Object Model for Database End-User Interfaces}}</ref> इस दृष्टिकोण में, ग्राफ़ को डेटाबेस उदाहरणों के रूप में माना जाता है, और प्रश्नों और विचारों को परिभाषित करने के लिए पुनर्लेखन संचालन को एक तंत्र के रूप में माना जाता है; इसलिए, सभी पुनर्लेखन के लिए अद्वितीय परिणाम ([[समरूपता तक]]) प्राप्त करने की आवश्यकता होती है, और यह किसी भी पुनर्लेखन नियम को पूरे ग्राफ़ में समवर्ती रूप से प्रयुक्त करके प्राप्त किया जाता है, जहाँ भी यह प्रयुक्त होता है, इस तरह से कि परिणाम वास्तव में विशिष्ट रूप से परिभाषित होता है।
फिर भी ग्राफ़ पुनर्लेखन के लिए एक और दृष्टिकोण, जिसे निर्धारित ग्राफ़ पुनर्लेखन के रूप में जाना जाता है, [[तर्क]] और [[डेटाबेस सिद्धांत]] से निकला है।<ref>{{cite web |url=https://www.cs.indiana.edu/~vgucht/p24-gyssens.pdf |title=A Graph-Oriented Object Model for Database End-User Interfaces}}</ref> इस दृष्टिकोण में, ग्राफ़ को डेटाबेस उदाहरणों के रूप में माना जाता है, और प्रश्नों और विचारों को परिभाषित करने के लिए पुनर्लेखन संचालन को तंत्र के रूप में माना जाता है; इसलिए, सभी पुनर्लेखन के लिए अद्वितीय परिणाम ([[समरूपता तक]]) प्राप्त करने की आवश्यकता होती है, और यह किसी भी पुनर्लेखन नियम को पूरे ग्राफ़ में समवर्ती रूप से प्रयुक्त करके प्राप्त किया जाता है, जहाँ भी यह प्रयुक्त होता है, इस तरह से कि परिणाम वास्तव में विशिष्ट रूप से परिभाषित होता है।


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


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


टर्मग्राफ सम्मेलन<ref>{{cite web |url=http://www.termgraph.org.uk/ |title=TERMGRAPH}}</ref> पूरी तरह से टर्म ग्राफ पुनर्लेखन और इसके अनुप्रयोगों में अनुसंधान पर केंद्रित है।
टर्मग्राफ सम्मेलन<ref>{{cite web |url=http://www.termgraph.org.uk/ |title=TERMGRAPH}}</ref> पूरी तरह से टर्म ग्राफ पुनर्लेखन और इसके अनुप्रयोगों में अनुसंधान पर केंद्रित है।
Line 40: Line 40:
== कार्यान्वयन और अनुप्रयोग ==
== कार्यान्वयन और अनुप्रयोग ==


रेखांकन संबंधों से जुड़ी वस्तुओं (संस्थाओं) के मॉडलिंग के लिए एक अभिव्यंजक, दृश्य और गणितीय रूप से सटीक औपचारिकता है; वस्तुओं को नोड्स और उनके बीच संबंधों को किनारों द्वारा दर्शाया जाता है। नोड्स और किनारों को सामान्यतः टाइप किया जाता है और जिम्मेदार ठहराया जाता है। इस मॉडल में संगणनाओं का वर्णन संस्थाओं के बीच संबंधों में परिवर्तन या ग्राफ तत्वों के गुण परिवर्तन द्वारा किया जाता है। वे ग्राफ़ रीराइट/ग्राफ़ रूपान्तरण नियमों में एन्कोड किए गए हैं और ग्राफ़ रीराइट प्रणाली/ग्राफ़ रूपान्तरण टूल द्वारा निष्पादित किए गए हैं।
रेखांकन संबंधों से जुड़ी वस्तुओं (संस्थाओं) के मॉडलिंग के लिए अभिव्यंजक, दृश्य और गणितीय रूप से सटीक औपचारिकता है; वस्तुओं को नोड्स और उनके बीच संबंधों को किनारों द्वारा दर्शाया जाता है। नोड्स और किनारों को सामान्यतः टाइप किया जाता है और जिम्मेदार ठहराया जाता है। इस मॉडल में संगणनाओं का वर्णन संस्थाओं के बीच संबंधों में परिवर्तन या ग्राफ तत्वों के गुण परिवर्तन द्वारा किया जाता है। वे ग्राफ़ पुनर्लेखन/ग्राफ़ रूपान्तरण नियमों में एन्कोड किए गए हैं और ग्राफ़ पुनर्लेखन प्रणाली/ग्राफ़ रूपान्तरण टूल द्वारा निष्पादित किए गए हैं।


* उपकरण जो अनुप्रयोग डोमेन तटस्थ हैं:
* उपकरण जो अनुप्रयोग डोमेन तटस्थ हैं:
** [https://web.archive.org/web/20110217171142/http://user.cs.tu-berlin.de/~gragra/agg/ AGG], जिम्मेदार ग्राफ व्याकरण प्रणाली ([[जावा (प्रोग्रामिंग भाषा)]] )
** [https://web.archive.org/web/20110217171142/http://user.cs.tu-berlin.de/~gragra/agg/ AGG], जिम्मेदार ग्राफ व्याकरण प्रणाली ([[जावा (प्रोग्रामिंग भाषा)]]
** [https://uoycs-plasma.github.io/GP2/ GP 2] ग्राफ़ परिवर्तन नियमों के निर्देशित अनुप्रयोग द्वारा ग्राफ़ पर गणना करने के लिए एक प्रोग्रामिंग भाषा है।
** [https://uoycs-plasma.github.io/GP2/ GP 2] ग्राफ़ परिवर्तन नियमों के निर्देशित अनुप्रयोग द्वारा ग्राफ़ पर गणना करने के लिए प्रोग्रामिंग भाषा है।
** [http://homepages.laas.fr/khalil/GMTE/ GMTE], [[ग्राफ मिलान]] और परिवर्तन के लिए ग्राफ मिलान और परिवर्तन इंजन। यह [[सी ++|C ++]] का उपयोग कर मेस्मर के एल्गोरिदम के विस्तार का कार्यान्वयन है।
** [http://homepages.laas.fr/khalil/GMTE/ GMTE], [[ग्राफ मिलान]] और परिवर्तन के लिए ग्राफ मिलान और परिवर्तन इंजन। यह [[सी ++|C ++]] का उपयोग कर मेस्मर के एल्गोरिदम के विस्तार का कार्यान्वयन है।
** GrGen |GrGen.NET, ग्राफ़ पुनर्लेखन जनरेटर, C शार्प (प्रोग्रामिंग भाषा) उत्सर्जित करने वाला एक ग्राफ़ रूपांतरण उपकरण | C#-कोड या .NET-असेंबली
** GrGen.NET, ग्राफ़ पुनर्लेखन जनरेटर, C शार्प (प्रोग्रामिंग भाषा) उत्सर्जित करने वाला ग्राफ़ रूपांतरण उपकरण C-कोड या .NET-असेंबली
** [http://groove.cs.utwente.nl/ GROOVE], ग्राफ़ और ग्राफ़ रूपान्तरण नियमों के संपादन के लिए एक जावा-आधारित टूल सेट, ग्राफ़ व्याकरण के स्टेट स्पेस की खोज, और उन स्टेट स्पेस की मॉडल जाँच; ग्राफ परिवर्तन इंजन के रूप में भी प्रयोग किया जा सकता है।
** [http://groove.cs.utwente.nl/ GROOVE], ग्राफ़ और ग्राफ़ रूपान्तरण नियमों के संपादन के लिए जावा-आधारित टूल सेट, ग्राफ़ व्याकरण के स्टेट स्पेस की खोज, और उन स्टेट स्पेस की मॉडल जाँच; ग्राफ परिवर्तन इंजन के रूप में भी प्रयोग किया जा सकता है।
** [https://github.com/Verites/verigraph/ Verigraph], ग्राफ पुनर्लेखन ([[हास्केल (प्रोग्रामिंग भाषा)]]) पर आधारित एक सॉफ्टवेयर विनिर्देश और सत्यापन प्रणाली।
** [https://github.com/Verites/verigraph/ Verigraph], ग्राफ पुनर्लेखन ([[हास्केल (प्रोग्रामिंग भाषा)]]) पर आधारित सॉफ्टवेयर विनिर्देश और सत्यापन प्रणाली।
* उपकरण जो ग्राफ पुनर्लेखन के साथ सॉफ्टवेयर इंजीनियरिंग कार्यों (मुख्य रूप से [[मॉडल संचालित वास्तुकला]]) को हल करते हैं:
* उपकरण जो ग्राफ पुनर्लेखन के साथ सॉफ्टवेयर इंजीनियरिंग कार्यों (मुख्य रूप से [[मॉडल संचालित वास्तुकला]]) को हल करते हैं:
** [http://emoflon.org/eMoflon], [[कहानी-संचालित मॉडलिंग]]|स्टोरी-ड्रिवन मॉडलिंग और ट्रिपल ग्राफ ग्रामर के समर्थन के साथ एक ईएमएफ-संगत मॉडल-परिवर्तन उपकरण
** [http://emoflon.org/eMoflon], [[कहानी-संचालित मॉडलिंग]]|स्टोरी-ड्रिवन मॉडलिंग और ट्रिपल ग्राफ ग्रामर के समर्थन के साथ ईएमएफ-संगत मॉडल-परिवर्तन उपकरण
** [http://www.emorf.org EMorF] [[ ग्रहण मॉडलिंग फ्रेमवर्क ]] पर आधारित एक ग्राफ रीराइटिंग प्रणाली, इन-प्लेस और मॉडल-टू-मॉडल [[मॉडल परिवर्तन]] का समर्थन करता है
** [http://www.emorf.org EMorF] [[ ग्रहण मॉडलिंग फ्रेमवर्क ]] पर आधारित ग्राफ पुनर्लेखनिंग प्रणाली, इन-प्लेस और मॉडल-टू-मॉडल [[मॉडल परिवर्तन]] का समर्थन करता है
** [http://www.fujaba.de/ Fujaba] कहानी चालित मॉडलिंग का उपयोग करता है, प्रगति पर आधारित एक ग्राफ पुनर्लेखन भाषा
** [http://www.fujaba.de/ Fujaba] कहानी चालित मॉडलिंग का उपयोग करता है, प्रगति पर आधारित ग्राफ पुनर्लेखन भाषा
** [[ग्राफ डेटाबेस]] अधिकांशतः ग्राफ़ के गतिशील पुनर्लेखन का समर्थन करता है
** [[ग्राफ डेटाबेस]] अधिकांशतः ग्राफ़ के गतिशील पुनर्लेखन का समर्थन करता है
*** [[महान|GReAT]]
*** [[महान|GReAT]]
** [http://tinkerpop.apache.org/gremlin.html Gremlin], एक ग्राफ़-आधारित प्रोग्रामिंग भाषा (देखें [https://github.com/tinkerpop/gremlin/wiki/Graph-Rewriting ग्राफ़ पुनर्लेखन])
** [http://tinkerpop.apache.org/gremlin.html Gremlin], ग्राफ़-आधारित प्रोग्रामिंग भाषा (देखें [https://github.com/tinkerpop/gremlin/wiki/Graph-Rewriting ग्राफ़ पुनर्लेखन])
** [https://www.eclipse.org/henshin/ Henshin], एक्लिप्स मॉडलिंग फ्रेमवर्क पर आधारित एक ग्राफ रीराइटिंग प्रणाली, इन-प्लेस और मॉडल-टू-मॉडल मॉडल ट्रांसफॉर्मेशन, [[महत्वपूर्ण जोड़ी (तर्क)]]लॉजिक) और [[ मॉडल की जाँच ]] को सपोर्ट करता है।
** [https://www.eclipse.org/henshin/ Henshin], एक्लिप्स मॉडलिंग फ्रेमवर्क पर आधारित ग्राफ पुनर्लेखनिंग प्रणाली, इन-प्लेस और मॉडल-टू-मॉडल मॉडल ट्रांसफॉर्मेशन, [[महत्वपूर्ण जोड़ी (तर्क)]]लॉजिक) और [[ मॉडल की जाँच ]] को सपोर्ट करता है।
** [http://www.se.rwth-aachen.de/tikiwiki/tiki-index.php%3Fpage=Research%3A+Progres.html PROGRES], प्रोग्राम्ड ग्राफ़ रीराइटिंग प्रणाली के लिए एक एकीकृत वातावरण और बहुत उच्च स्तरीय भाषा
** [http://www.se.rwth-aachen.de/tikiwiki/tiki-index.php%3Fpage=Research%3A+Progres.html PROGRES], प्रोग्राम्ड ग्राफ़ पुनर्लेखनिंग प्रणाली के लिए एकीकृत वातावरण और बहुत उच्च स्तरीय भाषा
*** [[हवाओं|VIATRA]]
*** [[हवाओं|VIATRA]]
* मैकेनिकल इंजीनियरिंग उपकरण
* मैकेनिकल इंजीनियरिंग उपकरण
** [http://www.graphsynth.com GraphSynth] अप्रतिबंधित ग्राफ व्याकरण बनाने के साथ-साथ परिणामी भाषा संस्करण का परीक्षण और खोज करने के लिए एक दुभाषिया और UI वातावरण है। यह ग्राफ़ और ग्राफ़ व्याकरण के नियमों को [[XML]] फ़ाइलों के रूप में सहेजता है और C Sharp (प्रोग्रामिंग भाषा) | C# में लिखा जाता है।
** [http://www.graphsynth.com GraphSynth] अप्रतिबंधित ग्राफ व्याकरण बनाने के साथ-साथ परिणामी भाषा संस्करण का परीक्षण और खोज करने के लिए दुभाषिया और UI वातावरण है। यह ग्राफ़ और ग्राफ़ व्याकरण के नियमों को [[XML]] फ़ाइलों के रूप में सहेजता है और C Sharp (प्रोग्रामिंग भाषा) C में लिखा जाता है।
** [https://archive.today/20150317152250/https://www.soley-technology.com/en/pr-soley-studio सोले स्टूडियो], ग्राफ परिवर्तन प्रणालियों के लिए एक एकीकृत विकास वातावरण है। इसका मुख्य अनुप्रयोग फोकस इंजीनियरिंग के क्षेत्र में डेटा एनालिटिक्स है।
** [https://archive.today/20150317152250/https://www.soley-technology.com/en/pr-soley-studio सोले स्टूडियो], ग्राफ परिवर्तन प्रणालियों के लिए एकीकृत विकास वातावरण है। इसका मुख्य अनुप्रयोग फोकस इंजीनियरिंग के क्षेत्र में डेटा एनालिटिक्स है।
* जीव विज्ञान अनुप्रयोग
* जीव विज्ञान अनुप्रयोग
** [http://opus.kobv.de/btu/volltexte/2009/593/pdf/thesis.pdf एक ग्राफ व्याकरण आधारित भाषा के साथ कार्यात्मक-संरचनात्मक संयंत्र मॉडलिंग]
** [http://opus.kobv.de/btu/volltexte/2009/593/pdf/thesis.pdf ग्राफ व्याकरण आधारित भाषा के साथ कार्यात्मक-संरचनात्मक संयंत्र मॉडलिंग]
** [https://dx.doi.org/10.1016/j.tcs.2011.07.004 स्ट्रिंग-विनियमित ग्राफ व्याकरण के साथ बहुकोशिकीय विकास मॉडलिंग]
** [https://dx.doi.org/10.1016/j.tcs.2011.07.004 स्ट्रिंग-विनियमित ग्राफ व्याकरण के साथ बहुकोशिकीय विकास मॉडलिंग]
* आर्टिफिशियल इंटेलिजेंस / प्राकृतिक भाषा प्रसंस्करण
* आर्टिफिशियल इंटेलिजेंस / प्राकृतिक भाषा प्रसंस्करण
** [[OpenCog]] एक बुनियादी पैटर्न मैचर ([[ hypergraph | हाइपरग्राफ]]  पर) प्रदान करता है जिसका उपयोग विभिन्न AI एल्गोरिदम को प्रयुक्त करने के लिए किया जाता है।
** [[OpenCog]] मूलभूत पैटर्न मैचर ([[ hypergraph | हाइपरग्राफ]]  पर) प्रदान करता है जिसका उपयोग विभिन्न AI एल्गोरिदम को प्रयुक्त करने के लिए किया जाता है।
** [http://wiki.opencog.org/w/RelEx RelEx] एक अंग्रेजी-भाषा पार्सर है जो एक [[लिंक व्याकरण]] को [[निर्भरता व्याकरण]] में बदलने के लिए ग्राफ री-राइटिंग को नियोजित करता है।
** [http://wiki.opencog.org/w/RelEx RelEx] अंग्रेजी-भाषा पार्सर है जो [[लिंक व्याकरण]] को [[निर्भरता व्याकरण]] में बदलने के लिए ग्राफ री-राइटिंग को नियोजित करता है।
* कंप्यूटर प्रोग्रामिंग भाषा
* कंप्यूटर प्रोग्रामिंग भाषा
** ग्राफ़ पुनर्लेखन का उपयोग करके [[स्वच्छ प्रोग्रामिंग भाषा]] प्रयुक्त की जाती है।
** ग्राफ़ पुनर्लेखन का उपयोग करके [[स्वच्छ प्रोग्रामिंग भाषा]] प्रयुक्त की जाती है।
Line 75: Line 75:
* [[आकार व्याकरण]]
* [[आकार व्याकरण]]
* [[औपचारिक व्याकरण]]
* [[औपचारिक व्याकरण]]
*[[सार पुनर्लेखन]] - ग्राफ पुनर्लेखन का एक सामान्यीकरण
*[[सार पुनर्लेखन]] - ग्राफ पुनर्लेखन का सामान्यीकरण


== संदर्भ ==
== संदर्भ ==
Line 100: Line 100:
श्रेणी:ग्राफ़ पुनर्लेखन
श्रेणी:ग्राफ़ पुनर्लेखन


[[Category: Machine Translated Page]]
[[Category:Created On 08/05/2023]]
[[Category:Created On 08/05/2023]]
[[Category:Lua-based templates]]
[[Category:Machine Translated Page]]
[[Category:Pages with script errors]]
[[Category:Templates Vigyan Ready]]
[[Category:Templates that add a tracking category]]
[[Category:Templates that generate short descriptions]]
[[Category:Templates using TemplateData]]

Latest revision as of 10:03, 22 May 2023

कंप्यूटर विज्ञान में, ग्राफ़ परिवर्तन, या ग्राफ़ पुनर्लेखन, एल्गोरिथम के मूल ग्राफ़ से नया ग्राफ़ (असतत गणित) बनाने की तकनीक से संबंधित है। इसमें सॉफ्टवेयर इंजीनियरिंग (सॉफ्टवेयर निर्माण और औपचारिक सत्यापन) से लेकर लेआउट एल्गोरिदम और चित्र पीढ़ी तक कई एप्लिकेशन हैं।

ग्राफ़ रूपान्तरण का उपयोग संगणना अमूर्त के रूप में किया जा सकता है। मूल विचार यह है कि यदि गणना की स्थिति को ग्राफ के रूप में प्रदर्शित किया जा सकता है, तो उस गणना में आगे के चरणों को उस ग्राफ पर परिवर्तन नियमों के रूप में प्रदर्शित किया जा सकता है। इस तरह के नियमों में मूल ग्राफ होता है, जिसे पूर्ण स्थिति में सबग्राफ से मिलान करना होता है, और प्रतिस्थापन ग्राफ, जो मिलान किए गए सबग्राफ को बदल देगा।

औपचारिक रूप से ग्राफ़ पुनर्लेखन प्रणाली में सामान्यतः फ़ॉर्म के ग्राफ़ पुनर्लेखन नियमों का सम्मुचय होता है , साथ पैटर्न ग्राफ (या बायीं ओर) कहा जा रहा है और प्रतिस्थापन ग्राफ (या नियम के दाहिने हाथ की ओर) कहा जा रहा है। पैटर्न ग्राफ की घटना (पैटर्न मिलान, इस प्रकार सबग्राफ समरूपता समस्या को हल करना) की खोज करके और प्रतिस्थापन ग्राफ के उदाहरण द्वारा पाया गया घटना को बदलकर ग्राफ पुनर्लेखन नियम आयोजक ग्राफ पर प्रयुक्त किया जाता है। स्ट्रिंग-विनियमित ग्राफ़ व्याकरण जैसे लेबल किए गए ग्राफ़ के स्थितियों में पुनर्लेखन नियमों को और अधिक विनियमित किया जा सकता है।

कभी-कभी ग्राफ़ व्याकरण का उपयोग 'ग्राफ़ पुनर्लेखन प्रणाली' के पर्याय के रूप में किया जाता है, विशेष रूप से औपचारिक भाषाओं के संदर्भ में; अलग-अलग शब्दों का उपयोग निर्माण के लक्ष्य पर जोर देने के लिए किया जाता है, जैसे कुछ प्रारंभिक ग्राफ से सभी ग्राफों की गणना, यानी ग्राफ भाषा की पीढ़ी - किसी दिए गए स्थिति (आयोजक ग्राफ) को नए स्थिति में बदलने के अतिरिक्त।

ग्राफ़ पुनर्लेखन दृष्टिकोण

शीर्ष: उदाहरण ग्राफ पुनर्लेखन नियम (कंपाइलर निर्माण से प्रोग्राम ऑप्टिमाइज़ेशन असेंबली स्तर: 2 के साथ गुणा को जोड़कर)। नीचे: y=x*2 को y=x+x में अनुकूलित करने के लिए नियम का अनुप्रयोग।

बीजगणितीय दृष्टिकोण

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

डीपीओ दृष्टिकोण के दृष्टिकोण से ग्राफ़ पुनर्लेखन नियम ग्राफ़ की श्रेणी में रूपवाद की जोड़ी है और उनके बीच ग्राफ़ समरूपता है: , लिखा भी है , कहाँ इंजेक्शन है। ग्राफ K को अपरिवर्तनीय या कभी-कभी ग्लूइंग ग्राफ कहा जाता है। पुनर्लेखन कदम या आयोजक ग्राफ G के नियम R के आवेदन को दो पुशआउट (श्रेणी सिद्धांत) आरेखों द्वारा परिभाषित किया गया है जो दोनों एक ही आकारिकी में उत्पन्न होते हैं। , जहां D संदर्भ ग्राफ है (यह वह जगह है जहां नाम डबल-पुशआउट आता है)। और ग्राफ रूपवाद G में L की घटना को मॉडल करता है और इसे पैटर्न मिलान कहा जाता है। इसकी व्यावहारिक समझ यह है सबग्राफ है जिससे मिलान किया जाता है (सबग्राफ समरूपता समस्या देखें), और मैच मिलने के बाद, से प्रतिस्थापित किया जाता है आयोजक ग्राफ में जहाँ इंटरफ़ेस के रूप में कार्य करता है, जिसमें नियम प्रयुक्त करते समय संरक्षित नोड्स और किनारे होते हैं। लेखाचित्र पैटर्न को इसके संदर्भ से मिलान करने के लिए संलग्न करने की आवश्यकता है: यदि यह खाली है, तो मैच केवल ग्राफ के पूरे जुड़े हुए घटक को निर्दिष्ट कर सकता है।

इसके विपरीत एसपीओ दृष्टिकोण का ग्राफ पुनर्लेखन नियम लेबल किए गए मल्टीग्राफ और आंशिक मैपिंग की श्रेणी में एकल आकारिकी है जो मल्टीग्राफ संरचना को संरक्षित करता है: . इस प्रकार पुनर्लेखन चरण को एकल पुशआउट (श्रेणी सिद्धांत) आरेख द्वारा परिभाषित किया गया है। इसकी व्यावहारिक समझ डीपीओ दृष्टिकोण के समान है। अंतर यह है कि पुनर्लेखन चरण का परिणाम होने के कारण आयोजक ग्राफ G और ग्राफ G' के बीच कोई इंटरफ़ेस नहीं है।

व्यावहारिक दृष्टिकोण से, डीपीओ और एसपीओ के बीच मुख्य अंतर यह है कि वे आसन्न किनारों के साथ नोड्स को हटाने से कैसे निपटते हैं, विशेष रूप से, वे कैसे बचते हैं कि इस तरह के विलोपन लटकते किनारों को पीछे छोड़ सकते हैं। डीपीओ दृष्टिकोण केवल नोड को हटाता है जब नियम सभी आसन्न किनारों को भी हटाने को निर्दिष्ट करता है (किसी दिए गए मैच के लिए इस झूलने की स्थिति की जाँच की जा सकती है), जबकि एसपीओ दृष्टिकोण स्पष्ट विनिर्देश की आवश्यकता के बिना, आसन्न किनारों का निपटारा करता है।

मुख्य रूप से बूलियन बीजगणित और मैट्रिसेस के बीजगणित पर आधारित ग्राफ पुनर्लेखन के लिए अन्य बीजगणितीय दृष्टिकोण भी है, जिसे मैट्रिक्स ग्राफ व्याकरण कहा जाता है।[1]


निर्धारित ग्राफ पुनर्लेखन

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

टर्म ग्राफ पुनर्लेखन

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

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

टर्मग्राफ सम्मेलन[3] पूरी तरह से टर्म ग्राफ पुनर्लेखन और इसके अनुप्रयोगों में अनुसंधान पर केंद्रित है।

ग्राफ व्याकरण और ग्राफ पुनर्लेखन प्रणाली की कक्षाएं

ग्राफ़ पुनर्लेखन प्रणाली स्वाभाविक रूप से उपयोग किए जाने वाले ग्राफ़ के प्रतिनिधित्व के प्रकार और पुनर्लेखन कैसे व्यक्त किए जाते हैं, के अनुसार कक्षाओं में समूहित होती है। शब्द ग्राफ़ व्याकरण, अन्यथा ग्राफ़ पुनर्लेखन प्रणाली या ग्राफ़ प्रतिस्थापन प्रणाली के समकक्ष, वर्गीकरण में सबसे अधिक बार उपयोग किया जाता है। कुछ सामान्य प्रकार हैं:

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

कार्यान्वयन और अनुप्रयोग

रेखांकन संबंधों से जुड़ी वस्तुओं (संस्थाओं) के मॉडलिंग के लिए अभिव्यंजक, दृश्य और गणितीय रूप से सटीक औपचारिकता है; वस्तुओं को नोड्स और उनके बीच संबंधों को किनारों द्वारा दर्शाया जाता है। नोड्स और किनारों को सामान्यतः टाइप किया जाता है और जिम्मेदार ठहराया जाता है। इस मॉडल में संगणनाओं का वर्णन संस्थाओं के बीच संबंधों में परिवर्तन या ग्राफ तत्वों के गुण परिवर्तन द्वारा किया जाता है। वे ग्राफ़ पुनर्लेखन/ग्राफ़ रूपान्तरण नियमों में एन्कोड किए गए हैं और ग्राफ़ पुनर्लेखन प्रणाली/ग्राफ़ रूपान्तरण टूल द्वारा निष्पादित किए गए हैं।

  • उपकरण जो अनुप्रयोग डोमेन तटस्थ हैं:
    • AGG, जिम्मेदार ग्राफ व्याकरण प्रणाली (जावा (प्रोग्रामिंग भाषा)
    • GP 2 ग्राफ़ परिवर्तन नियमों के निर्देशित अनुप्रयोग द्वारा ग्राफ़ पर गणना करने के लिए प्रोग्रामिंग भाषा है।
    • GMTE, ग्राफ मिलान और परिवर्तन के लिए ग्राफ मिलान और परिवर्तन इंजन। यह C ++ का उपयोग कर मेस्मर के एल्गोरिदम के विस्तार का कार्यान्वयन है।
    • GrGen.NET, ग्राफ़ पुनर्लेखन जनरेटर, C शार्प (प्रोग्रामिंग भाषा) उत्सर्जित करने वाला ग्राफ़ रूपांतरण उपकरण C-कोड या .NET-असेंबली
    • GROOVE, ग्राफ़ और ग्राफ़ रूपान्तरण नियमों के संपादन के लिए जावा-आधारित टूल सेट, ग्राफ़ व्याकरण के स्टेट स्पेस की खोज, और उन स्टेट स्पेस की मॉडल जाँच; ग्राफ परिवर्तन इंजन के रूप में भी प्रयोग किया जा सकता है।
    • Verigraph, ग्राफ पुनर्लेखन (हास्केल (प्रोग्रामिंग भाषा)) पर आधारित सॉफ्टवेयर विनिर्देश और सत्यापन प्रणाली।
  • उपकरण जो ग्राफ पुनर्लेखन के साथ सॉफ्टवेयर इंजीनियरिंग कार्यों (मुख्य रूप से मॉडल संचालित वास्तुकला) को हल करते हैं:
  • मैकेनिकल इंजीनियरिंग उपकरण
    • GraphSynth अप्रतिबंधित ग्राफ व्याकरण बनाने के साथ-साथ परिणामी भाषा संस्करण का परीक्षण और खोज करने के लिए दुभाषिया और UI वातावरण है। यह ग्राफ़ और ग्राफ़ व्याकरण के नियमों को XML फ़ाइलों के रूप में सहेजता है और C Sharp (प्रोग्रामिंग भाषा) C में लिखा जाता है।
    • सोले स्टूडियो, ग्राफ परिवर्तन प्रणालियों के लिए एकीकृत विकास वातावरण है। इसका मुख्य अनुप्रयोग फोकस इंजीनियरिंग के क्षेत्र में डेटा एनालिटिक्स है।
  • जीव विज्ञान अनुप्रयोग
  • आर्टिफिशियल इंटेलिजेंस / प्राकृतिक भाषा प्रसंस्करण
    • OpenCog मूलभूत पैटर्न मैचर ( हाइपरग्राफ पर) प्रदान करता है जिसका उपयोग विभिन्न AI एल्गोरिदम को प्रयुक्त करने के लिए किया जाता है।
    • RelEx अंग्रेजी-भाषा पार्सर है जो लिंक व्याकरण को निर्भरता व्याकरण में बदलने के लिए ग्राफ री-राइटिंग को नियोजित करता है।
  • कंप्यूटर प्रोग्रामिंग भाषा

यह भी देखें

संदर्भ

उद्धरण

  1. Perez 2009 covers this approach in detail.
  2. "A Graph-Oriented Object Model for Database End-User Interfaces" (PDF).
  3. "TERMGRAPH".


स्रोत

श्रेणी:ग्राफ़ पुनर्लेखन