0

0

高效查找 PyTorch 张量中唯一行的索引

聖光之護

聖光之護

发布时间:2025-10-04 12:10:15

|

668人浏览过

|

来源于php中文网

原创

高效查找 pytorch 张量中唯一行的索引

本文介绍了一种在 PyTorch 张量中高效查找每个唯一行首次出现索引的方法。通过利用 torch.unique 函数获取唯一行及其逆向索引,并结合二维张量和 torch.argmin 函数,避免了显式循环,从而提升了代码效率。文章提供了详细的代码示例和性能注意事项,帮助读者根据实际应用场景选择合适的解决方案。

在 PyTorch 中处理张量数据时,经常需要查找唯一行的索引。一种常见的方法是使用循环遍历每个唯一行,并在逆向索引中找到其首次出现的索引。然而,这种方法效率较低,尤其是在处理大型张量时。本文介绍一种更高效的方法,利用 PyTorch 的张量操作避免显式循环,从而提高代码性能。

使用 torch.unique 获取唯一行和逆向索引

首先,使用 torch.unique 函数获取张量中的唯一行、逆向索引和计数。torch.unique 函数的 return_inverse=True 参数会返回一个逆向索引张量,该张量指示原始张量中的每一行对应于唯一行张量中的哪个索引。

import torch
import numpy as np

# 示例张量
data = torch.rand(100, 5)
data[np.random.choice(100, 50, replace=False)] = torch.tensor([1.0, 2.0, 3.0, 4.0, 5.0])

# 查找唯一行
u_data, inverse_indices, counts = torch.unique(data, dim=0, return_inverse=True, return_counts=True)

使用二维张量和 torch.argmin 查找首次出现索引

为了避免循环,我们可以创建一个二维张量 A,其维度为原始张量的行数乘以唯一行的数量。将 A 初始化为一个较大的值(例如 1000,确保大于原始张量的行数),表示“未定义的行索引”。然后,对于原始张量的每个行索引 i,将 A[i, inverse_indices[i]] 设置为 inverse_indices[i]。

商务通(在线客服系统)
商务通(在线客服系统)

一款无需安装的即时交流系统,只需申请一个帐号,将一段代码嵌入贵站网页中,就可以让客服人员发现所有到达您网站的访客,而且可以看到访客的来源、使用的搜索引擎等,您可以主动发起对话与访客沟通,进行产品推销,从而大大提高产品销售成功率。 还是一款协同管理软件,在保持与客户信息通畅的同时,也保持公司内部之间的信息交流,从而提高企业的工作效率和客户服务质量。 管理员帐号:biiz.cn 密码:biiz.cn

下载
A = 1000 * torch.ones((len(data), len(u_data)), dtype=torch.long)
A[torch.arange(len(data)), inverse_indices] = inverse_indices

现在,考虑按列查看张量 A。第 j 列对应于第 j 个唯一行。该列的大部分值为 1000,但某些行将包含 j。该列的 argmin 就是映射到唯一行 j 的第一个原始行的索引。

unique_indices2 = torch.argmin(A, dim=0)

完整代码示例

import torch
import numpy as np

# 示例张量
data = torch.rand(100, 5)
data[np.random.choice(100, 50, replace=False)] = torch.tensor([1.0, 2.0, 3.0, 4.0, 5.0])

# 查找唯一行
u_data, inverse_indices, counts = torch.unique(data, dim=0, return_inverse=True, return_counts=True)

# 使用循环查找首次出现索引(作为参考)
unique_indices = torch.zeros(len(u_data), dtype=torch.long)
for idx in range(len(u_data)):
    unique_indices[idx] = torch.where(inverse_indices == idx)[0][0]

# 使用二维张量和 argmin 查找首次出现索引
A = 1000 * torch.ones((len(data), len(u_data)), dtype=torch.long)
A[torch.arange(len(data)), inverse_indices] = inverse_indices
unique_indices2 = torch.argmin(A, dim=0)

# 验证结果
print(torch.allclose(unique_indices2,unique_indices))

性能注意事项

虽然这种方法避免了循环和 torch.where 函数,但它使用了更多的内存。argmin 函数在硬件上的速度、实际问题的维度以及对内存的重视程度都会影响其效率。在实际应用中,需要根据具体情况权衡内存使用和计算速度,选择最合适的解决方案。如果数据量较小,循环方式可能更简单易懂;如果数据量较大,且对性能要求较高,则可以考虑使用本文介绍的基于张量操作的方法。

相关专题

更多
pytorch是干嘛的
pytorch是干嘛的

pytorch是一个基于python的深度学习框架,提供以下主要功能:动态图计算,提供灵活性。强大的张量操作,实现高效处理。自动微分,简化梯度计算。预构建的神经网络模块,简化模型构建。各种优化器,用于性能优化。想了解更多pytorch的相关内容,可以阅读本专题下面的文章。

428

2024.05.29

Python AI机器学习PyTorch教程_Python怎么用PyTorch和TensorFlow做机器学习
Python AI机器学习PyTorch教程_Python怎么用PyTorch和TensorFlow做机器学习

PyTorch 是一种用于构建深度学习模型的功能完备框架,是一种通常用于图像识别和语言处理等应用程序的机器学习。 使用Python 编写,因此对于大多数机器学习开发者而言,学习和使用起来相对简单。 PyTorch 的独特之处在于,它完全支持GPU,并且使用反向模式自动微分技术,因此可以动态修改计算图形。

5

2025.12.22

vlookup函数使用大全
vlookup函数使用大全

本专题整合了vlookup函数相关 教程,阅读专题下面的文章了解更多详细内容。

28

2025.12.30

金山文档相关教程
金山文档相关教程

本专题整合了金山文档相关教程,阅读专题下面的文章了解更多详细操作。

29

2025.12.30

PS反选快捷键
PS反选快捷键

本专题整合了ps反选快捷键介绍,阅读下面的文章找到答案。

25

2025.12.30

表格中一行两行的方法
表格中一行两行的方法

本专题整合了表格中一行两行的相关教程,阅读专题下面的文章了解更多详细内容。

4

2025.12.30

cpu温度过高解决方法大全
cpu温度过高解决方法大全

本专题整合了cpu温度过高相关教程,阅读专题下面的文章了解更多详细内容。

5

2025.12.30

ASCII码介绍
ASCII码介绍

本专题整合了ASCII码相关内容,阅读专题下面的文章了解更多详细内容。

31

2025.12.30

GPS是什么
GPS是什么

本专题整合了GPS相关内容,阅读专题下面的文章了解更多详细内容。

5

2025.12.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号