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


相关推荐

  • django配置文件详解_django配置redis

    django配置文件详解_django配置redis前言Django的配置文件settings.py用于配置整个网站的环境和功能,核心配置必须有项目路径、密钥配置、域名访问权限、App列表、中间件、资源文件、模板配置、数据库的连接方式基本配置信息

    2022年7月29日
    5
  • 如何定义多个context:property-placeholder配置

    如何定义多个context:property-placeholder配置今天在配置多配置文件的时候偶然发现如果我使用<context:property-placeholderlocation=”classpath:jdbc.properties”/><context:property-placeholderlocation=”classpath:freemarker.properties”/>//这个进行多行编写配置文件的时候会出现后面那个文件出现读取不到的问题这样会导致后面那个配置文件失效原因:Spring只会加载第一个cont

    2022年7月13日
    11
  • 菜鸟教程-maven[通俗易懂]

    菜鸟教程-maven[通俗易懂]Maven基于项目对象模型(缩写:POM)概念 Maven是一个项目管理工具,可以对Java项目进行构建、依赖管理。 Maven是一个基于Java的工具,所以要做的第一件事情就是安装JDK。 Maven提倡使用一个共同的标准目录结构,Maven使用约定优于配置的原则,大家尽可能的遵守这样的目录结构。如下所示: 目录 目的 ${basedir} 存放pom.xml和所有的子目录 ${basedir}/src/main/java 项目的ja

    2022年9月8日
    0
  • AJAX

    AJAX

    2022年4月2日
    36
  • java监听设计模式(java观察者设计模式)

    java监听设计模式(java观察者设计模式)

    2021年8月2日
    61
  • 出现将截断字符串或二进制数据怎么办_数据库从字符串转换日期失败

    出现将截断字符串或二进制数据怎么办_数据库从字符串转换日期失败原因是因为在数据库的表中进行了输入字符长度的限制,比如数据库表中的字段长度为5个varchar,而在前台的输入中超出了这个长度就会报这个错。出现此错的原因一般时:在进行数据测试时没有考虑数据的长度,只顾着测试方便乱输一通,稍有不慎就会多出一两个字节(我就是这种情况,在数据库中有一个表示状态的字段,是一个长度的int,但是我输入了双数)解决办法当然简单:只需要更改数据库中的字段长度或者在前台测试输…

    2022年10月7日
    0

发表回复

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

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