我想从FFT中提取两个余弦函数之间的相位差。余弦函数为: x1(n)=cos(2*pifi_n)和x2(N)=cos(2*pi_fi(N))。根据DFT特性,我们有:
DFT(x1(n))= X1(f);
DFT(x2(n))= exp( (-j*2*pi*m*fi)/N )X1(f)
因此,DFT(x1(n))和DFT(x2(n))之间的相位差等于(-2*pi_m_fi)/N。我的代码如下
clc
clear all
Fs = 250; % Sampling frequency
T = 1/Fs; % Sample time
iniPhase=pi/6;
fin=120;
t=0:(1/Fs):2;
xu = cos(2*pi*fin*(t)) ;
xd = cos(2*pi*fin*(t)+iniPhase) ;
NFFT=length(xu);
NFFT=256;
Xu = fftshift(xu);
FFTXu = 2*fft(Xu,NFFT);
SpecXu=2*abs(FFTXu(1:NFFT/2+1));
Xd = fftshift(xd) ;
FFTXd = 2*fft(Xd,NFFT);
SpecXd=2*abs(FFTXd(1:NFFT/2+1));
[tt ind]=max(SpecXd(1:NFFT/2+1));
Phased=(angle( FFTXd));
Phaseu=(angle( FFTXu));
theta=(Phased(ind))-(Phaseu(ind));
发布于 2015-04-19 01:51:58
从傅里叶变换的位移性质出发,给出了x1(n)和x2(n)的光谱。
DFT(x1(n))= X1(f);
DFT(x2(n))= exp( (-j*2*pi*m*fi)/N )X1(f);
那么,很明显,相位因子可以从
DFT(x2)/DFT(x1),
但不是
angle(DFT(x2) - DFT(x1)).
https://stackoverflow.com/questions/29716650
复制相似问题