PyTorch_张量索引操作

简单行,列索引操作

python 复制代码
import torch 
import numpy as np 

# 简单行列索引
def test01():
    data = torch.randint(0, 10, [4, 5])
    print(data)

    # 获得指定的某行元素
    print(data[0])

    # 获得指定某个列的元素
    print(data[:, 0])  # 逗号前面表示行,逗号后面表示列。冒号表示所有行或者所有列

    # 获得指定位置的某个元素
    print(data[1, 2])

    # 表示先获得前三行,再获得第三列的数据
    print(data[:3, 2])

    # 表示获得前三行的前两列
    print(data[:3, :2])

# 列表索引
def test02():
    data = torch.randint(0, 10, [4, 5])
    print(data)

    # 如果索引的行列都是一个一维的列表,那么两个列表的长度必须相等
    # 表示获得 (0, 0), (2, 1), (3, 2) 三个位置的元素
    print(data[[0, 2, 3], [0, 1, 2]])

    # 表示获得 0, 2, 3 行的 0, 1, 2 列
    print(data[[[0], [2], [3]], [0, 1, 2]])


if __name__ == "__main__":
    test02() 

布尔索引

python 复制代码
import torch 
import numpy as np 

# 布尔索引
def test01():
    torch.manual_seed(0)
    data = torch.randint(0, 10, [4, 5])
    print(data)

    # 能够获得该张量中所有大于3的元素
    # 张量可以与数字做比较
    print(data > 3)
    print(data[data > 3])

    # 返回第2列元素大于6的行
    print(data[data[:, 1] > 6])

    # 返回第2行元素大于3的所有列
    print(data[:, data[1] > 3])


# 多维索引
def test02():
    torch.manual_seed(0)
    data = torch.randint(0, 10, [3, 4, 5])
    print(data)

    # 选择第0行的所有元素
    print(data[0, :, :])

    # 按照第1哥维度选择第0元素, 是按行
    print(data[:, 0, :])

    # 按照第2个维度选择第0元素, 是按列
    print(data[:, :, 0])

if __name__ == "__main__":
    test02() 
相关推荐
白熊188几秒前
【计算机视觉】三维重建: MVSNet:基于深度学习的多视图立体视觉重建框架
人工智能·深度学习·计算机视觉
42fourtytoo34 分钟前
从0开始建立Github个人博客(hugo&PaperMod)
运维·服务器·python·go·github
CodeJourney.44 分钟前
Kotlin革新数据分析
人工智能·爬虫·算法·信息可视化
飘若随风1 小时前
PyTorch数据集与数据集加载
人工智能·pytorch·python
Doker 多克1 小时前
Python-Django系列—视图
开发语言·python·django
_Itachi__1 小时前
Python 中的 collections 库:高效数据结构的利器
linux·数据结构·python
钢铁男儿1 小时前
Python 装饰器优化策略模式:电商促销折扣的优雅解法
开发语言·python·策略模式
solomonzw1 小时前
with的用法
数据库·python·sqlite
白瑕1 小时前
[python]非零基础上手之文件操作
python
正宗咸豆花2 小时前
Prompt多版本测试指南:如何科学评估不同提示词的效果
人工智能·microsoft·prompt