अजगर - रेखांकन

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

  • ग्राफ लंब प्रदर्शित करें
  • ग्राफ के किनारों को प्रदर्शित करें
  • एक शीर्ष जोड़ें
  • एक किनारा जोड़ें
  • एक ग्राफ बनाना

अजगर शब्दकोश डेटा प्रकारों का उपयोग करके आसानी से एक ग्राफ प्रस्तुत किया जा सकता है। हम शब्दकोष की कुंजियों के रूप में कोने का प्रतिनिधित्व करते हैं और कोने के बीच के कनेक्शन को शब्दकोष में मान भी कहा जाता है।

निम्नलिखित ग्राफ पर एक नज़र डालें -

उपरोक्त ग्राफ में

V = {a, b, c, d, e}
E = {ab, ac, bd, cd, de}

हम इस ग्राफ को नीचे दिए गए अजगर कार्यक्रम में प्रस्तुत कर सकते हैं।

# Create the dictionary with graph elements
graph = { "a" : ["b","c"],
          "b" : ["a", "d"],
          "c" : ["a", "d"],
          "d" : ["e"],
          "e" : ["d"]
         }

# Print the graph 		 
print(graph)

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

{'c': ['a', 'd'], 'a': ['b', 'c'], 'e': ['d'], 'd': ['e'], 'b': ['a', 'd']}

ग्राफ लंब प्रदर्शित करें

ग्राफ़ के सिरों को प्रदर्शित करने के लिए हम ग्राफ़ शब्दकोश की कुंजियाँ सरल करते हैं। हम कुंजियों () पद्धति का उपयोग करते हैं।

class graph:
    def __init__(self,gdict=None):
        if gdict is None:
            gdict = []
        self.gdict = gdict

# Get the keys of the dictionary
    def getVertices(self):
        return list(self.gdict.keys())

# Create the dictionary with graph elements
graph_elements = { "a" : ["b","c"],
                "b" : ["a", "d"],
                "c" : ["a", "d"],
                "d" : ["e"],
                "e" : ["d"]
                }

g = graph(graph_elements)

print(g.getVertices())

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

['d', 'b', 'e', 'c', 'a']

ग्राफ के किनारों को प्रदर्शित करें

ग्राफ़ के किनारों को ढूंढना लंबों की तुलना में थोड़ा पेचीदा है क्योंकि हमें उन दोनों जोड़ियों को ढूंढना है जिनके बीच में एक किनारे है। तो हम किनारों की एक खाली सूची बनाते हैं, फिर प्रत्येक कोने से जुड़े किनारे मूल्यों को पुन: व्यवस्थित करते हैं। एक सूची बनाई जाती है जिसमें कोने से अलग किनारों का समूह होता है।

class graph:

    def __init__(self,gdict=None):
        if gdict is None:
            gdict = {}
        self.gdict = gdict

    def edges(self):
        return self.findedges()
# Find the distinct list of edges

    def findedges(self):
        edgename = []
        for vrtx in self.gdict:
            for nxtvrtx in self.gdict[vrtx]:
                if {nxtvrtx, vrtx} not in edgename:
                    edgename.append({vrtx, nxtvrtx})
        return edgename

# Create the dictionary with graph elements
graph_elements = { "a" : ["b","c"],
                "b" : ["a", "d"],
                "c" : ["a", "d"],
                "d" : ["e"],
                "e" : ["d"]
                }

g = graph(graph_elements)

print(g.edges())

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

[{'b', 'a'}, {'b', 'd'}, {'e', 'd'}, {'a', 'c'}, {'c', 'd'}]

एक शीर्ष जोड़ना

एक शीर्ष जोड़ना सीधे आगे है जहां हम ग्राफ़ शब्दकोश में एक और अतिरिक्त कुंजी जोड़ते हैं।

class graph:

    def __init__(self,gdict=None):
        if gdict is None:
            gdict = {}
        self.gdict = gdict

    def getVertices(self):
        return list(self.gdict.keys())

# Add the vertex as a key
    def addVertex(self, vrtx):
       if vrtx not in self.gdict:
            self.gdict[vrtx] = []

# Create the dictionary with graph elements
graph_elements = { "a" : ["b","c"],
                "b" : ["a", "d"],
                "c" : ["a", "d"],
                "d" : ["e"],
                "e" : ["d"]
                }

g = graph(graph_elements)

g.addVertex("f")

print(g.getVertices())

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

['f', 'e', 'b', 'a', 'c','d']

एक धार जोड़ना

किसी मौजूदा ग्राफ़ में एक किनारे जोड़ने से नए वर्टेक्स को एक टुपल के रूप में माना जाता है और यह प्रमाणित करता है कि किनारे पर पहले से मौजूद है। यदि नहीं तो किनारे को जोड़ा जाता है।

class graph:

    def __init__(self,gdict=None):
        if gdict is None:
            gdict = {}
        self.gdict = gdict

    def edges(self):
        return self.findedges()
# Add the new edge

    def AddEdge(self, edge):
        edge = set(edge)
        (vrtx1, vrtx2) = tuple(edge)
        if vrtx1 in self.gdict:
            self.gdict[vrtx1].append(vrtx2)
        else:
            self.gdict[vrtx1] = [vrtx2]

# List the edge names
    def findedges(self):
        edgename = []
        for vrtx in self.gdict:
            for nxtvrtx in self.gdict[vrtx]:
                if {nxtvrtx, vrtx} not in edgename:
                    edgename.append({vrtx, nxtvrtx})
        return edgename

# Create the dictionary with graph elements
graph_elements = { "a" : ["b","c"],
                "b" : ["a", "d"],
                "c" : ["a", "d"],
                "d" : ["e"],
                "e" : ["d"]
                }

g = graph(graph_elements)
g.AddEdge({'a','e'})
g.AddEdge({'a','c'})
print(g.edges())

जब उपरोक्त कोड निष्पादित किया जाता है, तो यह निम्नलिखित परिणाम उत्पन्न करता है -

[{'e', 'd'}, {'b', 'a'}, {'b', 'd'}, {'a', 'c'}, {'a', 'e'}, {'c', 'd'}]