pytorch+numpy实现--获取每行中数据大于平均值的数据,将其提取出来转化为稀疏矩阵

代码

import torch
x = torch.randn(3,4)
print(x)
print(torch.mean(x,dim=1,keepdim=True))
mz_items = x[:,] > torch.mean(x,dim=1,keepdim=True)
print(mz_items)
import numpy as np
mz_items_np = mz_items.numpy()
index = np.argwhere( mz_items_np == True )
print(index)
index[:, 1] = index[:, 1]
vals = x[mz_items]
adj = sp.coo_matrix((vals, (index[:, 0], index[:, 1])), shape=(7, 7))
print(adj)

结果:

tensor([[ 0.4772, -0.7524,  0.1866,  0.2946],
        [ 0.3332,  0.6116,  1.0253, -0.8315],
        [-0.5561,  0.5256,  0.5922,  1.3521]])
tensor([[0.0515],
        [0.2846],
        [0.4785]])
tensor([[ True, False,  True,  True],
        [ True,  True,  True, False],
        [False,  True,  True,  True]])
[[0 0]
 [0 2]
 [0 3]
 [1 0]
 [1 1]
 [1 2]
 [2 1]
 [2 2]
 [2 3]]
  (0, 0)	0.47724348
  (0, 2)	0.18663067
  (0, 3)	0.29461738
  (1, 0)	0.33317146
  (1, 1)	0.6115727
  (1, 2)	1.0253372
  (2, 1)	0.5256042
  (2, 2)	0.5922486
  (2, 3)	1.3520662

补充,要获取最大值的方法:

mz_items = x[:,] == torch.max(x,1,keepdim=True).values

torch.argmax可获取最大值的位置

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值