zoukankan      html  css  js  c++  java
  • Graph Network Notes

    dgl:

    G = dgl.DGLGraph()
    G.add_nodes(10)  # 10 isolated nodes are added
    G.add_edge(0, 1)
    
    G.add_edges([1, 2, 3], [3, 4, 5])  # three edges: 1->3, 2->4, 3->5
    G.add_edges(4, [7, 8, 9])  # three edges: 4->7, 4->8, 4->9
    G.add_edges([2, 6, 8], 5)  # three edges: 2->5, 6->5, 8->5
    
    import torch as th
    G.add_edges(th.tensor([3, 4, 5]), 1)  # three edges: 3->1, 4->1, 5->1
    
    ## 节点特征设置
    G = dgl.DGLGraph()
    G.add_nodes(3)
    G.ndata['x'] = th.zeros((3, 5))  # init 3 nodes with zero vector(len=5)
    """
    G.ndata
    {'x' : tensor([[0., 0., 0., 0., 0.],
                   [0., 0., 0., 0., 0.],
                   [0., 0., 0., 0., 0.]])}
    """
    G.nodes[[0, 2]].data['x'] = th.ones((2, 5))
    G.ndata
    
    """
    {'x' : tensor([[1., 1., 1., 1., 1.],
                   [0., 0., 0., 0., 0.],
                   [1., 1., 1., 1., 1.]])}
    """
    
    G.add_edges([0, 1], 2)  # 0->2, 1->2
    G.edata['y'] = th.zeros((2, 4))  # init 2 edges with zero vector(len=4)
    """"
    G.edata
    {'y' : tensor([[0., 0., 0., 0.],
                   [0., 0., 0., 0.]])}
    """
    G.edges[1, 2].data['y'] = th.ones((1, 4))  ## 设置指定边1->2的特征
    """
    G.edata
    {'y' : tensor([[0., 0., 0., 0.],
                   [1., 1., 1., 1.]])}
    """
    
    ## Message Passing:
    >>> # Define the function for sending messages.
    >>> def send_source(edges): return {'m': edges.src['x'] + 1}   # 定义消息传递的函数
    >>> # Set the function defined to be the default message function.
    >>> G.register_message_func(send_source)     # 把消息函数设置给图G
    >>> # Send messages through all edges.
    >>> G.send(G.edges())                 
    
    >>> # Define a function for summing messages received and replacing the original feature.
    >>> def simple_reduce(nodes): return {'x': nodes.mailbox['m'].sum(1)}
    >>> # Set the function defined to be the default message reduce function.
    >>> G.register_reduce_func(simple_reduce)
    >>> # All existing edges have node 2 as the destination.
    >>> # Receive the messages for node 2 and update its feature.
    >>> G.recv(v=2)
    >>> G.ndata
    {'x': tensor([[1., 1., 1., 1., 1.],
                  [0., 0., 0., 0., 0.],
                  [3., 3., 3., 3., 3.]])} # 3 = (1 + 1) + (0 + 1)
  • 相关阅读:
    18文件权限管理
    17用户身份管理
    16Shell脚本—计划任务服务程序
    15Shell脚本—流程控制
    14Shell脚本—判断语句
    13Shell脚本—编写简单脚本
    12Vim在系统配置中的应用示例
    11Vim文本编辑器
    10重要的环境变量
    09命令行通配符和转义字符
  • 原文地址:https://www.cnblogs.com/sandy-t/p/13426925.html
Copyright © 2011-2022 走看看