mininet.topo.MultiGraph

优质
小牛编辑
133浏览
2023-12-01

mininet.topo.MultiGraph

表示一个图结构。 类似于networkx中的图G(V,E)的概念。主要维护节点、边信息。 在MultiGraph中,节点就是一个序号,边则通过节点和节点所对应的连接列表中元素来表示。节点和节点的连接列表的对应关系通过字典结构来维护。

init

def __init__( self ):
        self.data = {}

图结构最主要的功能就是维护一个字典。Key 是节点,value 是该节点所连接的所有的其他节点的列表。

add_node
    def add_node( self, node ):
        "Add node to graph"
        self.data.setdefault( node, [] )

添加一个节点,实际上就是添加一个 key 到 data 字典中。

add_edge
    def add_edge( self, src, dest ):
        "Add edge to graph"
        src, dest = sorted( ( src, dest ) )
        self.add_node( src )
        self.add_node( dest )
        self.data[ src ].append( dest )

添加一条边,实际上就是添加两个节点,然后将连接信息放到 data 字典中(需要注意的是一条边的信息仅被保存了一次,即放到序号较小的节点对应的 list 中)。