graph_sample_neighbors

paddle.incubate. graph_sample_neighbors ( row, colptr, input_nodes, eids=None, perm_buffer=None, sample_size=- 1, return_eids=False, flag_perm_buffer=False, name=None ) [源代码]

主要应用于图学习领域,主要目的是提供高性能图邻居采样方法。通过输入图的 CSC(Compressed Sparse Column,压缩列信息),分别对应 rowcolptr,从而将图转换为适用于邻居采样的格式,再输入需要进行采样的中心节点 input_nodes,以及采样的邻居个数 sample_size,从而可以获得对应中心节点采样后的邻居。另外,在 GPU 版本提供了 Fisher-yates 高性能图采样方法。

参数

  • row (Tensor) - 输入原始图的 CSC 格式的行信息,数据类型为:int32、int64,形状为[num_edges, 1] 或 [num_edges]。

  • colptr (Tensor) - 输入原始图的 CSC 格式的压缩列信息,数据类型应当与 row 一致,形状为[num_nodes + 1, 1]或 [num_nodes + 1]。

  • input_nodes (Tensor) - 需进行邻居采样的中心节点信息,数据类型应当与 row 一致。

  • eids (Tensor,可选) - 输入原始图在 CSC 格式下的边编号信息。如果 return_eids 为 True,则不能为空。数据类型应当与 row 一致。默认为 None,表示不需要返回边编号信息。

  • perm_buffer (Tensor,可选) - Fisher-yates 采样方法需要用到的缓存 Tensor。如果 flag_perm_buffer 为 True,则不能为空。数据类型应当与 row 一致,形状为[num_edges],填充内容为 0 至 num_edges 的顺序递增序列。

  • sample_size (int) - 采样邻居个数。默认值为-1,表示采样输入中心节点的所有邻居。

  • return_eids (bool) - 是否返回采样后对应的原始边编号信息,默认为 False。

  • flag_perm_buffer (bool) - 是否采用 Fisher-yates 采样方法,默认为 False。

  • name (str,可选) - 具体用法请参见 Name,一般无需设置,默认值为 None。

返回

  • out_neighbors (Tensor) - 返回采样后的邻居节点。

  • out_count (Tensor) - 返回中心节点各自对应的采样邻居数目,形状应该与 input_nodes 一致。

  • out_eids (Tensor) - 如果 return_eids 为 True,则会返回采样边对应的编号信息,否则不返回。

代码示例

>>> import paddle
>>> # edges: (3, 0), (7, 0), (0, 1), (9, 1), (1, 2), (4, 3), (2, 4),
>>> #        (9, 5), (3, 5), (9, 6), (1, 6), (9, 8), (7, 8)
>>> row = [3, 7, 0, 9, 1, 4, 2, 9, 3, 9, 1, 9, 7]
>>> colptr = [0, 2, 4, 5, 6, 7, 9, 11, 11, 13, 13]
>>> nodes = [0, 8, 1, 2]
>>> sample_size = 2
>>> row = paddle.to_tensor(row, dtype="int64")
>>> colptr = paddle.to_tensor(colptr, dtype="int64")
>>> nodes = paddle.to_tensor(nodes, dtype="int64")
>>> out_neighbors, out_count = paddle.incubate.graph_sample_neighbors(
...     row,
...     colptr,
...     nodes,
...     sample_size=sample_size
... )