当前位置:首页 > 代码 > 正文

leach代码(LEACH协议)

admin 发布:2022-12-19 16:24 126


本篇文章给大家谈谈leach代码,以及LEACH协议对应的知识点,希望对各位有所帮助,不要忘了收藏本站喔。

本文目录一览:

为什么ns2中的leach协议需要安装

如果我们要往NS2中添加自己的模块,那么我们至少要实现两个类:

一, 首先要有一个类继承自TclObject类或者其子类,例如这个Mac802_16类的继承关系为:TclObject/NsObject/Mac /Mac802_16.这个类里面实现了C++类里面的变量与Otcl类的变量的绑定关系,以及我们的模块要实现的一系列算法等等,这个类负责的就是协议 的实现。

这个类,一般需要有构造函数中执行变量的绑定,使用bind()函数,将Otcl变量与C++的成员变量绑定起来。

声 明为protected的command()函数:为Otcl类提供方法,对Otcl中的类的方法进行翻译并执行;对于没有考虑到的或者不能解析的命令, 调用该C++类的父类的command方法。当在Otcl类中调用某个方法时,首先去tcl类中查找并执行该方法;若查找失败,则在该Otcl类对应的 C++类的command方法中查找,若查找仍然失败,则沿着该类的父类一直往上找,尝试调用它们的command方法;若所有父类的command方法 都不能解析,则报告该命令无法执行。

其他的成员变量和成员函数,这是用于实现自己的算法模块的内容。

二,其次我们要定义一个声明为static的类,继承自TclClass类,这个类实现了C++环境里面的类与Otcl环境里面的类的关联,简单点来说,这个类负责与Otcl环境进行关联。取最开头的那段代码;

static class Mac802_16Class : public TclClass

{

public:

Mac802_16Class() : TclClass("Mac/802_16") {}

TclObject* create(int, const char*const*)

{

return (new Mac802_16());

}

} class_mac802_16;

这 一段代码里面,包含了一个将Otcl的类名作为参数传给其父类的构造函数;一个create方法:创建一个C++类的对象实例并返回;该方法的返回类定义 为TclObject*。C++类的类型包含在create方法中,Otcl类的类型包含在TclClass类的构造函数中,因此可以实现C++类和 Otcl类的连接。

接下来,如果我们要实现的类完成以后,将头文件和源文件放置于~ns目录下自己新建的一个子目录,然 后打开~ns/Makefile文件,将“类名.o”添加到该Makefile的OBJ_CC宏定义中,对ns进行编译的时候就能够能够找到该模块的源文 件并将其编译到ns中;如果类中定义了一些变量,打开~ns/tcl/lib/ns-default.tcl文件,为该类对应的Otcl类设置一些初始 值。最后,对Makefile执行指令:make clean,make,对整个ns重新编译,我们的模块就可以添加到ns2中了。

leach-c协议matlab仿真代码急求,急

clear

fs=1000;%采样频率1000hz

N=500;%采样点数

t=(0:1:N-1)/fs;

f=10;%正弦信号频率10hz

x=sin(2*pi*f*t)+randn(size(t));%被随机信号干扰的正弦信号

b = fir1(31,0.5); %由b = fir1(31,0.5); 产生32阶滤波器系数

n = 0.1*randn(1,500); % 通过以上滤波系统所加入的噪声

d = filter(b,1,x)+n; % 通过滤波器后的期望信号

delta = 0.005; % 设置自适应滤波器其中一个步长因子为0.005

ha = adaptfilt.lms(32,delta);%求出系统的滤波器系数

[y,e] = filter(ha,x,d);

delta0=0.001; %另一个步长因子为0.001作对比

ha=adaptfilt.lms(32,delta0);

[y0,e0]=filter(ha,x,d);

m=1:500;

figure(1);

plot(m,x,'g');

figure(2);

plot(m,e,'r',m,e0);

legend('delta=0.001','delta=0.005')

% subplot(2,1,1)

% plot(m,e0)

%

以上是基本的LMS算法

% 滤波型LMS算法滤波

M = 20; % 运行次数

N = 1000; % 信号的长度

n = 0:N-1;

s = sin(2*pi*n/10); % 初始信号

u = s + 0.36*randn(1,N); % 叠加噪声后的信号

% 信号叠加噪声波形图

figure(1);

plot(n,u);

title('信号叠加噪声波形图');

xlabel('n');ylabel('u');

leach协议遇到的问题(急需解决)

这个有可能是你安装ns2的时候没有安装好,最后的办法就是将ns2卸载掉,注册表删除干净重新装ns2!然后再导入leach协议

leach代码的介绍就聊到这里吧,感谢你花时间阅读本站内容,更多关于LEACH协议、leach代码的信息别忘了在本站进行查找喔。

版权说明:如非注明,本站文章均为 AH站长 原创,转载请注明出处和附带本文链接;

本文地址:http://ahzz.com.cn/post/12810.html


取消回复欢迎 发表评论:

分享到

温馨提示

下载成功了么?或者链接失效了?

联系我们反馈

立即下载