当前位置: 首页 > news >正文

PyG edge index 转换回 邻接矩阵

PyG的edge index形式是 [ ( n o d e 1 , n o d e 2 ) , ( n o d e 1 , n o d e 3 ) . . . ] [(node_1,node_2), (node_1, node_3)...] [(node1,node2),(node1,node3)...]这种edge pair。

naive

直接for循环,吧edge index里面的位置填充1:

import torch  def edge_index_to_adjacency_matrix(edge_index, num_nodes):  # 创建大小为 (num_nodes, num_nodes) 的二维张量  adjacency_matrix = torch.zeros(num_nodes, num_nodes)  # 根据边索引填充邻接矩阵的元素  for i, j in zip(*edge_index):  adjacency_matrix[i, j] = 1  adjacency_matrix[j, i] = 1  return adjacency_matrix

效率很低

利用传播机制

用PyTorch的广播机制,通过将边索引直接作为索引,一次性将对应的邻接矩阵元素设置为1,避免了使用for循环进行逐个元素的填充。这种方法在大规模图形上具有更高的效率。

import torch  def edge_index_to_adjacency_matrix(edge_index, num_nodes):  # 构建一个大小为 (num_nodes, num_nodes) 的零矩阵  adjacency_matrix = torch.zeros(num_nodes, num_nodes, dtype=torch.uint8)  # 使用索引广播机制,一次性将边索引映射到邻接矩阵的相应位置上  adjacency_matrix[edge_index[0], edge_index[1]] = 1  adjacency_matrix[edge_index[1], edge_index[0]] = 1  return adjacency_matrix
http://www.lryc.cn/news/213004.html

相关文章:

  • JavaSE19——file文件类
  • mongodb记录
  • Go语言:数组和切片
  • OPENCV 闭运算实验示例代码morphologyEx()函数
  • UE4 体积云制作 学习笔记
  • visual studio编译QtAV
  • 喜报!CACTER邮件安全网关荣获2023鲲鹏应用创新大赛广东赛区三等奖
  • Spark On Hive原理和配置
  • 驱动第十天
  • 工作中常用的git命令,千万不能忘
  • 计组之存储系统
  • 【Jenkins】新建任务FAQ
  • 生产环境使用boost::fiber
  • TSINGSEE青犀AI视频识别技术+危化安全生产智慧监管方案
  • 小程序request请求封装
  • Easy Javadoc插件的使用教程
  • 一篇文章让你弄懂Java中的方法
  • SAP MM学习笔记39 - MRP(资材所要量计划)
  • 总线类设备驱动——IIC
  • MES 的价值点之动态调度
  • dfs序及相关例题
  • python入门实战:爬取图片到本地
  • day02 矩阵 2023.10.26
  • 浪潮信息inMerge超融合 刷新全球vSAN架构虚拟化VMmark最佳成绩
  • 【【哈希应用】位图/布隆过滤器】
  • OpenCV学习笔记
  • idea 一键部署jar包
  • 16、SpringCloud -- 常见的接口防刷限流方式
  • Typora(morkdown编辑器)的安装包和安装教程
  • 服务器不稳定对网站有什么影响