- 在线时间
- 478 小时
- 最后登录
- 2026-4-9
- 注册时间
- 2023-7-11
- 听众数
- 4
- 收听数
- 0
- 能力
- 0 分
- 体力
- 7788 点
- 威望
- 0 点
- 阅读权限
- 255
- 积分
- 2922
- 相册
- 0
- 日志
- 0
- 记录
- 0
- 帖子
- 1171
- 主题
- 1186
- 精华
- 0
- 分享
- 0
- 好友
- 1
该用户从未签到
 |
数据集:任意选择一组图片。
- q! f# ?$ h: x$ h任务:使用PCA对图片进行压缩和重构。9 [% v6 V: I* {, W% r
挑战:分析压缩比例与图像质量之间的关系,并尝试使用其他降维技术。- _! a* m4 C8 i( X2 G
使用PCA进行图像压缩和重构. `0 F9 Y0 h# {. j
假设你已经安装了必要的Python库,如numpy, matplotlib, 和scikit-learn。如果没有,你可以通过pip安装它们。) G+ ?- j8 B# S- `- Q+ n( P
/ m* G5 p6 H3 a$ h
以下是使用PCA对单张图片进行压缩和重构的步骤:" k# |. e& \5 Y' j2 r& R2 b7 H
5 y* a; i7 q! `* r' C加载图片:首先,我们需要加载一张图片并将其转换为合适的格式。$ k- @+ Y+ N% |# V6 [; k
) y/ Z, T+ T' K: Q, M3 C# B# W) z0 A
应用PCA:然后,我们将应用PCA来降低图片的维度,实现压缩。6 E$ u& z5 ?* D, M% _" P* Z
2 q5 c: \' X& P& a
重构图片:最后,我们将使用PCA的逆变换来重构图片,尽量恢复原始图片。- import numpy as np
: E T* K: o4 U; ]3 D2 d2 J5 B - from sklearn.decomposition import PCA' J\" I4 h7 a% Y; [3 e6 a
- import matplotlib.pyplot as plt/ {# L' U3 U( ]! k2 t
- from PIL import Image
6 X, k+ x/ U) `; W/ P7 K - 9 x1 P: r) G6 [9 b3 R; v
- # 加载图片并转换为灰度图
5 t! ~- D; ]3 V% t& W - image_path = 'path_to_your_image.jpg'6 |( t, i* Q\" R
- image = Image.open(image_path).convert('L')8 [9 ~$ S( \! h9 r+ p# ~
- image_array = np.array(image)
5 W8 f5 D, j8 l6 Z8 y( Z -
2 i& q2 \! [; Y8 Q$ V, m6 R. o - # 展平图像数组, i3 ]. Z# R0 f2 m
- h, w = image_array.shape/ @8 Q* H L/ D) P4 n0 m* ~2 E$ u0 s
- image_flattened = image_array.flatten().reshape(1, h * w)# g0 M' T* ]) ]% @5 F, v2 f\" T0 W
-
9 N7 a3 i: r! n b/ H) J' j- ? - # 应用PCA
: b! _2 ]7 B! r8 q\" P+ D$ C* x - n_components = 100 # 选择保留的主成分数量$ c7 |& X- Z2 y7 H
- pca = PCA(n_components=n_components)
/ u1 h7 w2 u* q4 {& A; \( V7 Z - image_compressed = pca.fit_transform(image_flattened)
' L2 C7 {1 w \ -
/ Z H1 J4 i9 o2 P: Z* t0 R - # 重构图像
v/ B2 ^ R6 B, j( s - image_reconstructed = pca.inverse_transform(image_compressed).reshape(h, w)& O9 t; `& X! _0 r h/ `
- . |* ~8 i; _; f* I5 A\" t: C' K' |
- # 显示原始和重构的图像
; s2 L- W( E# g) r - plt.figure(figsize=(10, 5))) U; i& ]7 i+ `3 D& w0 L5 K
- plt.subplot(1, 2, 1)
3 a% P( B0 S2 `2 j, j& R( r\" L. n - plt.imshow(image_array, cmap='gray')+ @3 f3 n4 ~# t* }$ g! s
- plt.title('Original Image')
0 Z\" P3 D8 [2 Z6 x2 h - plt.subplot(1, 2, 2)
5 [; W$ j# e2 \\" [) g. U9 I, m - plt.imshow(image_reconstructed, cmap='gray'): D0 U2 W5 r' F7 c+ A7 V- ~7 u
- plt.title('Reconstructed Image')\" }3 t\" T! \6 d' q; n7 i
- plt.show()
复制代码 分析压缩比例与图像质量之间的关系# m, h" A. a @6 P& e; p" ^
压缩比例与图像质量之间的关系可以通过改变n_components(PCA中保留的主成分数量)来探索。减少n_components会增加压缩比例,但可能会降低重构图像的质量。通过观察不同n_components值对应的重构图像,可以分析这种权衡关系。
: M7 I1 n( X, S' \
& [ \; N) _8 P+ [+ M尝试其他降维技术
$ M3 q6 I& m3 r: ^- X7 e D除了PCA之外,还有其他降维技术可以用于图像压缩,例如:: R4 t% M4 I0 `# O) I: M! _$ T
( A" f- w$ D: H) g. f8 ^: k9 I; D随机投影(sklearn.random_projection)
6 z+ J1 S3 j/ E( E& Z* M非负矩阵分解(NMF,sklearn.decomposition.NMF)
: P3 H5 t5 t1 e9 F8 n) s3 X这些方法也可以用类似的方式应用于图像压缩,通过比较不同方法的效果,你可以深入理解各种降维技术在图像压缩任务中的表现和适用性。
" q: q- ]) H$ a: t% F
+ U& l4 ?; R% x, Z$ Z3 D# x# \$ k9 ~: l, [& R
+ ?- T8 j7 r" G
|
zan
|