高光谱图像基于MATLAB的PCA降维

本文介绍了如何使用MATLAB进行高光谱图像的PCA降维。以Salinas数据集为例,将204维数据降至3维,通过PCA函数计算降维后的精度,并展示保留前三维的还原效果。
摘要由CSDN通过智能技术生成

工具:matlab,本人使用的是2016a
使用数据集用公开的Salinas数据集为例,Salinas数据集为512*217*204,即它有204个波段,我们要把它从204维降至3维。

matlab中内含了进行PCA降维的函数,但这个函数输进去的数据要是二维的,所以我们先用resharp函数把原矩阵处理成111104*204的矩阵M
再使用自带的降维函数:
[pc,score,latent,tsquare] = pca(M)

latent用来计算降维后取多少维度能够达到自己需要的精度,
通过下面的代码运行结果可以得到取pc中对应每一维度对原始数据的精度:
在命令行输入
cumsum(latent)./sum(latent)
部分截如下

我们可以看到只去取第一维的话和原始数据的准确度只有74.4%,我们取到第三维,此时已有99%的精度,一般来说取到90%以上即可。

再取前三维,把矩阵还原为三维。此时便已完成了对高光谱图像的降维。

完整代码如下:
M=reshape(d,111104,204);
[pc,score,latent,tsquare] = pca(M);
feature_after_PCA=score(:,1:3);
RES=reshape(feature_after_PCA,512,217,3);

导入进来的矩阵命名为d

把它转为图片看看效果:
imwrite(RES(:,:,1),’1.jpg’);

评论 11
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值