sp.coo_matrix

import numpy as np
import scipy.sparse as sp
import torch

a = np.array([[1,0,0,1,0],[0,1,1,0,0],[0,0,0,0,1],[1,0,0,0,1],[0,0,1,0,0]])
a = sp.coo_matrix(a,shape=(5,5))
sparse_mx = a.tocoo().astype(np.float32)
print(sparse_mx.row)
print(sparse_mx.col)
print(sparse_mx.data)
print(sparse_mx.shape)

indices = torch.from_numpy(np.vstack((sparse_mx.row, sparse_mx.col)).astype(np.int64)) # 存储非零元素的行列坐标

values = torch.from_numpy(sparse_mx.data)
shape = torch.Size(sparse_mx.shape)
print(torch.sparse.FloatTensor(indices, values, shape))

输出:
[0 0 1 1 2 3 3 4]
[0 3 1 2 4 0 4 2]
[1. 1. 1. 1. 1. 1. 1. 1.]
(5, 5)
tensor(indices=tensor([[0, 0, 1, 1, 2, 3, 3, 4],
[0, 3, 1, 2, 4, 0, 4, 2]]),
values=tensor([1., 1., 1., 1., 1., 1., 1., 1.]),
size=(5, 5), nnz=8, layout=torch.sparse_coo)

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值