自适应滤波器——LMS算法

15 篇文章 17 订阅

Matlab代码如下:

clear; close all; clc;

t = 0:199;
xs = 10*cos(0.5*t); %xs为理想的余弦信号
noise = randn(1,length(t)); %噪声信号
xn = xs+noise; %输入信号
dn = xs;
[w,en,yn] = LMS_Simple(xn,dn); %引用LMS算法实现滤波

t_new = 0:length(yn)-1;

figure;
subplot(511); plot(t,xs); 										  grid;title('理想信号');
subplot(512); plot(noise); 										  grid;title('随机噪声');
subplot(513); plot(t,xn,'r',t,dn,'blue'); 						  grid;title('输入信号和理想信号的对比');
subplot(514); plot(yn); 										  grid;title('输出信号');
subplot(515); plot(t,xn,'red',t_new,yn,'blue',t_new,en,'yellow'); grid;title('三种信号的比较');
legend('输入信号','输出信号','误差信号');

%LMS算法
function [w,en,yn] = LMS_Simple(xn,dn) %xn为输入信号(行向量), dn为理想信号(行向量)
	M = 30; %滤波器的阶数

	zeroize = zeros( (ceil(length(xn)/M) * M) - length(xn) , 1); % 补零
	xn = cat(1,xn',zeroize);%行向量转置为列向量,补零
	dn = cat(1,dn',zeroize);%行向量转置为列向量,补零

	itr = length(xn); % 使得迭代次数为输入信号xn的长度
	w = zeros(M,itr); % 滤波器的系数矩阵
	en = zeros(itr,1); % 误差信号
	yn = zeros(length(xn)); %滤波器的输出信号

	lambda = max(eig(xn*xn')); %xn的自相关矩阵的最大特征值
	mu = 0.95 * (2/lambda); %求步长,0.95系数可设置,保证小于2/lambda

	%迭代更新滤波器的参数
	for k = M:itr  %要保证输入延时后的信号有效,所以实际的迭代次数只有(itr-M)次,
	    x = xn(k:-1:k-M+1); %将输入信号延迟,使得滤波器的每个抽头都有输入
	    y = w(:,k-1)'*x;  %计算出滤波器的输出
	    en(k) = dn(k)-y;   %得出误差信号
	    w(:,k) = w(:,k-1) + mu*en(k)*x;%迭代更新滤波器的系数
	    yn(k) = w(:,k)'*x; %滤波器的最终输出
	end
end

这里的理想参考信号在实际应用中,常常不能事先确定,需要用其它方法来确定。

梯度∇为误差增加的方向,所以W(n+1)=W(n)+μ(-∇),而-∇为误差减小的方向。

  • 3
    点赞
  • 34
    收藏
    觉得还不错? 一键收藏
  • 3
    评论
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值