频谱细化-----CZT算法介绍及MATLAB实现

CZT变换(Chirp-Z变换)是一种利用FFT算法快速计算Z变换的特殊形式,尤其适用于信号的局部频谱分析。在Z平面上,CZT允许沿着任意路径取样,对于窄带信号,可以集中在感兴趣的频带上进行采样,从而提高频率分辨率。通过螺旋线采样,可以更好地识别信号的极点频率。在MATLAB中,可以使用内置的`czt`函数实现CZT变换,与直接的FFT相比,CZT在细化频率分析方面表现出更高的精确度。通过仿真实验,对比了FFT和CZT在75Hz到175Hz范围内的结果,显示CZT提供了更好的频率分辨率。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

CZT变换

采用FFT算法可以很快算出全部N点DFT值,即Z变换X(z)X\left( z \right)X(z)在Z平面单位圆上的全部等间隔取样值。实际中,也许不需要计算整个单位圆上Z变换的取样,如对于窄带信号,只需要对信号所在的一段频带进行分析,这时希望频谱的采样集中在这一频带内,以获得较高的分辨率,而频带以外的部分可不考虑,或者对其他围线上的Z变换取样感兴趣,例如语音信号处理中,需要知道Z变换的极点所在频率,如极点位置离单位圆较远,则其单位圆上的频谱就很平滑,这时很难从中识别出极点所在的频率,如果采样不是沿单位圆而是沿一条接近这些极点的弧线进行,则在极点所在频率上的频谱将出现明显的尖峰,由此可较准确地测定极点频率。螺旋线采样是一种适合于这种需要的变换,且可以采用FFT来快速计算,这种变换也称作Chirp-z变换。
已知x(n)x\left( n \right)x(n)0≤n≤N−10\le n\le N-10nN1,是有限长序列,它的Z变换为:
X(z)=∑n=0N−1x(n)z−nX\left( z \right)=\sum\limits_{n=0}^{N-1}{x\left( n \right){{z}^{-n}}}X(z)=n=0N1x(n)zn
为适应zzz可以沿ZZZ平面更一般的路径取值,故沿Z平面上的一段螺线作等分角的抽样,zzz的这些抽样点zk{{z}_{k}}zk为:
zk=AW−k,k=0,...,M−1{{z}_{k}}=A{{W}^{-k}},k=0,...,M-1zk=AWk,k=0,...,M1
M为所要分析的复频谱的点数,即采样点的总数,不一定等于NNNAAAWWW都是任意复数,可表示为:
{A=A0ejθ0W=W0e−jϕ0\left\{ \begin{matrix} A={{A}_{0}}{{e}^{j{{\theta }_{0}}}} \\ W={{W}_{0}}{{e}^{-j{{\phi }_{0}}}} \\ \end{matrix} \right.{A=A0ejθ0W=W0ejϕ0
zk=A0ejθ0W0−kejkϕ0=A0W0−kej(θ0+kϕ0){{z}_{k}}={{A}_{0}}{{e}^{j{{\theta }_{0}}}}W_{0}^{-k}{{e}^{jk{{\phi }_{0}}}}={{A}_{0}}W_{0}^{-k}{{e}^{j\left( {{\theta }_{0}}+k{{\phi }_{0}} \right)}}zk=A0ejθ0W0kejkϕ0=A0W0kej(θ0+kϕ0)
因此有
z0=A0ejθ0{{z}_{0}}={{A}_{0}}{{e}^{j{{\theta }_{0}}}}z0=A0ejθ0
z1=A0W0−1ej(θ0+ϕ0){{z}_{1}}={{A}_{0}}W_{0}^{-1}{{e}^{j\left( {{\theta }_{0}}+{{\phi }_{0}} \right)}}z1=A0W01ej(θ0+ϕ0)
zk=A0W0−kej(θ0+kϕ0){{z}_{k}}={{A}_{0}}W_{0}^{-k}{{e}^{j\left( {{\theta }_{0}}+k{{\phi }_{0}} \right)}}zk=A0W0kej(θ0+kϕ0)
zM−1=A0W0−(M−1)ej[θ0+(M−1)ϕ0]{{z}_{M-1}}={{A}_{0}}W_{0}^{-\left( M-1 \right)}{{e}^{j\left[ {{\theta }_{0}}+\left( M-1 \right){{\phi }_{0}} \right]}}zM1=A0W0(M1)ej[θ0+(M1)ϕ0]
(1)A0{{A}_{0}}A0表示起始采样点z0{{z}_{0}}z0的矢量半径长度,通常A0≤1{{A}_{0}}\le 1A01;否则z0{{z}_{0}}z0将处于单位圆∣z∣=1\left| z \right|=1z=1的外部。
(2)θ0{{\theta }_{0}}θ0表示起始采样点z0{{z}_{0}}z0的相角,它可以是正值或负值。
(3)ϕ0{{\phi }_{0}}ϕ0表示两相邻采样点之间的角度差。ϕ0{{\phi }_{0}}ϕ0为正时,表示zkz{}_{k}zk的路径沿逆时针旋转;ϕ0{{\phi }_{0}}ϕ0为负时,表示zk{{z}_{k}}zk的路径沿顺时针旋转。
(4)W0{{W}_{0}}W0的大小表示螺旋线的伸展率,W0<1{{W}_{0}}<1W0<1时,则随[k]的增加螺线外伸;W0>1{{W}_{0}}>1W0>1时,则随kkk的增加螺线内缩(反时针);W0=1{{W}_{0}}=1W0=1时,表示是半径为A0{{A}_{0}}A0的一段圆弧。若又有A0=1{{A}_{0}}=1A0=1,则这段圆弧则是单位圆的一部分。
M=NM=NM=N,A=A0ejθ0=1A={{A}_{0}}{{e}^{j{{\theta }_{0}}}}=1A=A0ejθ0=1时,满足:W=W0⋅e−jϕ0=−j2πN(W0=1,ϕ0=2π/N)W={{W}_{0}}\centerdot {{e}^{-j{{\phi }_{0}}}}=-j\frac{2\pi }{N}\left( {{W}_{0}}=1,{{\phi }_{0}}=2\pi /N \right)W=W0ejϕ0=jN2π(W0=1,ϕ0=2π/N)这一特殊情况时,各zk{{z}_{k}}zk就均匀等间隔地分布在单位圆上,这就是求序列的DFT。
X(zk)=∑n=0N−1x(n)zk−n=∑n=0N−1x(n)A−nWnk0≤k≤M−1\begin{aligned} & X\left( {{z}_{k}} \right)=\sum\limits_{n=0}^{N-1}{x\left( n \right)z_{k}^{-n}} \\ & \begin{matrix} {} & \begin{matrix} {} & =\sum\limits_{n=0}^{N-1}{x\left( n \right)} \\ \end{matrix} \\ \end{matrix}{{A}^{-n}}{{W}^{nk}}\begin{matrix} {} & 0\le k\le M-1 \\ \end{matrix} \\ \end{aligned}X(zk)=n=0N1x(n)zkn=n=0N1x(n)AnWnk0kM1
nknknk用表达式来替换:nk=12[n2+k2−(k−n)2],n=0,1,...,N−1,k=0,1,...,M−1nk=\frac{1}{2}\left[ {{n}^{2}}+{{k}^{2}}-{{\left( k-n \right)}^{2}} \right],n=0,1,...,N-1,k=0,1,...,M-1nk=21[n2+k2(kn)2],n=0,1,...,N1,k=0,1,...,M1
可得:
X(zk)=∑n=0N−1x(n)A−nWn22W−(k−n)22Wk22=Wk22∑n=0N−1[x(n)A−nWn22]W−(k−n)22X\left( {{z}_{k}} \right)=\sum\limits_{n=0}^{N-1}{x\left( n \right)}{{A}^{-n}}{{W}^{\frac{{{n}^{2}}}{2}}}{{W}^{-\frac{{{\left( k-n \right)}^{2}}}{2}}}{{W}^{\frac{{{k}^{2}}}{2}}}={{W}^{\frac{{{k}^{2}}}{2}}}\sum\limits_{n=0}^{N-1}{\left[ x\left( n \right){{A}^{-n}}{{W}^{\frac{{{n}^{2}}}{2}}} \right]}{{W}^{-\frac{{{\left( k-n \right)}^{2}}}{2}}}X(zk)=n=0N1x(n)AnW2n2W2(kn)2W2k2=W2k2n=0N1[x(n)AnW2n2]W2(kn)2
定义:
g(n)=x(n)A−nWn22,h(n)=W−n22,0≤g(n)≤N−1,−(N−1)≤h(n)≤M−1g\left( n \right)=x\left( n \right){{A}^{-n}}{{W}^{\frac{{{n}^{2}}}{2}}},h\left( n \right)={{W}^{-\frac{{{n}^{2}}}{2}}},0\le g\left( n \right)\le N-1,-\left( N-1 \right)\le h\left( n \right)\le M-1g(n)=x(n)AnW2n2,h(n)=W2n2,0g(n)N1,(N1)h(n)M1
则:
g(k)∗h(k)=∑n=0N−1g(n)h(k−n)=∑n=0N−1[x(n)A−nWn22]W−(k−n)22g\left( k \right)*h\left( k \right)=\sum\limits_{n=0}^{N-1}{g\left( n \right)}h\left( k-n \right)=\sum\limits_{n=0}^{N-1}{\left[ x\left( n \right){{A}^{-n}}{{W}^{\frac{{{n}^{2}}}{2}}} \right]}{{W}^{-\frac{{{\left( k-n \right)}^{2}}}{2}}}g(k)h(k)=n=0N1g(n)h(kn)=n=0N1[x(n)AnW2n2]W2(kn)2
X(zk)=Wk2w⋅[g(k)∗h(k)]X\left( {{z}_{k}} \right)={{W}^{\frac{{{k}^{2}}}{w}}}\centerdot \left[ g\left( k \right)*h\left( k \right) \right]X(zk)=Wwk2[g(k)h(k)]
先进行一次加权A−nWn2/2{{A}^{-n}}{{W}^{{{n}^{2}}/2}}AnWn2/2处理,然后通过一个单位脉冲响应为h(n)=W−n2/2h\left( n \right)={{W}^{-{{n}^{2}}/2}}h(n)=Wn2/2的线性系统即求g(n)g\left( n \right)g(n)h(n)h\left( n \right)h(n)的线性卷积;最后,对该系统的前M点输出再做一次加权,这样就得到了全部MMM点螺线采样值X(zn)(n=0,1,...,M−1)X\left( {{z}_{n}} \right)\left( n=0,1,...,M-1 \right)X(zn)(n=0,1,...,M1)
由于系统的单位脉冲响应h(n)=W−n2/2h\left( n \right)={{W}^{-{{n}^{2}}/2}}h(n)=Wn2/2可以想象为频率随时间[n]呈线性增长的复指数序列。在雷达系统中,这种信号称为线性调频信号,因此这里的变换称为线性调频Z变换。

具体过程

(1) 选择一个最小的整数LLL,使其满足L≥N+M−1L\ge N+M-1LN+M1,同时满足L=2mL={{2}^{m}}L=2m,以便采用基-2FFT算法。
(2) 将g(n)=x(n)A−nWn2/2g\left( n \right)=x\left( n \right){{A}^{-n}}{{W}^{{{n}^{2}}/2}}g(n)=x(n)AnWn2/2补上零值点,变为LLL点序列,因而有
g(n)={A−nWn22x(n)0≤n≤N−100≤n≤L−1g\left( n \right)=\left\{ \begin{matrix} {{A}^{-n}}{{W}^{\frac{{{n}^{2}}}{2}}}x\left( n \right) & 0\le n\le N-1 \\ 0 & 0\le n\le L-1 \\ \end{matrix} \right.g(n)={AnW2n2x(n)00nN10nL1
(3) 并利用FFT法求此序列的LLL点DFT:
G(r)=∑n=0N−1g(n)e−j2πLrn0≤r≤L−1\begin{matrix} G\left( r \right)=\sum\limits_{n=0}^{N-1}{g\left( n \right)}{{e}^{-j\frac{2\pi }{L}rn}} & 0\le r\le L-1 \\ \end{matrix} G(r)=n=0N1g(n)ejL2πrn0rL1
(4) 形成LLL点序列h(n)h\left( n \right)h(n),在n=0n=0n=0M−1M-1M1一段W−n22{{W}^{-\frac{{{n}^{2}}}{2}}}W2n2n=Mn=Mn=ML−NL-NLN段取h(n)h\left( n \right)h(n)为任意值(一般为零),在L=N+M−1L=N+M-1L=N+M1L−1L-1L1段取h(n)h\left( n \right)h(n)W−n22{{W}^{-\frac{{{n}^{2}}}{2}}}W2n2的周期延拓序列W−(L−n)22{{W}^{-\frac{{{\left( L-n \right)}^{2}}}{2}}}W2(Ln)2,即有
h(n)={W−n220≤n≤M−10W−(L−n)22M≤n≤L−NL−N+1≤n≤L−1h\left( n \right)=\left\{ \begin{matrix} {{W}^{-\frac{{{n}^{2}}}{2}}} & 0\le n\le M-1 \\ \begin{matrix} 0 \\ {{W}^{-\frac{{{\left( L-n \right)}^{2}}}{2}}} \\ \end{matrix} & \begin{matrix} M\le n\le L-N \\ L-N+1\le n\le L-1 \\ \end{matrix} \\ \end{matrix} \right. h(n)=W2n20W2(Ln)20nM1MnLNLN+1nL1
h(n)h\left( n \right)h(n)实际上是序列W−m2/2{{W}^{-{{m}^{2}}/2}}Wm2/2LLL为周期的周期延拓序列的主值序列
用FFT法求h(n)h\left( n \right)h(n)LLL点DFT:
H(r)=∑n=0L−1h(n)e−j2πLrn0≤r≤L−1\begin{matrix} H\left( r \right)=\sum\limits_{n=0}^{L-1}{h\left( n \right)}{{e}^{-j\frac{2\pi }{L}rn}} & 0\le r\le L-1 \\ \end{matrix} H(r)=n=0L1h(n)ejL2πrn0rL1
(5) 将H(r)H\left( r \right)H(r)G(r)G\left( r \right)G(r)相乘,得Q(r)=H(r)G(r)Q\left( r \right)=H\left( r \right)G\left( r \right)Q(r)=H(r)G(r)Q(r)Q\left( r \right)Q(r)LLL点频域离散序列
(6) 用FFT法求Q(r)Q\left( r \right)Q(r)LLL点IDFT,得h(n)h\left( n \right)h(n)g(n)g\left( n \right)g(n)的圆周卷积:
h(n)g(n)=q(n)=1L∑r=0L−1H(r)G(r)ej2πLrnh\left( n \right)g\left( n \right)=q\left( n \right)=\frac{1}{L}\sum\limits_{r=0}^{L-1}{H\left( r \right)}G\left( r \right){{e}^{j\frac{2\pi }{L}rn}}h(n)g(n)=q(n)=L1r=0L1H(r)G(r)ejL2πrn
式中,前MMM个值等于h(n)h\left( n \right)h(n)g(n)g\left( n \right)g(n)的线性卷积结果[h(n)∗g(n)]\left[ h\left( n \right)*g\left( n \right) \right][h(n)g(n)]n≥Mn\ge MnM的值没有意义,不需要求。
(7) 最后求X(zk)X\left( {{z}_{k}} \right)X(zk)
X(zk)=Wk22q(k)0≤k≤M−1\begin{matrix} X\left( {{z}_{k}} \right)={{W}^{\frac{{{k}^{2}}}{2}}}q\left( k \right) & 0\le k\le M-1 \\ \end{matrix} X(zk)=W2k2q(k)0kM1

关于该算法的实现,MATLAB有自带的CZT函数,具体用法为

y = czt(x,m,w,a),其中x为输入信号,m为变换的长度,默认值为信号长度,w为螺旋轮廓点之间的比值,a为螺旋轮廓起点

该函数返回由x 沿由 w 和 a 定义的 z 平面上的螺旋轮廓的长度,其中z = a*w.^-(0:m-1),使用默认值 m、w 和 a,czt 返回 x 在单位圆周围 m 个等距点处的 Z 变换,结果等效于由 fft(x) 给出的 x 的离散傅立叶变换 (DFT) .

下面给出一个简单的仿真实验,对比直接FFT与CZT之间的效果,细化频率75Hz~175Hz。
在这里插入图片描述
从图中可以看出,FFT的频率之间是由明显的间隔,在75Hz~175Hz之间,CZT的频率更加细化
在这里插入图片描述

在这里插入图片描述

显示100Hz~115Hz之间的结果可以看出,经过CZT之后有更高的频率分辨率,这也与上述的分析一致。
代码如下:

clear;
close all;
clc;
fs = 1000;    %采样频率
d = designfilt('lowpassfir','FilterOrder',30,'CutoffFrequency',125, ...
    'DesignMethod','window','Window',@rectwin,'SampleRate',fs);
h = tf(d);   %系统传递函数
m = 1024;    %变换点数
y = fft(h,m);  % 直接FFT结果
f1 = 75;   %细化起始频率
f2 = 175;  %细化结束频率
w = exp(-1j*2*pi*(f2-f1)/(m*fs));   %螺旋轮廓点之间的比值
a = exp(1j*2*pi*f1/fs);             %螺旋轮廓起点
z = czt(h,m,w,a);                   %CZT变换
fn = (0:m-1)'/m;
fy = fs*fn;                         %频率
fz = (f2-f1)*fn + f1;
figure(1);
plot(fy,abs(y),'r-*',fz,abs(z),'b')
xlim([50 200])
legend('FFT','CZT')
xlabel('Frequency (Hz)')
grid on;
figure(2);
plot(fy,abs(y),'r-*',fz,abs(z),'b')
xlim([100 115])
legend('FFT','CZT')
xlabel('Frequency (Hz)')
grid on;
figure(3);
plot(fy,abs(y),'r-*',fz,abs(z),'b-p')
xlim([100 115])
legend('FFT','CZT')
xlabel('Frequency (Hz)')
grid on;

参考文献
[1]王旭刚. 基于FMCW体制K波段测距雷达的研究与实现[D].南京航空航天大学,2012.
[2]Matlab CZT函数介绍

评论 7
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值