| 
我想写一个通用的apFFT时移相位差法校正程序,也就是对任意的信号,可以采用apFFT作频谱校正,主要参考论坛里面贴出的程序,可是得到的结果非常不理想,请问高手是什么问题?
x
马上注册,结交更多好友,享用更多功能,让你轻松玩转社区。您需要 登录 才可以下载或查看,没有账号?我要加入 
  
 function [fff,AA,PH,N]=apFFT_Correct(s,Fs,CNum)
 % 采用时移相位差法校正全相位FFT谱,需要3*N-1个样本点
 % close all;
 % clear all;
 % clc;
 N=fix((length(s)+1)/3);
 s=s(1:3*N-1);
 
 win=hann(N)';
 win1=hann(N)';
 win2=conv(win,win1);
 win2=win2/sum(win2);
 w=pi*2;
 s1=s(1:2*N-1);
 s1=s1-ones(size(s1)).*mean(s1);
 y1=s1.*win2;
 y1a=y1(N:end)+[0,y1(1:N-1)];
 Out1=fft(y1a,N);
 s2=s(1+N:3*N-1);
 s2=s2-ones(size(s2)).*mean(s2);
 y2=s2.*win2;
 y2a=y2(N:end)+[0,y2(1:N-1)];
 Out2=fft(y2a,N);
 a1=abs(Out1);
 p1=rem(atan(imag(Out1)./real(Out1)),2*pi);
 a2=abs(Out2);
 p2=rem(atan(imag(Out2)./real(Out2)),2*pi);
 g=rem((p2-p1)/pi/2,1);
 h=2*pi*g.*(1-g.*g)./sin(pi*g);
 
 aa1=abs((h.^2).*a2)/2;
 L=fix(N/2)+1;
 f=(0:L)*Fs/N;
 figure;
 subplot(1,2,1)
 plot(f,a1(1:L+1));
 subplot(1,2,2)
 plot(f,p1(1:L+1));
 figure;
 subplot(1,2,1)
 plot(f,a2(1:L+1));
 subplot(1,2,2)
 plot(f,p2(1:L+1));
 for i=1:CNum
 [A,Ind(i)]=max(a1(1:L));
 f0=f(Ind(i));
 fff(i)=f0+g(Ind(i))*Fs/N;
 AA(i)=aa1(Ind(i));
 dp=rem((Ind(i)-1)*2*pi*fff(i)/Fs,2*pi);
 PH(i)=p1(Ind(i))*180/pi;
 StartP=Ind(i)-2;
 StopP=Ind(i)+2;
 if Ind(i)-2<1
 StartP=1;
 end
 if Ind(i)+2>L
 StopP=L;
 end
 Indx=StartP:StopP;
 a1(Indx)=zeros(1,length(Indx));
 end
 
 
 
 
 测试程序:
 clc
 Fs=4096;
 N=8192;
 t=-N+1:N*2-1;
 
 f=[4.2,126.4,131.7,258.5,382.8];
 A=ones(1,5);
 Ph=[40,20,30,70,60];
 CNum=length(f);
 s=zeros(1,length(t));
 for i=1:CNum
 myt=A(i)*cos(2*pi*t*f(i)/Fs+Ph(i)*pi/180);
 s=s+myt;
 end
 
 [ff,A,pho,Nn,tt]=apFFT_Correct(s,Fs,CNum)
 % 利用传统比值法对频谱校正的结果,注意:这里输出的相位值为起始点的相位值。
 % N=0点的相位值应等于(输出相位值+2*pi*N*f1/Fs/pi*180)
 for i=1:CNum
 Phh(i)=rem(2*pi*Nn*f(i)/Fs+Ph(i)*pi/180,2*pi)*180/pi;
 end
 [f;pho;ff;Phh]
 
 理想的频率:
 4.2000  126.4000  131.7000  258.5000  382.8000
 理想的相位
 70.0000   20.0000   30.0000   40.0000   60.0000
 校正的频率:
 3.9500 126.4000 131.4500  258.5000   382.8000
 校正的初相位
 184.0000  308.0000  174.0000   70.0000  276.0000
 
 我怀疑是程序中的变量“g”的计算有问题,但是却不知如何修改,请大牛们指点!!
 |