[PyTroch系列-5]:PyTorch基础 - 稀疏矩阵与其创建方法

作者主页(文火冰糖的硅基工坊):https://blog.csdn.net/HiWangWenBing

本文网址:https://blog.csdn.net/HiWangWenBing/article/details/119423982


目录

第1部分 稀疏矩阵概述

1.1 概述

1.2 COO矩阵的原理

第2部分 稀疏矩阵创建的代码示例

2.1 环境准备

2.2 COO矩阵

2.3 目标稀疏矩阵

参考:


第1部分 稀疏矩阵概述

1.1 概述

稀疏矩阵指矩阵中的大多数元素的值都为0,由于其中非常多的元素都是0,使用常规方法进行存储非常的浪费空间,所以采用另外的方法存储稀疏矩阵。

1.2 COO矩阵的原理

Coordinate(COO)格式是用来描述稀疏矩阵一种方法或数据结构。

Coordinate(COO)格式本身是一个矩阵,用COO矩阵,描述另一个目标稀疏矩阵,原理如下:

这是非常简单的一种方式,使用一个三元组构成的三维COO矩阵来描述任意维度的稀疏矩阵。

三元组分别表示稀疏矩阵中的元素(所在行,所在列,元素值)。

如上图目标矩阵,一共有4*4的目标矩阵,共16个元素,其中4个非零元素:

(0, 0) 位置的值是1。

(0,1) 位置的值是7

(1,1) 位置的值是2

(1,2) 位置的值是8

因此需要3 * 4的COO矩阵,来描述一个4*4的稀疏矩阵。

很显然,通过上述方法,目标稀疏矩阵的每个位置,需要通过3个数组来表示,增加了存储空间。

因此当矩阵规模比较小时,上述的表示是浪费存储空间的。

只有当矩阵的规模比较大,且是稀疏矩阵时,上述的表示才体现出优势。

第2部分 稀疏矩阵创建的代码示例

2.1 环境准备

import numpy as np
import torch

print("Hello World")
print(torch.__version__)
print(torch.cuda.is_available())

2.2 COO矩阵

indices = torch.tensor([[0, 0, 1, 1], [0, 1, 1, 2]])
values = torch.tensor([1, 7, 2, 8], dtype=torch.float32)
a = torch.sparse_coo_tensor(indices=indices, values=values, size=[4, 4])

print(a)

print(a.device)
print(a.layout)
print(a.dtype)       #tensor的数据类型
print(a.type)        #tensor本身的类型
print(a.type())      #tensor的数据类型
print(a.size())
print(a.shape)      #tensor的维度
输出:

tensor(indices=tensor([[0, 0, 1, 1],
                       [0, 1, 1, 2]]),
       values=tensor([1., 7., 2., 8.]),
       size=(4, 4), nnz=4, layout=torch.sparse_coo)
cpu
torch.sparse_coo
torch.float32
<built-in method type of Tensor object at 0x000002655E57B980>
torch.sparse.FloatTensor
torch.Size([4, 4])
torch.Size([4, 4])

2.3 目标稀疏矩阵

b = a.to_dense()  #把COO矩阵转换成稀疏矩阵

print(b)

print(a.device)
print(a.layout)
print(a.dtype)       #tensor的数据类型
print(a.type)        #tensor本身的类型
print(a.type())      #tensor的数据类型
print(a.size())
print(a.shape)      #tensor的维度

输出:

tensor([[1., 7., 0., 0.],
        [0., 2., 8., 0.],
        [0., 0., 0., 0.],
        [0., 0., 0., 0.]])
cpu
torch.sparse_coo
torch.float32
<built-in method type of Tensor object at 0x000002655E57B980>
torch.sparse.FloatTensor
torch.Size([4, 4])
torch.Size([4, 4])

参考:

Pytorch官方教程:https://www.pytorch123.com/


作者主页(文火冰糖的硅基工坊):https://blog.csdn.net/HiWangWenBing

本文网址:https://blog.csdn.net/HiWangWenBing/article/details/119423982

 

  • 0
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
PyTorch中,稀疏矩阵是一种特殊的数据结构,用于存储大量零元素的矩阵。PyTorch提供了`torch.sparse`模块来支持稀疏矩阵创建和操作。 可以通过以下方式创建稀疏矩阵: 1. 使用`torch.sparse.FloatTensor`构造函数创建一个稀疏张量: ```python import torch # 创建稀疏矩阵 indices = torch.LongTensor([[0, 1], [2, 0]]) values = torch.FloatTensor([1, 2]) size = torch.Size([3, 2]) sparse_matrix = torch.sparse.FloatTensor(indices, values, size) ``` 在上述代码中,我们创建了一个3x2的稀疏矩阵,其中包含两个非零元素。 2. 可以使用`to_sparse()`方法将稠密矩阵转换为稀疏矩阵: ```python import torch # 创建稠密矩阵 dense_matrix = torch.FloatTensor([[1, 0], [0, 2], [3, 0]]) # 转换为稀疏矩阵 sparse_matrix = dense_matrix.to_sparse() ``` 在上述代码中,我们将一个稠密矩阵转换为稀疏矩阵。 对于稀疏矩阵,可以使用以下方法进行操作: 1. 使用`_indices()`方法获取稀疏矩阵的非零元素的索引: ```python indices = sparse_matrix._indices() ``` 2. 使用`_values()`方法获取稀疏矩阵的非零元素的值: ```python values = sparse_matrix._values() ``` 3. 使用`_nnz()`方法获取稀疏矩阵的非零元素的数量: ```python nnz = sparse_matrix._nnz() ``` 这些方法可用于访问稀疏矩阵的相关信息和数据。 希望以上信息能对你理解PyTorch中的稀疏矩阵有所帮助。如果还有其他问题,请随时提问。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

文火冰糖的硅基工坊

你的鼓励是我前进的动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值