2020-06-12
阅读量:
2101
SVD-矩阵奇异值分解 —— 原理与几何意义
1.简介
SVD 全称:Singular Value Decomposition。SVD 是一种提取信息的强大工具,它提供了一种非常便捷的矩阵分解方式,能够发现数据中十分有意思的潜在模式。
主要应用领域包括:
- 隐性语义分析 (Latent Semantic Analysis, LSA) 或隐性语义索引 (Latent Semantic Indexing, LSI);
- 推荐系统 (Recommender system),可以说是最有价值的应用点;
- 矩阵形式数据(主要是图像数据)的压缩。
2.线性变换
data:image/s3,"s3://crabby-images/2d502/2d502c9c17f40d0fdc74b946a3e4b4f96a0b6855" alt=""
3. SVD 推导
data:image/s3,"s3://crabby-images/fbb82/fbb82cc134be3012c76f677f6e9d0cc667c53440" alt=""
data:image/s3,"s3://crabby-images/d2d54/d2d54c180447eff63657a52c88949e9bfeabe33d" alt=""
data:image/s3,"s3://crabby-images/ed40d/ed40db712664d75ba62f401dd4bbb42d899e78a4" alt=""
.4 实现代码
以下是基于 python 的 numpy 库实现的 SVD 矩阵分解的代码,用于实现图像压缩的功能。
代码链接 : https://github.com/zlxy9892/ml_
# -*- coding: utf-8 -*-
import numpy as np
import numpy.linalg as la
import matplotlib.pyplot as plt
from sklearn import datasets
from skimage import io
def getImgAsMat(index):
ds = datasets.fetch_olivetti_faces()
return np.mat(ds.images[index])
def getImgAsMatFromFile(filename):
img = io.imread(filename, as_grey=True)
return np.mat(img)
def plotImg(imgMat):
plt.imshow(imgMat, cmap=plt.cm.gray)
plt.show()
def recoverBySVD(imgMat, k):
# singular value decomposition
U, s, V = la.svd(imgMat)
# choose top k important singular values (or eigens)
Uk = U[:, 0:k]
Sk = np.diag(s[0:k])
Vk = V[0:k, :]
# recover the image
imgMat_new = Uk * Sk * Vk
return imgMat_new
# -------------------- main --------------------- #
A = getImgAsMatFromFile('D:/pic.jpg')
plotImg(A)
A_new = recoverBySVD(A, 30)
plotImg(A_new)
这里用小黄人的大头照做个例子看看:
原图:
data:image/s3,"s3://crabby-images/734a0/734a0ac0b7c2e2e6dd6f60abc21374eda5be9286" alt=""
设置 k = 10,得到的压缩图:
data:image/s3,"s3://crabby-images/aed39/aed39361707c807c3e2956d2ca720ef8ca558a78" alt=""
k = 20:
data:image/s3,"s3://crabby-images/0cc62/0cc620ce476994d5b1fb416b80e9f103464070ee" alt=""
k = 30:
data:image/s3,"s3://crabby-images/2ac32/2ac32cd234836a8e96deb0f791256e53d4841ec8" alt=""
继续增加 k 值,将会得到越来越接近原始图的压缩图。
5 参考资料
data:image/s3,"s3://crabby-images/b36c2/b36c2fbcf3758545d67d271c049a8bc8fd1e7d4d" alt=""
data:image/s3,"s3://crabby-images/c1041/c1041b9802f860f6d67283093b35732a8b1f80c5" alt=""
data:image/s3,"s3://crabby-images/9c257/9c2577908bb770785ef077ba18c5717c406e2104" alt=""
data:image/s3,"s3://crabby-images/3a93f/3a93f3403d3655a5ceec3159c354822d8d026c35" alt=""
data:image/s3,"s3://crabby-images/72cfe/72cfee970cdf98a52ca83720dc7e2835e677467a" alt=""
data:image/s3,"s3://crabby-images/dcba3/dcba3b87fb2a23c8c1a358b4a53d67a040b26a2c" alt=""
评论(0)
data:image/s3,"s3://crabby-images/c16c8/c16c82a5943bfa92a18aafac1e2b0488ad2a178d" alt=""
data:image/s3,"s3://crabby-images/91e50/91e5062b55d0de13ef1d78e26cec2f5b2f545583" alt=""
暂无数据
推荐帖子
0条评论
0条评论
0条评论