python 生成随机稀疏矩阵

生成随机矩阵

import numpy as np
import scipy.sparse as ss

# 生成随机稀疏矩阵
num_col = 20
num_row = 10
num_ele = 40
a = [np.random.randint(0,num_row) for _ in range(num_ele)]
b = [np.random.randint(0,num_col) for _ in range(num_ele-num_col)] + [i for i in range(num_col)]  # 保证每一列都有值,不会出现全零列
c = [np.random.rand() for _ in range(num_ele)]
rows, cols, v = np.array(a), np.array(b), np.array(c)
sparseX = ss.coo_matrix((v,(rows,cols)))
X = sparseX.todense()

fig = plt.figure()
ax = fig.add_subplot(111)
ax.matshow(X, vmin=0, vmax=1, cmap='magma')
ax.set_xticks([])
ax.set_yticks([])
plt.show()

在这里插入图片描述

常用 colormap
在这里插入图片描述
在这里插入图片描述

生成稀疏编码信号

from sklearn.datasets import make_sparse_coded_signal

n_samples, n_components, n_features = 5, 10, 8
n_nonzero_coefs = 3

# Y = DX
# |x_i|_0 = n_nonzero_coefs

Y, D, X = make_sparse_coded_signal(n_samples=n_samples,
                                   n_components=n_components,
                                   n_features=n_features,
                                   n_nonzero_coefs=n_nonzero_coefs,
                                   random_state=42)

这是字典学习中处理的问题:
Y = D X Y = DX Y=DX
X X X 为原始信号 Y Y Y 的稀疏编码。
在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值