当前位置:   article > 正文

MATLAB环境下一维时间序列信号的同步压缩小波包变换

MATLAB环境下一维时间序列信号的同步压缩小波包变换

时频分析相较于目前的时域、频域信号处理方法在分析时变信号方面,其主要优势在于可以同时提供时域和频域等多域信号信息,并清晰的刻画了频率随时间的变化规律,已被广泛用于医学工程、地震、雷达、生物及机械等领域。

线性时频分析方法是将信号分解为时域和频域中基的加权和,例如短时傅里叶变换STFT和小波变换WT。短时傅里叶变换利用短窗口沿时间尺度移动以对信号进行切片,可以获得每个片段的局部傅里叶谱,揭示信号的变化规律。由于海森堡不确定原理,STFT方法在达到最优时间位置时其时频分辨率较低,反之亦然。因此,该方法缺乏适应性,它只适用于分析在短时间窗尺度上的平稳信号,而不适用于分析信号中的高瞬态冲击信号。小波变换是一种重要的信号处理工具,利用可变窗同时兼顾高低频信号的分辨率,适用于非平稳信号分析。但也存在不足之处,小波变换对低频信号进行迭代分解,而对高频的细节信号没有进一步的处理。对于高频分量,小波变换具有较好的时间局域特性,但无法满足最佳频率分辨率的要求;对于低频分量,当达到最优频率分辨率时,而时间局部特性呈现出较差的状态。此外,小波变换还存在与母小波选择标准、边界失真、能量泄漏相关的问题。

二次时频分布主要属于Cohen类双线性时频能量分布,其中最常用的是Wigner-Ville分布及其变体。二次时频分布不包含任何窗函数,因此不受不确定性的影响,但是其交叉项在处理多分量信号中产生较大的影响。尽管这种干扰可以通过平滑处理来减弱,但平滑后的分布会变得模糊,降低时频分辨率。二次时频分析方法的理论中尽管有许多优良的性质,但是由于不能直接重构信号,限制了在实际问题中的应用。

为了提高时频分析的质量,众多学者已经开发了一些时频重分配方法。时频重分配方法是通过修改原始谱能量分布来提高原始线性或二次时频变换的可读性的后处理技术。重新分配后,频谱能量将集中在瞬时频率附近,避免了人为干预。Daubechies和Oberlin分别基于CWT和STFT提出了同步压缩变换SST。

SST方法是通过将时频系数压缩至瞬时频率的轨迹中进行设计的,提高了时频的分辨率并重建了原始信号。但在强噪声的干扰下SST方法的时频分辨率较低,并且由于其对真实瞬时频率分布的估计偏差而导致时频能量不集中。

同步压缩小波包变换方法首先将信号进行小波包变换得到小波包变换系数,然后求取信号的瞬时频率,最后对小波包变换系数沿信号瞬时频率方向进行压缩,从而将各频率成分清晰呈现于时频图中,可以提高时频分辨率。

程序运行环境为MATLAB R2018A,执行一维时间序列信号的同步压缩小波包变换,并给出了模拟信号和实际信号的例子。算法可迁移至金融时间序列,地震信号,语音信号,声信号,生理信号等一维时间序列信号。

部分代码如下:

  1. % Inputs
  2. % x input signal, a vector of length N
  3. %
  4. % Optional Inputs
  5. % is_real Type of the transform
  6. % 0: complex-valued wave packets
  7. % 1: real-valued wave packets
  8. % [default set to 0]
  9. % is_unif whether x is sampled on a uniform grid
  10. % 0: No; 1: Yes
  11. % typeNUFFT 1: NUFFT by Air Force Lab
  12. % 2: USFFT by E. Candes
  13. % 3: NUFFT by L. Greengard and J.-Y. Lee
  14. % 4: Direct non-uniform Fourier Transform
  15. % xo non-uniform locations at which x is measured
  16. % NG number of subsampled points in time
  17. % [R_low R_high] The range of interested spectrum
  18. % rad a parameter to adjust the size of supports of the mother wave packet in
  19. % the frequency domain, rad <= 2.
  20. % is_cos Type of the window function
  21. % 0: C^infinity window function
  22. % 1: cosine window function
  23. % [default set to 0]
  24. % t_sc scaling parameter for radius
  25. % [default set to 1-1/4]
  26. % red redundancy parameter, red is a positive integer
  27. % [default set to 1]
  28. % epsl threshold for instantaneous frequency estimates
  29. % [default set to 1e-2]
  30. % h frequency band width per pixel in the synchrosqueezed
  31. % time-frequency representation
  32. % [default set to 1]
  33. % is_fac 0: do not increase the magnitude of high frequency wave
  34. % packet coefficients; 1: increase;
  35. % [default set to 1, better to visualize high frequency
  36. % instantaneous frequencies]
  37. % wedge_length_coarse
  38. % length of coarsest wedge
  39. % [default set to 4]
  40. %
  41. % Outputs
  42. % T_f 1D synchrosqueezed wave packet transform, a matrix with NG columns, each column represent frequency
  43. % information at a fixed time
  44. % coef 1D wave packet transform coefficients of x
  45. % kk instantaneous frequency estimates from each wave packet
  46. % coefficient

出图如下:

声明:本文内容由网友自发贡献,不代表【wpsshop博客】立场,版权归原作者所有,本站不承担相应法律责任。如您发现有侵权的内容,请联系我们。转载请注明出处:https://www.wpsshop.cn/w/AllinToyou/article/detail/90261
推荐阅读
相关标签
  

闽ICP备14008679号