QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 2242|回复: 0
打印 上一主题 下一主题

图像压缩(主成分分析)

[复制链接]
字体大小: 正常 放大

1189

主题

4

听众

2934

积分

该用户从未签到

跳转到指定楼层
1#
发表于 2024-3-31 16:40 |只看该作者 |倒序浏览
|招呼Ta 关注Ta
数据集:任意选择一组图片。
1 U. T2 V, Z& f3 a3 s0 `8 m任务:使用PCA对图片进行压缩和重构。7 H  ^  k  A8 Y: C# G, @6 @
挑战:分析压缩比例与图像质量之间的关系,并尝试使用其他降维技术。2 I6 L, o0 s5 ]
使用PCA进行图像压缩和重构
5 r' }7 g: ^2 }假设你已经安装了必要的Python库,如numpy, matplotlib, 和scikit-learn。如果没有,你可以通过pip安装它们。5 m' \# m3 k3 c- O) n5 D  A
: s& M+ M5 `' l# S+ |! q- d
以下是使用PCA对单张图片进行压缩和重构的步骤:
4 G% ?' i  p% r6 H9 a# s& u. Q6 }' ?9 ~7 X
加载图片:首先,我们需要加载一张图片并将其转换为合适的格式。4 t4 ~" c$ f4 @# g$ }8 v

1 S% x3 f1 K" Q$ A应用PCA:然后,我们将应用PCA来降低图片的维度,实现压缩。* y5 {/ ^! {  P, p
! m" o4 o* D1 v% H; Q. J
重构图片:最后,我们将使用PCA的逆变换来重构图片,尽量恢复原始图片。
  1. import numpy as np* g9 w/ {1 z9 N) Z
  2. from sklearn.decomposition import PCA
    ( f6 v* _- e/ Y; @' t+ `) z. i4 a. L
  3. import matplotlib.pyplot as plt
    ) Q! h( o, b3 l( J
  4. from PIL import Image
    ' V2 x: \9 ]6 k) Q3 @. v
  5. \" U7 Q& z: a2 U* o
  6. # 加载图片并转换为灰度图+ D9 b5 ?* B, W# H$ M4 y
  7. image_path = 'path_to_your_image.jpg'3 Z: c* W\" u6 P3 A
  8. image = Image.open(image_path).convert('L')
    8 ^# [0 ~( G9 m4 h0 [* ~( S
  9. image_array = np.array(image)0 g) u! F9 U) e2 h

  10.   \/ v1 U- r4 f! d. w
  11. # 展平图像数组
    6 u* T) A3 Q: v) H5 w9 t5 E$ q
  12. h, w = image_array.shape4 K9 r' a3 Q$ p5 [
  13. image_flattened = image_array.flatten().reshape(1, h * w)- ~0 [2 F0 |2 v0 X0 j

  14. 7 A; L: Q0 A1 a' P6 g: o3 m0 i
  15. # 应用PCA
    / Z, ~& b9 N1 v* c( @
  16. n_components = 100  # 选择保留的主成分数量
    % ~3 C: [- {7 ~* A7 x
  17. pca = PCA(n_components=n_components)
    6 s5 v* u* ~; b# f  R& x
  18. image_compressed = pca.fit_transform(image_flattened)
    ! M) s/ X, g% b7 r' ^, i
  19. 4 g( Q/ b$ v. H( K
  20. # 重构图像
    # h8 `* P; g( R\" {\" A& c. n
  21. image_reconstructed = pca.inverse_transform(image_compressed).reshape(h, w)9 p  i4 x( }5 i) l

  22. + \. P$ i% r# u+ @( a
  23. # 显示原始和重构的图像
    , Z; I0 J\" @7 u. ^$ ^/ x* {
  24. plt.figure(figsize=(10, 5))) D* m2 v- G8 J2 U' v, @
  25. plt.subplot(1, 2, 1)
    ) I& `\" }1 O, e
  26. plt.imshow(image_array, cmap='gray')6 J( I/ z  z! {# p2 Q( V
  27. plt.title('Original Image')
    # @, u( Q+ e6 n5 x% V
  28. plt.subplot(1, 2, 2)
      V0 a0 Q3 a- \! M6 i4 L9 n4 I
  29. plt.imshow(image_reconstructed, cmap='gray'): x% `7 n2 E9 a. D1 c+ F5 K7 U
  30. plt.title('Reconstructed Image')
    9 k  c5 T( j/ {. _
  31. plt.show()
复制代码
分析压缩比例与图像质量之间的关系
' m1 p* L. d' K( n1 W8 a: z& Q0 z% t压缩比例与图像质量之间的关系可以通过改变n_components(PCA中保留的主成分数量)来探索。减少n_components会增加压缩比例,但可能会降低重构图像的质量。通过观察不同n_components值对应的重构图像,可以分析这种权衡关系。
( Z/ Y1 i5 |% j& F2 {; F; y1 W; d% Z7 A
' g* ^) e0 T* O6 d( N' O& n尝试其他降维技术* e9 D8 X0 _/ ^( {
除了PCA之外,还有其他降维技术可以用于图像压缩,例如:
+ f3 \- F* d/ I4 a9 l
! c: \* D6 P7 b3 ~6 }2 W随机投影(sklearn.random_projection)+ a6 H# V+ ^' x0 `% t' n7 K
非负矩阵分解(NMF,sklearn.decomposition.NMF)8 B) ]. ^6 A1 G2 Q: T0 J4 B
这些方法也可以用类似的方式应用于图像压缩,通过比较不同方法的效果,你可以深入理解各种降维技术在图像压缩任务中的表现和适用性。
  L. U; d9 L* l% [/ x
/ I8 D) z! o. y$ A6 B( ~& X: i' }  E# s

) u2 p2 H6 i& J* F/ ^- B3 \9 x9 _
zan
转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
您需要登录后才可以回帖 登录 | 注册地址

qq
收缩
  • 电话咨询

  • 04714969085
fastpost

关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

手机版|Archiver| |繁體中文 手机客户端  

蒙公网安备 15010502000194号

Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

GMT+8, 2026-6-14 16:34 , Processed in 0.435831 second(s), 51 queries .

回顶部