clear all;
close all;
clc;
img1=imread('Corner.png');
img2=imread('Corner1.png');
img3=imread('Corner2.png');

img1=imresize(img1,[35 90]); %Matlab的svd不支持太大的数据,我把数据变小了.
img2=imresize(img2,[35 90]);
img3=imresize(img3,[35 90]);

[height width]=size(img2);
a=reshape(double(img1),1,35*90);
b=reshape(double(img2),1,35*90);
c=reshape(double(img3),1,35*90);

ma=mean(a);
mb=mean(b);
mc=mean(c);

a=a-ma;
b=b-mb;
c=c-mc;

x=[a' b' c'];
x=double(x);
%y=x'*x/(height*width);

%[v d]=eig(y);
[u s w]=svd(x); %w相当于排序后的d,用svd就不用求x'*x了

ed=x*w;%v;

img4=zeros(height,width);
img4=reshape(ed(:,1),height,width);

img5=zeros(height,width);
img5=reshape(ed(:,2),height,width);

img6=zeros(height,width);
img6=reshape(ed(:,3),height,width);

imshow(mat2gray(img4));
figure,imshow(mat2gray(img5));
figure,imshow(mat2gray(img6));

参考:

1.http://iiec.cqu.edu.cn/wiki/index.php/SVD%E4%B8%8EPCA%E7%9A%84%E7%93%9C%E8%91%9B

最新文章

  1. PL/SQL通过免安装客户端连接远端ORACLE数据库
  2. libev安装与示例程序编译运行
  3. asp.net判断FileUpload选择的文件是否是图片
  4. 弹出框四 之toastr.js (完成提示框)
  5. 情定XMLA,割舍不下的XAML
  6. bzoj4137 [FJOI2015]火星商店问题
  7. ural 1114,计数dp
  8. Android下各个按键对应的key code
  9. iOS事件机制(二)
  10. SRM 441(1-250pt, 1-500pt)
  11. jquery prop()方法 解决全选 不全选 反选 问题 解决执行一次不不能再执行问题
  12. 【noip 2009】 乌龟棋 记忆化搜索&动规
  13. 很污的机器学习:从xhamster网站找到喜欢的片子
  14. jQuery === 面条式代码?
  15. 前端的UI设计与交互之布局篇
  16. Error response from daemon: conflict: unable to remove repository reference 解决方案
  17. pta编程总结
  18. MyBatisPlus环境下使用MyBatis的配置类
  19. window10安装黑苹果
  20. 初始化Weex项目遇到的问题记录

热门文章

  1. SQL Server :理解数据页结构
  2. Maven和Gradle
  3. 玩转html5(二)----用canvas结合脚本在画布上画简单的图(html5又一强大功能)
  4. OCP解决问题053-16 MEMORY_TARGET
  5. 浅谈http请求数据分析
  6. 引用第三方框架 不支持ARC
  7. 在 VS 类库项目中 Add Service References 和 Add Web References 的区别
  8. Android异步操作总结
  9. 深入理解Javascript闭包概念
  10. atitit.404错误调查过程汇总