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)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Sqoop问题解决:运行报错java.lang.RuntimeException: Could not load db driver class: com.mysql.jdbc.Driver

    Sqoop问题解决:运行报错java.lang.RuntimeException: Could not load db driver class: com.mysql.jdbc.DriverSqoop问题解决:运行报错报错信息:java.lang.RuntimeException:Couldnotloaddbdriverclass:com.mysql.jdbc.Driver原因分析:未将mysql关系型数据库驱动包放到sqoop/lib目录下解决方法:将mysql关系型数据库驱动包放到sqoop/lib目录下这里需要下载mysql关系型数据库驱动包放到本地/opt/software/下mysql依赖包下载链接:https://pan.baidu.com/s

    2022年7月25日
    12
  • 十大排序算法详解(一)冒泡排序、选择排序、插入排序、快速排序、希尔排序[通俗易懂]

    十大排序算法详解(一)冒泡排序、选择排序、插入排序、快速排序、希尔排序[通俗易懂]冒泡排序、选择排序、插入排序、快速排序、希尔排序

    2022年6月26日
    30
  • 加密原理详解:对称式加密 VS 非对称式加密[通俗易懂]

    加密原理详解:对称式加密 VS 非对称式加密[通俗易懂]一、前言在了解加密原理前,我们来看看这样一个故事。小红和小明是情侣,一天,小红给小明发短信说:“亲爱的,我银行卡上没有钱了,你给我转1万块吧。”有过上当受骗经历的人都知道这有可能是小偷偷了小红手提包,然后拿手机发的短信。不过我们小明学过加密原理,于是他回复说:“你直接拿我的银行卡刷吧,密码加上我们第一次约会的日期就是663156。”很明显,只有小明和小红知道他们第一次约会是什么时候,假设是2008年4月1号,那么小红就可以根据计算663156-200841=462315得到银行卡密码,就可以消费了。这

    2022年5月6日
    40
  • Android开机动画总结

    Android开机动画总结开机动画制作开机动画两个要点启动开机动画开机动画运行过程代码位置运行简介开机动画遇到的问题制作开机动画两个要点压缩时选择“存储”模式资源文件命名序号,需要和最大序号位数相同,位数不够,前面补零。如00、01、02、。。。、10、11。系统开机动画支持功能配置debug.sf.nobootanimation为0若要关闭开机动画功能,在device目录下的mk文件中配置,确保系统开…

    2022年5月15日
    44
  • leetcode – Missing Ranges

    leetcode – Missing Ranges

    2022年1月13日
    49
  • Git和Github使用说明

    1.安装官网地址:https://git-scm.com/downloads我这里使用的是gitversion2.19.1.windows.1,全程傻瓜式安装,点下一步即可,可以把命令模式和

    2021年12月30日
    48

发表回复

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

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