lms算法matlab实现道客巴巴_自适应算法matlab代码

lms算法matlab实现道客巴巴_自适应算法matlab代码LMS算法MatLab实现LMS自适应滤波器是使滤波器的输出信号与期望响应之间的误差的均方值为最小,因此称为最小均方(LMS)自适应滤波器。其原理及推导见http://download.csdn.n

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE使用 1年只要46元 售后保障 童叟无欺

      LMS算法MatLab实现 

    LMS自适应滤波器是使滤波器的输出信号与期望响应之间的误差的均方值为最小,因此称为最小均方(LMS)自适应滤波器。其原理及推导见http://download.csdn.net/source/432206

lms算法matlab实现道客巴巴_自适应算法matlab代码
function [yn,W,en]
=
LMS(xn,dn,M,mu,itr)
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 LMS(Least Mean Squre)算法
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 输入参数:
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
     xn   输入的信号序列      (列向量)
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
     dn   所期望的响应序列    (列向量)
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
     M    滤波器的阶数        (标量)
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
     mu   收敛因子(步长)      (标量)     要求大于0,小于xn的相关矩阵最大特征值的倒数    
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
     itr  迭代次数            (标量)     默认为xn的长度,M
<
itr
<
length(xn)
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 输出参数:
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
     W    滤波器的权值矩阵     (矩阵)
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
          大小为M x itr,
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
     en   误差序列(itr x 
1
)    (列向量)  
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
     yn   实际输出序列             (列向量)
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 参数个数必须为4个或5个
lms算法matlab实现道客巴巴_自适应算法matlab代码

if
 nargin 
==
 
4
                 
%
 4个时递归迭代的次数为xn的长度 
lms算法matlab实现道客巴巴_自适应算法matlab代码    itr 

=
 length(xn);
lms算法matlab实现道客巴巴_自适应算法matlab代码elseif nargin 

==
 
5
             
%
 5个时满足M
<
itr
<
length(xn)
lms算法matlab实现道客巴巴_自适应算法matlab代码    

if
 itr
>
length(xn) 
|
 itr
<
M
lms算法matlab实现道客巴巴_自适应算法matlab代码        error(


迭代次数过大或过小!

);
lms算法matlab实现道客巴巴_自适应算法matlab代码    end
lms算法matlab实现道客巴巴_自适应算法matlab代码

else

lms算法matlab实现道客巴巴_自适应算法matlab代码    error(


请检查输入参数的个数!

);
lms算法matlab实现道客巴巴_自适应算法matlab代码end
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 初始化参数
lms算法matlab实现道客巴巴_自适应算法matlab代码en 

=
 zeros(itr,
1
);             
%
 误差序列,en(k)表示第k次迭代时预期输出与实际输入的误差
lms算法matlab实现道客巴巴_自适应算法matlab代码W  

=
 zeros(M,itr);             
%
 每一行代表一个加权参量,每一列代表

次迭代,初始为0
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 迭代计算
lms算法matlab实现道客巴巴_自适应算法matlab代码

for
 k 
=
 M:itr                  
%
 第k次迭代
lms算法matlab实现道客巴巴_自适应算法matlab代码    x 

=
 xn(k:

1
:k

M
+
1
);        
%
 滤波器M个抽头的输入
lms算法matlab实现道客巴巴_自适应算法matlab代码    y 

=
 W(:,k

1
).

 * x;        % 滤波器的输出

lms算法matlab实现道客巴巴_自适应算法matlab代码

    en(k) 
=
 dn(k) 

 y ;        
%
 第k次迭代的误差
lms算法matlab实现道客巴巴_自适应算法matlab代码    
lms算法matlab实现道客巴巴_自适应算法matlab代码    

%
 滤波器权值计算的迭代式
lms算法matlab实现道客巴巴_自适应算法matlab代码    W(:,k) 

=
 W(:,k

1

+
 
2
*
mu
*
en(k)
*
x;
lms算法matlab实现道客巴巴_自适应算法matlab代码end
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 求最优时滤波器的输出序列
lms算法matlab实现道客巴巴_自适应算法matlab代码yn 

=
 inf 
*
 ones(size(xn));
lms算法matlab实现道客巴巴_自适应算法matlab代码

for
 k 
=
 M:length(xn)
lms算法matlab实现道客巴巴_自适应算法matlab代码    x 

=
 xn(k:

1
:k

M
+
1
);
lms算法matlab实现道客巴巴_自适应算法matlab代码    yn(k) 

=
 W(:,end).

* x;

lms算法matlab实现道客巴巴_自适应算法matlab代码

end
lms算法matlab实现道客巴巴_自适应算法matlab代码    

        LMS函数的一个实例:

lms算法matlab实现道客巴巴_自适应算法matlab代码
%
function main()
lms算法matlab实现道客巴巴_自适应算法matlab代码close  all
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 周期信号的产生 
lms算法matlab实现道客巴巴_自适应算法matlab代码t

=
0
:
99
;
lms算法matlab实现道客巴巴_自适应算法matlab代码xs

=
10
*
sin(
0.5
*
t);
lms算法matlab实现道客巴巴_自适应算法matlab代码figure;
lms算法matlab实现道客巴巴_自适应算法matlab代码subplot(

2
,
1
,
1
);
lms算法matlab实现道客巴巴_自适应算法matlab代码plot(t,xs);grid;
lms算法matlab实现道客巴巴_自适应算法matlab代码ylabel(


幅值

);
lms算法matlab实现道客巴巴_自适应算法matlab代码title(


it{输入周期性信号}

);
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 噪声信号的产生
lms算法matlab实现道客巴巴_自适应算法matlab代码randn(


state

,sum(
100
*
clock));
lms算法matlab实现道客巴巴_自适应算法matlab代码xn

=
randn(
1
,
100
);
lms算法matlab实现道客巴巴_自适应算法matlab代码subplot(

2
,
1
,
2
);
lms算法matlab实现道客巴巴_自适应算法matlab代码plot(t,xn);grid;
lms算法matlab实现道客巴巴_自适应算法matlab代码ylabel(


幅值

);
lms算法matlab实现道客巴巴_自适应算法matlab代码xlabel(


时间

);
lms算法matlab实现道客巴巴_自适应算法matlab代码title(


it{随机噪声信号}

);
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 信号滤波
lms算法matlab实现道客巴巴_自适应算法matlab代码xn 

=
 xs
+
xn;
lms算法matlab实现道客巴巴_自适应算法matlab代码xn 

=
 xn.

 ;   % 输入信号序列

lms算法matlab实现道客巴巴_自适应算法matlab代码

dn 
=
 xs.

 ;   % 预期结果序列

lms算法matlab实现道客巴巴_自适应算法matlab代码

M  
=
 
20
   ;   
%
 滤波器的阶数
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码rho_max 

=
 max(eig(xn
*
xn.

));   % 输入信号相关矩阵的最大特征值

lms算法matlab实现道客巴巴_自适应算法matlab代码

mu 
=
 rand()
*
(
1
/
rho_max)   ;    
%
 收敛因子 
0
 
<
 mu 
<
 
1
/
rho
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码[yn,W,en] 

=
 LMS(xn,dn,M,mu);
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 绘制滤波器输入信号
lms算法matlab实现道客巴巴_自适应算法matlab代码figure;
lms算法matlab实现道客巴巴_自适应算法matlab代码subplot(

2
,
1
,
1
);
lms算法matlab实现道客巴巴_自适应算法matlab代码plot(t,xn);grid;
lms算法matlab实现道客巴巴_自适应算法matlab代码ylabel(


幅值

);
lms算法matlab实现道客巴巴_自适应算法matlab代码xlabel(


时间

);
lms算法matlab实现道客巴巴_自适应算法matlab代码title(


it{滤波器输入信号}

);
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 绘制自适应滤波器输出信号
lms算法matlab实现道客巴巴_自适应算法matlab代码subplot(

2
,
1
,
2
);
lms算法matlab实现道客巴巴_自适应算法matlab代码plot(t,yn);grid;
lms算法matlab实现道客巴巴_自适应算法matlab代码ylabel(


幅值

);
lms算法matlab实现道客巴巴_自适应算法matlab代码xlabel(


时间

);
lms算法matlab实现道客巴巴_自适应算法matlab代码title(


it{自适应滤波器输出信号}

);
lms算法matlab实现道客巴巴_自适应算法matlab代码
lms算法matlab实现道客巴巴_自适应算法matlab代码

%
 绘制自适应滤波器输出信号,预期输出信号和两者的误差
lms算法matlab实现道客巴巴_自适应算法matlab代码figure 
lms算法matlab实现道客巴巴_自适应算法matlab代码plot(t,yn,


b

,t,dn,

g

,t,dn

yn,

r

);grid;
lms算法matlab实现道客巴巴_自适应算法matlab代码legend(


自适应滤波器输出

,

预期输出

,

误差

);
lms算法matlab实现道客巴巴_自适应算法matlab代码ylabel(


幅值

);
lms算法matlab实现道客巴巴_自适应算法matlab代码xlabel(


时间

);
lms算法matlab实现道客巴巴_自适应算法matlab代码title(


it{自适应滤波器}

);

       运行后的结果如下:

lms算法matlab实现道客巴巴_自适应算法matlab代码

lms算法matlab实现道客巴巴_自适应算法matlab代码

lms算法matlab实现道客巴巴_自适应算法matlab代码

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/167475.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • 如何给自己心仪的人每天发送天气提醒消息

    如何给自己心仪的人每天发送天气提醒消息

    2021年9月18日
    63
  • 协同过滤推荐算法(一)原理与实现

    协同过滤推荐算法(一)原理与实现一、协同过滤算法原理协同过滤推荐算法是诞生最早,并且较为著名的推荐算法。主要的功能是预测和推荐。算法通过对用户历史行为数据的挖掘发现用户的偏好,基于不同的偏好对用户进行群组划分并推荐品味相似的商品。协同过滤推荐算法分为两类,分别是基于用户的协同过滤算法(user-basedcollaboratIvefiltering),和基于物品的协同过滤算法(item-basedcollaborati…

    2022年6月24日
    29
  • stm32cubemx软件库_STM32cube

    stm32cubemx软件库_STM32cube前言:本系列教程将HAL库与STM32CubeMX结合在一起讲解,使您可以更快速的学会各个模块的使用在我们的HAL库中,对硬件SPI函数做了很好的集成,使得之前SPI几百行代码,在HAL库中,只需要寥寥几行就可以完成那么这篇文章将带你去感受下它的优异之处,这些优异的函数,也正是HAL库的优点所在所用工具:1、芯片:STM32F103ZET62、STM32CubeMx软件3、IDE:…

    2022年8月31日
    4
  • 完全干净卸载mysql教程

    完全干净卸载mysql教程引言很多人因为第一次安装mysql导致安装错误,或者安装的数据库版本太高,比如mysql8.0版本,出现了很多问题,导致数据库无法使用,或者一些图形界面无法操作,想要卸载,重装稳定的mysql数据库,却是一件麻烦的事情,接下来教大家如何卸载有问题的mysq版本不限l,希望帮到大家,分为五步!个人微信公众号:源码客栈感兴趣可以关注下,更多视频资料教程!第一步卸载Mysql相关的应用程序打开控制面板-》找到程序和功能,看到所有和mysql相关的应用程序,右击卸载掉,有些人可能有workbench

    2022年6月16日
    34
  • mysql和oracle的区别有什么_oracle数据库收费

    mysql和oracle的区别有什么_oracle数据库收费MySQL和Oracle的区别一、宏观上:1、Oracle是大型的数据库而Mysql是中小型数据库;Mysql是开源的,Oracle是收费的,且价格昂贵。2、Oracle支持大并发,大访问量,是OLTP的最好的工具。3、安装占用的内存也是有差别,Mysql安装完成之后占用的内存远远小于Oracle所占用的内存,并且Oracle越用所占内存也会变多。二、微观上:1、对于事务的支持Mys…

    2022年10月2日
    2
  • 访问控制列表(ACL)基本的配置以及详细讲解「建议收藏」

    访问控制列表(ACL)基本的配置以及详细讲解「建议收藏」【网络环境】网络时代的高速发展,对网络的安全性也越来越高。西安凌云高科技有限公司因为网络建设的扩展,因此便引入了访问控制列表(ACL)来进行控制,作为网络管理员我们应该怎么来具体的实施来满足公司的需求

    2022年8月6日
    16

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号