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


相关推荐

  • 【转载】VS工具使用——代码生成函数关系图

    【转载】VS工具使用——代码生成函数关系图

    2021年11月18日
    91
  • C-V2X 频点-频段简介[通俗易懂]

    C-V2X 频点-频段简介[通俗易懂]1.缩略语1.Bband频段一个频率的范围或者频谱的宽度2.ULUplink上行链路3.DLDownlink下行链路4.EARFCNE-UTRAAbsoluteRadioFrequencyChannelNumber载波频点号5.FULF_{UL}FUL​FrequencyUplink载频上行频率6.NULN_{UL}NUL​EARFCNUplink载频上行频点号7.FDLF_{DL}FDL​FrequencyDownlink 载频下行频率8.

    2022年9月1日
    1
  • c++面试基本问题_面试结果一般要等几天

    c++面试基本问题_面试结果一般要等几天1.    面向对象的程序设计思想是什么?答:把数据结构和对数据结构进行操作的方法封装形成一个个的对象。 2.    什么是类?答:把一些具有共性的对象归类后形成一个集合,也就是所谓的类。 3.    对象都具有的二方面特征是什么?分别是什么含义?答:对象都具有的特征是:静态特征和动态特征。静态特征是指能描述对象的一些属性;

    2022年10月3日
    2
  • clion2022.01.4激活码【中文破解版】2022.03.07

    (clion2022.01.4激活码)本文适用于JetBrains家族所有ide,包括IntelliJidea,phpstorm,webstorm,pycharm,datagrip等。IntelliJ2021最新激活注册码,破解教程可免费永久激活,亲测有效,下面是详细链接哦~https://javaforall.net/100143.html…

    2022年4月2日
    236
  • IT学生学习指南

    IT学生学习指南本文主要为了计算机相关专业的学生而写。内容是从本博主的工作经验和教学经验当中总结出来的一些干货,涵盖了从大一到大四期间学生所遇到的常见问题,包括如何找到满意的工作、如何选择适合自己的工作岗位、如何制定自己的学习计划、如何分辨自身适合考研还是就业、女生的IT之路怎么走、如何锻炼自己的技术等等大学生最关心的问题。如果大家觉得文本值得一看,那就请推荐给身边那些还在迷茫中的孩子们吧!

    2022年6月4日
    22
  • 美股实时行情api接口(美股开户)

    所有美股历史交易行情数据,完整历史交易/任意时间段查询。1.产品功能支持所有历史美股交易查询;支持指定任意时间段查询;超高的查询效率,秒级返回;所有的交易数据为未复权的数据;全接口支持HTTPS(TLSv1.0/v1.1/v1.2/v1.3);全面兼容AppleATS;全国多节点CDN部署;接口极速响应,多台服务器构建API接口负载均衡。2.API文档接口地址:https://api.gugudata.com/stock/us返回格式:

    2022年4月11日
    136

发表回复

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

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