压缩采样 矩阵重构 最小l1范数算法 matlab,【网安学术】超宽带信号的快速匹配追踪算法...

本文主要是介绍压缩采样 矩阵重构 最小l1范数算法 matlab,【网安学术】超宽带信号的快速匹配追踪算法...,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

原标题:【网安学术】超宽带信号的快速匹配追踪算法

2321c21bae86712d14a5354ebab09e97.png

摘要:压缩感知理论可应用到脉冲超宽带通信中,以降低采样速率。超宽带信号常常采用多径分集字典来稀疏表示,使得压缩采样匹配追踪(CoSaMP)、广义正交匹配追踪(GOMP)等经典的重构算法经常出现原子误选的情况,导致信号重构误差增大。因此,在GOMP的基础上,提出了一种新的重构算法。该算法在每次迭代中可选取多个原子以加快迭代收敛速度,并且通过限制被选中原子之间的序号差来避免原子误选。仿真实验表明,该算法不仅可以保证重构精度,而且具有更低的计算复杂度。

0 引言

传统采样定理要求采样频率是信号带宽的2倍以上,从而保证采样所得信号不失真。因此,在处理超宽带信号时,就会面临许多困难。压缩感知(Compressive Sensing,CS)[1]是一种新的稀疏信号采样和重建理论。该理论中,信号采样和压缩能同时完成,使得系统能够低于奈奎斯特采样频率采样,降低了系统的数据采样和储存成本,适合应用于超宽带通信系统。

Jose[2]是最早研究压缩感知应用于超宽带的学者之一。文献[2]中提到了两种超宽带稀疏信号的表示方式,一种用时域稀疏字典来表示,即单位矩阵,一种用多径分集字典来表示,能够更加稀疏地表示超宽带信号,因此被更多采用。但是,多径分集字典由超宽带脉冲波形位移产生,相邻原子之间的相关性较高,在使用匹配追踪算法时,会对原子的正确选择造成一定干扰。压缩采样匹配追踪(Compressive Sampling Matching Pursuit,CoSaMP)[3]算法、稀疏度自适应匹配追踪(Sparsity Adaptive Matching Pursuit,SAMP)[4]算法和正则化正交匹配追踪(Regularized Orthogonal Matching Pursuit,ROMP)[5]算法,每次迭代都会选取多个原子,使得选取相邻原子的可能性加大而产生误选。广义正交匹配追踪(Generalized Orthogonal Matching Pursuit,GOMP)[6]每次迭代选择L 个原子,L 被称为迭代步长。L 越大,GOMP发生原子误选的可能性越高。正交匹配追踪(Orthogonal Matching Pursuit,OMP)算法[7]由于每次迭代只选择一个原子,所以重构精度没有明显降低。但是,OMP的迭代次数过多,需要大量计算时间,所以L 在一定范围内时,GOMP更加适合应用于超宽带通信。

本文在GOMP算法的基础上,针对超宽带信号稀疏表示的特点做出改进,尽可能避免一定区间范围内同时选择多个原子。仿真实验表明,本文算法能够在运算时间接近GOMP的情况下,获得更高的重构精度。而相对于OMP而言,本文算法能在保证重构精度的同时,有效节省运算时间。

1 压缩感知理论

压缩感知理论指出:假设信号在nxn 维的稀疏字典下可以被稀疏表示,稀疏度k<n ,通过mxn 维的测量矩阵随机采样后得到m(k<m<n) 维的观测向量y 为:

其中称作传感矩阵,向量a 是信号x 在稀疏字典下的稀疏表示。由于m<n ,通过观测向量y 和测量矩阵无法直接求信号x ,所以将其转化成如下最优化问题:

其中,表示a 的l0 范数。式(2)中的优化问题是一个NP-Hard问题,通常在传感矩阵满足约束等距性质(Restricted Isometry Property,RIP)[8]的条件下,将式(2)中l0 范数优化问题转化为如式(3)所示的l1 范数优化问题:

通过相关重构算法,如OMP算法、基追踪(Basis Pursuit,BP)算法[9]和迭代硬阈值(Iterative Hard Thresholding,IHT)算法[10]等,就可以利用已知的观测向量y 和传感矩阵求得稀疏表示向量a ,再进而求出信号x 。

2 超宽带信号的快速匹配追踪算法

2.1 算法分析

首先介绍多径分集字典。脉冲超宽带信号经过多条不同时延和衰落的路径到达接收机,接收信号就由这些分量组合而成。稀疏字典的设计应该尽可能考虑和利用被稀疏表示信号的结构与特征。所以,文献[2]提出了一种稀疏表示基,即:

其中,p(t) 表示超宽带发射脉冲波形,表示理论上的采样时间间隔。若N 表示一次观测的总采样点数,则一次观测的总时长为。接收信号在此稀疏字典下可表示为:

其中,K 既代表信号多径的数目,也代表信号x 的稀疏度,{a(nl)} 为各个多径分量的幅值。超宽带信号占用的带宽极宽,具有高多径分辨率,可认为多径分量重叠的概率很小,且只有一小部分的多径分量幅值较大。因此,超宽带信号在该稀疏字典下可以被稀疏表示,且相对于时域稀疏字典,这种表示方法的结果更加稀疏。

目前,关于压缩感知应用于超宽带的研究中,大多数采用了多径分集字典作为稀疏矩阵。因为多径分集字典相比于时域稀疏字典,更能充分利用脉冲超宽带信号的稀疏性。使用时域稀疏字典时,无论采用何种重构算法,重构精度都比较低。因此,实际应用中采用时域稀疏字典是不可行的。

然而,在使用多径分集字典时,CoSaMP、SAMP、ROMP均出现了较大误差,原因是多径分集字典的相邻原子相关性很高,匹配追踪类算法采用内积的绝对值大小作为原子筛选的标准。正确原子相邻的位置的内积绝对值往往也较大,若一次迭代中选择很多原子,那么在匹配追踪的原子筛选过程中容易选择正确原子的相邻原子,从而产生误选。

文章第3节的图1可以看出,随着GOMP迭代步长的增大,重构精度明显下降。但是,当字典为单位矩阵时,迭代步长的增大并不会造成重构精度明显下降[6]。由此可以证明,多径分集字典对迭代步长较大的匹配追踪算法会有一定影响,问题的根本原因是正确原子的相邻原子与残差的内积值较大,致使其容易在同一次迭代中被选中。解决这一问题的办法是在匹配原子的过程中尽量避免同一次迭代选中相邻原子。基于这样的目的,本文提出了一种算法,使得同一次迭代所选原子保持一定距离。若只选择正确的原子,再经过正交化处理,那么下一次迭代中残差与其相邻原子的内积值会明显减小,从而可以有效降低误选的可能性。

此外,本文算法将GOMP的迭代停止条件改为或者满足t>K ,其中t 代表迭代次数的序号,rt 代表第t 次迭代后的残差,K 是允许的最大迭代次数,为常数。也就是说,当残差的相对变化率小于一定数值时,认为匹配追踪已经完成。该条件增强了算法的自适应性,在信号稀疏度不明确的条件下也能使用该算法。

2.2 算法步骤

GOMP的计算复杂度比OMP低,在步长L 不大时,其重构精度甚至略微优于OMP,所以显然更适合应用在超宽带的高速通信中。本文在GOMP的基础上,针对算法的不足作出改进,使得在算法复杂度没有明显提高的前提下提高重构精度,使算法更具有应用价值。

下面是本文提出算法的具体步骤:

输入:感知矩阵,观测向量y ,每次迭代选取的原子个数L ,最大迭代次数K ;

(1)初始化:残差r0=y ,已选原子索引集合,已选原子集合,迭代次数t=1 ;

(2)计算, 表示中各原子(列向量)的序号和u 中各元素的序号;

(3)按照向量u 各元素的值从大到小依次选择对应序号的原子。在此过程中,若某原子与任意已被选中原子的序号之差的绝对值小于S ,则该原子被舍弃,直到L 个原子被选中,再进行下一步;

(4)将这L 个原子对应的序号构成集合J ,代表第j 个原子;

(5)利用最小二乘法计算被选原子对应的系数;

(6)更新残差 ;

(7)t=t+1 ,如果或者满足t>K ,则进行下一步;否则返回第2步继续迭代;

(8)根据被选原子的系数at 和稀疏矩阵,可以得到原始信号;

输出:原始信号x 。

3 仿真与分析

本文通过仿真实验验证算法的性能。选取原始信号为IEEE802.15.3a CM1模型下1024x1 的脉冲超宽带多径信号,测量矩阵为Mx1024 的高斯随机矩阵,M 为观测点数,本文算法中 S的取值为3,取值为0.1。参照文献[2]中的评价标准:若重构误差小于原始信号能量的1%,即,则认为信号被成功重构。本文采用信号重构成功的概率作为重构精度的衡量指标。仿真环境为Intel i5-5200U CPU,8G RAM,Windows 10 64位操作系统,采用Matlab 2016b仿真。

图1和图2分别表示迭代步长L 从1变化到15过程中,GOMP算法和本文算法运行时间和重构精度的对比,其中稀疏字典都采用多径分集稀疏字典。由图1和图2可得以下结论:(1)本文算法与GOMP算法的计算复杂度相近,迭代次数是影响整体计算复杂度的最主要因素。相比OMP算法(即GOMP算法L=1 时),GOMP和本文算法在计算复杂度上有明显优势。(2)当随机采样点数为256时,本文算法在迭代步长L=4 时成功重构信号的概率最大,GOMP算法在L=3 时成功重构的概率最大。相比于OMP算法和GOMP算法,本文算法在重构精度和计算复杂度两个方面都有一定优势。(3)当迭代步长过大时,GOMP和本文算法的重构精度都会下降,但显然本文算法受到的影响更小,所以同等精度要求下,本文算法可以选择更大的迭代步长。

1901ebd318e68536908f5e10d7b081b1.png

1c7e123a6348c3d004f56dbb9d1e6b16.png

表1为观测点数M 不同的情况下,不同重构算法成功重构原始信号的概率。分别检测OMP算法、GOMP算法(L=3 、L=6 )以及本文算法(L=3 、L=6 )在稀疏字典为多径分集字典的情况下成功重构的概率。各种情况均重复10 000次,最后得到如表1所示的统计结果。从表1的数据中可以看出,当要求重构成功概率为1时,OMP和本文算法(L=3 )所需的观测点数M 最少,但本文算法运行时间约是OMP的1/3。GOMP需要的观测点数最多,不利于降低采样率,也增加了重构所需的时间,说明本文算法相比OMP和GOMP具有更佳的性能。在实际应用中,可以根据需求选择合适的步长,从而在满足采样率和重构精度要求的前提下节省算法的运行时间。

c5725eec4cc7323db139a5199b95bbcf.png

4 结语

本文介绍了用于稀疏表示超宽带信号的多径分集字典,分析了CoSaMP、GOMP等算法出现原子误选的原因,并针对OMP和GOMP两种算法在超宽带应用中的不足作出改进,限制被选原子之间的序号差,减少原子误选的发生,弥补多径分集字典的不足,从而选择更大的迭代步长。仿真实验证明,该算法在运行时间和重构精度两个方面都获得了一定改善。

参考文献:

[1] Donoho D L.Compressed Sensing[J].IEEE Transactions on Information Theory,2012,52(04):1289-1306.

[2] Paredes J L,Arce G R,Wang Z.Ultra-Wideband Compressed Sensing:Channel Estimation[J].IEEE Journal of Selected Topics in Signal Processing,2007,1(03):383-395.

[3] Needell D,Tropp J A.CoSaMP:Iterative Signal Recovery from Incomplete and Inaccurate Samples[J].Applied & Computational Harmonic Analysis,2008,26(03):301-321.

[4] Do T T,Lu G,Nguyen N,et al.Sparsity Adaptive Matching Pursuit Algorithm for Practical Compressed Sensing[C].Signals,Systems and Computers,2009:581-587.

[5] Needell D,Vershynin R.Uniform Uncertainty Principle and Signal Recovery via Regularized Orthogonal Matching Pursuit[J].Foundations of Computational Mathematics,2009,9(03):317-334.

[6] Jian W,Kwon S,Shim B.Generalized Orthogonal Matching Pursuit[J].IEEE Transactions on Signal Processing,2012,60(12):6202-6216.

[7] Pati Y C,Rezaiifar R,Krishnaprasad P S.Orthogonal Matching Pursuit:Recursive Function Approximation with Applications to Wavelet Decomposition[C].Signals,Systems and Computers,2002:40-44.

[8]Donoho D L,Huo X.Uncertainty Principles and Ideal Atomic Decomposition[J].IEEE Transactions on Information Theory,2002,47(07):2845-2862.

[9] Chen S S,Donoho D L,Saunders M A.Atomic Decomposition by Basis Pursuit[J].Siam Review,2001,43(01):129-159.

[10] Donoho D L,Tsaig Y,Drori I,et al.Sparse Solution of Underdetermined Systems of Linear Equations by Stagewise Orthogonal Matching Pursuit[J].IEEE Transactions on Information Theory,2012,58(02):1094-1121.

作者简介:

沈子钰,杭州电子科技大学 通信工程学院硕士,主要研究方向为压缩感知;

褚杭柯,杭州电子科技大学 通信工程学院硕士,主要研究方向为无线通信;

唐川雁,杭州电子科技大学 通信工程学院硕士,主要研究方向为信号处理。

(本文选自《通信技术》2018年第五期)

原创声明 >>>

本微信公众号刊载的原创文章,欢迎个人转发。未经授权,其他媒体、微信公众号和网站不得转载。

···························································返回搜狐,查看更多

责任编辑:

这篇关于压缩采样 矩阵重构 最小l1范数算法 matlab,【网安学术】超宽带信号的快速匹配追踪算法...的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/701417

相关文章

SpringBoot如何使用TraceId日志链路追踪

《SpringBoot如何使用TraceId日志链路追踪》文章介绍了如何使用TraceId进行日志链路追踪,通过在日志中添加TraceId关键字,可以将同一次业务调用链上的日志串起来,本文通过实例代码... 目录项目场景:实现步骤1、pom.XML 依赖2、整合logback,打印日志,logback-sp

Python中的随机森林算法与实战

《Python中的随机森林算法与实战》本文详细介绍了随机森林算法,包括其原理、实现步骤、分类和回归案例,并讨论了其优点和缺点,通过面向对象编程实现了一个简单的随机森林模型,并应用于鸢尾花分类和波士顿房... 目录1、随机森林算法概述2、随机森林的原理3、实现步骤4、分类案例:使用随机森林预测鸢尾花品种4.1

shell脚本快速检查192.168.1网段ip是否在用的方法

《shell脚本快速检查192.168.1网段ip是否在用的方法》该Shell脚本通过并发ping命令检查192.168.1网段中哪些IP地址正在使用,脚本定义了网络段、超时时间和并行扫描数量,并使用... 目录脚本:检查 192.168.1 网段 IP 是否在用脚本说明使用方法示例输出优化建议总结检查 1

无线路由器哪个品牌好用信号强? 口碑最好的三个路由器大比拼

《无线路由器哪个品牌好用信号强?口碑最好的三个路由器大比拼》不同品牌在信号覆盖、稳定性和易用性等方面各有特色,如何在众多选择中找到最适合自己的那款无线路由器呢?今天推荐三款路由器让你的网速起飞... 今天我们来聊聊那些让网速飞起来的路由器。在这个信息爆炸的时代,一个好路由器简直就是家庭网编程络的心脏。无论你

Rust中的Option枚举快速入门教程

《Rust中的Option枚举快速入门教程》Rust中的Option枚举用于表示可能不存在的值,提供了多种方法来处理这些值,避免了空指针异常,文章介绍了Option的定义、常见方法、使用场景以及注意事... 目录引言Option介绍Option的常见方法Option使用场景场景一:函数返回可能不存在的值场景

电脑显示hdmi无信号怎么办? 电脑显示器无信号的终极解决指南

《电脑显示hdmi无信号怎么办?电脑显示器无信号的终极解决指南》HDMI无信号的问题却让人头疼不已,遇到这种情况该怎么办?针对这种情况,我们可以采取一系列步骤来逐一排查并解决问题,以下是详细的方法... 无论你是试图为笔记本电脑设置多个显示器还是使用外部显示器,都可能会弹出“无HDMI信号”错误。此消息可能

Qt实现文件的压缩和解压缩操作

《Qt实现文件的压缩和解压缩操作》这篇文章主要为大家详细介绍了如何使用Qt库中的QZipReader和QZipWriter实现文件的压缩和解压缩功能,文中的示例代码简洁易懂,需要的可以参考一下... 目录一、实现方式二、具体步骤1、在.pro文件中添加模块gui-private2、通过QObject方式创建

不懂推荐算法也能设计推荐系统

本文以商业化应用推荐为例,告诉我们不懂推荐算法的产品,也能从产品侧出发, 设计出一款不错的推荐系统。 相信很多新手产品,看到算法二字,多是懵圈的。 什么排序算法、最短路径等都是相对传统的算法(注:传统是指科班出身的产品都会接触过)。但对于推荐算法,多数产品对着网上搜到的资源,都会无从下手。特别当某些推荐算法 和 “AI”扯上关系后,更是加大了理解的难度。 但,不了解推荐算法,就无法做推荐系

hdu1043(八数码问题,广搜 + hash(实现状态压缩) )

利用康拓展开将一个排列映射成一个自然数,然后就变成了普通的广搜题。 #include<iostream>#include<algorithm>#include<string>#include<stack>#include<queue>#include<map>#include<stdio.h>#include<stdlib.h>#include<ctype.h>#inclu

康拓展开(hash算法中会用到)

康拓展开是一个全排列到一个自然数的双射(也就是某个全排列与某个自然数一一对应) 公式: X=a[n]*(n-1)!+a[n-1]*(n-2)!+...+a[i]*(i-1)!+...+a[1]*0! 其中,a[i]为整数,并且0<=a[i]<i,1<=i<=n。(a[i]在不同应用中的含义不同); 典型应用: 计算当前排列在所有由小到大全排列中的顺序,也就是说求当前排列是第