目录
本文提出了一种基于FFT和最小二乘的两步法正弦信号参数估计算法。首先通过FFT频谱峰值法对信号频率进行粗估计,然后构建最小二乘拟合矩阵精确求解频率、幅度和相位参数。算法包含五个关键步骤:频率粗估计、构建拟合矩阵、最小二乘求解、幅度估计和相位估计。MATLAB仿真测试表明,该方法能有效估计单频正弦信号的参数,并分析了不同虚警概率下的检测性能。完整代码工程提供了详细的中文注释和操作指导,为信号处理领域的参数估计问题提供了一种有效解决方案。
1.前言
算法核心是对单频正弦信号y(t)=Acos(2πfct+ϕ)进行参数估计(频率fc、幅度A、相位ϕ),采用"FFT粗估频率+最小二乘精估幅度/相位/频率" 的两步策略:先通过FFT频谱峰值定位信号主频,再基于该频率构建最小二乘拟合矩阵,求解信号的幅度,相位,频率参数。
2.算法测试效果图预览






3.算法运行软件版本
matlab2022b
4.部分核心程序
(完整版代码包含中文注释和操作步骤视频)
%对比不同检测概率的仿真结果
Pfa=[10^-1,10^-2,10^-3];
for i = 1:length(Pfa)
for j=1:length(ENR)
j
for k = 1:MTKL
y1 = awgn(y0,ENR(j)-4*log2(1/Pfa(i)));
[Aest_] = func_sinchecker0(y1,fs,fc0,Fai);
if mean(abs(Aest_-A)./A)>=1%检测失败
Aest2(i,j,k)= 0;
else
Aest2(i,j,k)= 1-mean(abs(Aest_-A)./A);
end
end
end
end
for p=1:length(Pfa)
for q=1:length(ENR)
Pd(p,q)=Q(Qinv((5*Pfa(p)))-sqrt(10^(ENR(q)/20)));%这个地方,和理论分析有点不一样,主要理论分析和实际还是有点差异的
end
end
01_226m
5.算法理论概述
采用"FFT粗估频率+最小二乘精估幅度/相位/频率"的两步策略:先通过FFT频谱峰值定位信号主频,再基于该频率构建最小二乘拟合矩阵,求解信号的参数。
步骤1:频率粗估计(FFT频谱峰值法)
用FFT将时域信号转换到频域,通过寻找频谱峰值对应的频率,得到信号频率的初始估计值。
具体实现过程如下:

步骤2:构建最小二乘拟合矩阵H
将正弦信号拆解为余弦、正弦分量的线性组合,构建拟合矩阵用于后续最小二乘求解。
具体实现过程如下:

步骤3:最小二乘求解系数
通过最小二乘法求解线性方程组y=H⋅θ(θ=[a1,a2,DC]^T),得到余弦/正弦项的系数a1、a2。
具体实现过程如下:

步骤4:幅度估计
利用三角函数合成公式,将余弦、正弦项系数转换为信号幅度,并基于"基准幅值1"修正偏差。
具体实现过程如下:

步骤5:相位估计
由余弦、正弦项系数的比值推导相位,通过整数化处理减小误差,再还原为实际相位值。
具体实现过程如下:

6.算法完整程序工程
OOOOO
OOO
O
关注GZH后输入自动回复码: 0027
或输入自动回复码:FFTLS