主要内容:

  1. StOMP的算法流程
  2. StOMP的MATLAB实现
  3. 一维信号的实验与结果
  4. 门限参数Ts、测量数M与重构成功概率关系的实验与结果

一、StOMP的算法流程

分段正交匹配追踪(Stagewise OMP)也是由OMP改进而来的一种贪心算法,与CoSaMP、SP算法类似,不同之处在于CoSaMP、SP算法在迭代过程中选择的是与信号内积最大的2K或K个原子,而StOMP是通过门限阈值来确定原子。此算法的输入参数中没有信号稀疏度K,因此相比于ROMP及CoSaMP有独到的优势(这句话存在疑问)。

StOMP的算法流程:

二、StOMP的MATLAB实现(CS_StOMP.m)

  1. function [ theta ] = CS_StOMP( y,A,S,ts )
  2. % CS_StOMP
  3. % Detailed explanation goes here
  4. % y = Phi * x
  5. % x = Psi * theta
  6. % y = Phi*Psi * theta
  7. % A = Phi*Psi, y=A*theta
  8. % S is the maximum number of StOMP iterations to perform
  9. % ts is the threshold parameter
  10. % 现在已知yA,求theta
  11. % Reference:Donoho D LTsaig YDrori IStarck J LSparse solution of
  12. % underdetermined linear equations by stagewise orthogonal matching
  13. % pursuit[J].IEEE Transactions on Information Theory,,():—
  14. if nargin <
  15. ts = 2.5; %ts范围[,],默认值为2.
  16. end
  17. if nargin <
  18. S = ; %S默认值为10
  19. end
  20. [y_rows,y_columns] = size(y);
  21. if y_rows<y_columns
  22. y = y'; %y should be a column vector
  23. end
  24. [M,N] = size(A); %传感矩阵A为M*N矩阵
  25. theta = zeros(N,); %用来存储恢复的theta(列向量)
  26. pos_num = []; %用来迭代过程中存储A被选择的列序号
  27. res = y; %初始化残差(residual)为y
  28. for ss=:S %最多迭代S次
  29. product = A'*res; %传感矩阵A各列与残差的内积
  30. sigma = norm(res)/sqrt(M); %参见参考文献第3Remarks()
  31. Js = find(abs(product)>ts*sigma); %选出大于阈值的列
  32. Is = union(pos_num,Js); %pos_numJs并集
  33. if length(pos_num) == length(Is)
  34. if ss==
  35. theta_ls = ; %防止第1次就跳出导致theta_ls无定义
  36. end
  37. break; %如果没有新的列被选中则跳出循环
  38. end
  39. %At的行数要大于列数,此为最小二乘的基础(列线性无关)
  40. if length(Is)<=M
  41. pos_num = Is; %更新列序号集合
  42. At = A(:,pos_num); %将A的这几列组成矩阵At
  43. else %At的列数大于行数,列必为线性相关的,At'*At将不可逆
  44. if ss==
  45. theta_ls = ; %防止第1次就跳出导致theta_ls无定义
  46. end
  47. break; %跳出for循环
  48. end
  49. %y=At*theta,以下求theta的最小二乘解(Least Square)
  50. theta_ls = (At'*At)^(-1)*At'*y; %最小二乘解
  51. %At*theta_ls是y在At列空间上的正交投影
  52. res = y - At*theta_ls; %更新残差
  53. if norm(res)<1e- %Repeat the steps until r=
  54. break; %跳出for循环
  55. end
  56. end
  57. theta(pos_num)=theta_ls; %恢复出的theta
  58. end

三、一维信号的实验与结果

  1. %压缩感知重构算法测试
  2. clear all;close all;clc;
  3. M = ; %观测值个数
  4. N = ; %信号x的长度
  5. K = ; %信号x的稀疏度
  6. Index_K = randperm(N);
  7. x = zeros(N,);
  8. x(Index_K(:K)) = *randn(K,); %xK稀疏的,且位置是随机的
  9. Psi = eye(N); %x本身是稀疏的,定义稀疏矩阵为单位阵x=Psi*theta
  10. Phi = randn(M,N)/sqrt(M); %测量矩阵为高斯矩阵
  11. A = Phi * Psi; %传感矩阵
  12. y = Phi * x; %得到观测向量y
  13.  
  14. %% 恢复重构信号x
  15. tic
  16. theta = CS_StOMP(y,A);
  17. x_r = Psi * theta; % x=Psi * theta
  18. toc
  19.  
  20. %% 绘图
  21. figure;
  22. plot(x_r,'k.-'); %绘出x的恢复信号
  23. hold on;
  24. plot(x,'r'); %绘出原信号x
  25. hold off;
  26. legend('Recovery','Original')
  27. fprintf('\n恢复残差:');
  28. norm(x_r-x) %恢复残差

四、门限参数ts、测量数M与重构成功概率关系的实验与结果

  1. clear all;close all;clc;
  2.  
  3. %% 参数配置初始化
  4. CNT = ;%对于每组(K,M,N),重复迭代次数
  5. N = ;%信号x的长度
  6. Psi = eye(N);%x本身是稀疏的,定义稀疏矩阵为单位阵x=Psi*theta
  7. ts_set = :0.2:;
  8. K_set = [,,,,];%信号x的稀疏度集合
  9. Percentage = zeros(N,length(K_set),length(ts_set));%存储恢复成功概率
  10.  
  11. %% 主循环,遍历每组(ts,K,M,N)
  12. tic
  13. for tt = :length(ts_set)
  14. ts = ts_set(tt);
  15. for kk = :length(K_set)
  16. K = K_set(kk);%本次稀疏度
  17. %M没必要全部遍历,每隔5测试一个就可以了
  18. M_set=*K::N;
  19. PercentageK = zeros(,length(M_set));%存储此稀疏度K下不同M的恢复成功概率
  20. for mm = :length(M_set)
  21. M = M_set(mm);%本次观测值个数
  22. fprintf('ts=%f,K=%d,M=%d\n',ts,K,M);
  23. P = ;
  24. for cnt = :CNT %每个观测值个数均运行CNT
  25. Index_K = randperm(N);
  26. x = zeros(N,);
  27. x(Index_K(:K)) = *randn(K,);%xK稀疏的,且位置是随机的
  28. Phi = randn(M,N)/sqrt(M);%测量矩阵为高斯矩阵
  29. A = Phi * Psi;%传感矩阵
  30. y = Phi * x;%得到观测向量y
  31. theta = CS_StOMP(y,A,,ts);%恢复重构信号theta
  32. x_r = Psi * theta;% x=Psi * theta
  33. if norm(x_r-x)<1e-%如果残差小于1e-6则认为恢复成功
  34. P = P + ;
  35. end
  36. end
  37. PercentageK(mm) = P/CNT*;%计算恢复概率
  38. end
  39. Percentage(:length(M_set),kk,tt) = PercentageK;
  40. end
  41. end
  42. toc
  43. save StOMPMtoPercentage1000 %运行一次不容易,把变量全部存储下来
  44.  
  45. %% 绘图
  46. for tt = :length(ts_set)
  47. S = ['-ks';'-ko';'-kd';'-kv';'-k*'];
  48. figure;
  49. for kk = :length(K_set)
  50. K = K_set(kk);
  51. M_set=*K::N;
  52. L_Mset = length(M_set);
  53. plot(M_set,Percentage(:L_Mset,kk,tt),S(kk,:));%绘出x的恢复信号
  54. hold on;
  55. end
  56. hold off;
  57. xlim([ ]);
  58. legend('K=4','K=12','K=20','K=28','K=36');
  59. xlabel('Number of measurements(M)');
  60. ylabel('Percentage recovered');
  61. title(['Percentage of input signals recovered correctly(N=256,ts=',...
  62. num2str(ts_set(tt)),')(Gaussian)']);
  63. end
  64. for kk = :length(K_set)
  65. K = K_set(kk);
  66. M_set=*K::N;
  67. L_Mset = length(M_set);
  68. S = ['-ks';'-ko';'-kd';'-kv';'-k*';'-k+'];
  69. figure;
  70. for tt = :length(ts_set)
  71. plot(M_set,Percentage(:L_Mset,kk,tt),S(tt,:));%绘出x的恢复信号
  72. hold on;
  73. end
  74. hold off;
  75. xlim([ ]);
  76. legend('ts=2.0','ts=2.2','ts=2.4','ts=2.6','ts=2.8','ts=3.0');
  77. xlabel('Number of measurements(M)');
  78. ylabel('Percentage recovered');
  79. title(['Percentage of input signals recovered correctly(N=256,K=',...
  80. num2str(K),')(Gaussian)']);
  81. end

1、门限参数ts分别为2.0,2.2,2.4,2.6,2.8,3.0时,不同稀疏信号下,测量值M与重构成功概率的关系:

2、稀疏度为4,12,20,28,36时,不同门限参数ts下,测量值M与重构成功概率的关系:

结论:

通过对比可以看出,总体上讲ts=2.4或ts=2.6时效果较好,较大和较小重构效果都会降低,这里由于没有ts=2.5的情况,但我们推测ts=2.5应该是一个比较好的值,因此一般默认取为2.5即可。

六、参考文章

http://blog.csdn.net/jbb0523/article/details/45441601

浅谈压缩感知(二十五):压缩感知重构算法之分段正交匹配追踪(StOMP)的更多相关文章

  1. [转]压缩感知重构算法之分段正交匹配追踪(StOMP)

    分段正交匹配追踪(StagewiseOMP)或者翻译为逐步正交匹配追踪,它是OMP另一种改进算法,每次迭代可以选择多个原子.此算法的输入参数中没有信号稀疏度K,因此相比于ROMP及CoSaMP有独到的 ...

  2. 浅谈压缩感知(二十二):压缩感知重构算法之正则化正交匹配追踪(ROMP)

    主要内容: ROMP的算法流程 ROMP的MATLAB实现 一维信号的实验与结果 测量数M与重构成功概率关系的实验与结果 一.ROMP的算法流程 正则化正交匹配追踪ROMP算法流程与OMP的最大不同之 ...

  3. 浅谈压缩感知(二十八):压缩感知重构算法之广义正交匹配追踪(gOMP)

    主要内容: gOMP的算法流程 gOMP的MATLAB实现 一维信号的实验与结果 稀疏度K与重构成功概率关系的实验与结果 一.gOMP的算法流程 广义正交匹配追踪(Generalized OMP, g ...

  4. 浅谈压缩感知(二十六):压缩感知重构算法之分段弱正交匹配追踪(SWOMP)

    主要内容: SWOMP的算法流程 SWOMP的MATLAB实现 一维信号的实验与结果 门限参数a.测量数M与重构成功概率关系的实验与结果 SWOMP与StOMP性能比较 一.SWOMP的算法流程 分段 ...

  5. 浅谈压缩感知(二十一):压缩感知重构算法之正交匹配追踪(OMP)

    主要内容: OMP的算法流程 OMP的MATLAB实现 一维信号的实验与结果 测量数M与重构成功概率关系的实验与结果 稀疏度K与重构成功概率关系的实验与结果 一.OMP的算法流程 二.OMP的MATL ...

  6. 浅谈压缩感知(九):正交匹配追踪算法OMP

    主要内容: OMP算法介绍 OMP的MATLAB实现 OMP中的数学知识 一.OMP算法介绍 来源:http://blog.csdn.net/scucj/article/details/7467955 ...

  7. Bootstrap入门(二十五)JS插件2:过渡效果

    Bootstrap入门(二十五)JS插件2:过渡效果 对于简单的过渡效果,只需将 transition.js 和其它 JS 文件一起引入即可.如果你使用的是编译(或压缩)版的bootstrap.js  ...

  8. 二十五种网页加速方法和seo优化技巧

    一.使用良好的结构 可扩展 HTML (XHTML) 具有许多优势,但是其缺点也很明显.XHTML 可能使您的页面更加符合标准,但是它大量使用标记(强制性的 <start> 和 <e ...

  9. Bootstrap <基础二十五>警告(Alerts)

    警告(Alerts)以及 Bootstrap 所提供的用于警告的 class.警告(Alerts)向用户提供了一种定义消息样式的方式.它们为典型的用户操作提供了上下文信息反馈. 您可以为警告框添加一个 ...

随机推荐

  1. webform页面传值和删除修改

    一.webform跨页面传值1.内置对象地址栏数据拼接 QueryString 优点:简单好用:速度快:不消耗服务器内存. 缺点:只能传字符串:保密性差(调转页面后在地址栏显示):长度有限.响应请求对 ...

  2. 【微博SDK调用逻辑】微博SDK的调用逻辑,最好自己还是写一个例子,试一下!!!

    逻辑是这样的,谢谢给我讲东西的开发哥哥,嘻嘻~~~  1.点击微博登录,SDK会打开微博客户端,然后点击登陆(如果已经登录了会出现一个当前app跟微博交互的图片界面,然后提示“正在获取授权信息”,如果 ...

  3. GNUPLOT 画多组柱状图 以及 折线图 以及各种问题的解决方案

    在Windows下使用客户端,直接可以打开.plt文件的gnuplot格式的文件,open->xx.plt 在Linux下使用shell 运行gnuplot脚本, 结果一闪而过.解决办法是在 程 ...

  4. CentOS 7将网卡名称eno16777736改为eth0

    http://www.linuxidc.com/Linux/2015-09/123396.htm Linux系统版本:CentOS_7(64位) 一.前言: 今天将CentOS 6.5装回了CentO ...

  5. sourceTree忽略跟踪文件

    1.未跟踪文件,直接在.gitignore文件打上文件名字,如果要忽略整个文件夹,要在文字后面加上一个/ .如:gradle/ . 2.已跟踪文件,先删除那些文件,再提交到git上,即删除远程的文件, ...

  6. u3d shader forge 冰渐冻材质

    <ignore_js_op> 分享个自己研究的冰材质渐冻shader可以调节的参数很多,并且带模型顶点偏移,能更加真实模拟冰的凹凸厚度感.(参数过大容易出现模型破损,慎用)shader f ...

  7. IOS开发涉及有点概念&相关知识点

    前言,IOS是基于UNIX的,用C/C+/OC直通系统底层,不想android有个jvm. 首先还是系统架构的分层架构 1.核心操作系统层 Core OS,就是内存管理.文件系统.电源管理等 2.核心 ...

  8. go 的 time ticker 设置定时器

    上示例 package main import ( // "bytes" // "encoding/json" "fmt" // " ...

  9. mORMot使用基础

    mORMot 名称来自Marmot,对,土拨鼠,俗称旱獭,是一种生活在高寒山区的动物.多数都在白天活动,喜群居,善掘土,所挖地道深达数米,内有铺草的居室,非常舒适.通常洞穴都会有两个以上的入口,以策安 ...

  10. adobe pro破解说明

    安装说明(仔细阅读!)1.在安装之前手工修改host文件的方法:在hosts文件(默认位置C:\windows\system32\drivers\etc\hosts)中添加如下几行# Adobe Bl ...