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,压缩列信息),分别对应 row
和 colptr
,从而将图转换为适用于邻居采样的格式,再输入需要进行采样的中心节点 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,可选) - 操作的名称(可选,默认值为None)。更多信息请参见 Name 。
返回¶
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)