http://blog.csdn.net/codingkid/article/details/7215216

1.复制leach_test为leach-c_test,修改里面的文件夹和输出文件名。并且手动建立相应的文件夹。

很多教程说只修改文件名,没提到修改文件夹,如果同时运行两个协议会覆盖一部分实验结果的,而且是并行的就更难分解出是哪个协议的实验数据了。所以还是分开较好。

2.添加到test文件最后,后台运行的,需要等待。

3.写脚本分析实验数据。

  1. #计算不同时间剩余节点的数量
  2. BEGIN {
  3. countcyl=0;
  4. totalleft=0;
  5. lasttime=0;
  6. time[0]=0;
  7. node=0;
  8. total[0]=100;
  9. }
  10. {
  11. simtime              = $1;
  12. nodeid               = $2;
  13. statenode            = $3;
  14. if (simtime>lasttime ) {
  15. countcyl++;
  16. lasttime=simtime;
  17. time[countcyl]=simtime;
  18. totalleft=0;
  19. }
  20. if (statenode==1)
  21. totalleft++;
  22. total[countcyl]=totalleft;
  23. }
  24. END {
  25. for(i=0;i<=countcyl;i++)
  26. printf( "%f %d\n",time[i],total[i]);
  27. }
  1. BEGIN {
  2. countcyl=0;
  3. packetsum=0;                       #当前时间发包且接收的总数
  4. lasttime=0;
  5. time[0]=0;
  6. sum[0]=0;
  7. }
  8. {
  9. simtime              = $1;
  10. nodeid               = $2;
  11. packet               = $3;             #读取当前时间,当前节点的发包且被成功接收的数目
  12. if (simtime>lasttime ) {                                #具体算法
  13. packtsum=0;
  14. countcyl++;
  15. lasttime=simtime;
  16. time[countcyl]=simtime;
  17. }
  18. if (simtime==lasttime ) {
  19. packetsum=packetsum+packet;
  20. sum[countcyl]=packetsum;
  21. }
  22. }
  23. END {                                                        #对应时段,打印发包总量。
  24. for(i=0;i<=countcyl;i++)
  25. printf ( "%f %f\n",time[i],sum[i]);
  26. }
  1. BEGIN {
  2. countcyl=0;                           #计数器,用来记录当前的轮数 或者当前的时段数
  3. energysum=0;                      #用来暂时储存当前时段的节点消耗能量总和
  4. lasttime=0;                           #记录当前最后的时间
  5. time[0]=0;                             #存储各(轮)分段的时间
  6. sum[0]=0;                             #存储各分段时间对应的消耗的能量
  7. }
  8. {
  9. simtime              = $1;                      #文件中第一字段的值,当前时间
  10. nodeid               = $2;                      #。。。第二字段的值,节点ID
  11. nodeenergy            = $3;               #。。。第三字段的值,当前节点使用的能量
  12. if (simtime>lasttime ) {     #这里就是一个简单的方法来提取每个时间段,节点总共消耗了多少能量
  13. energysum=0;
  14. countcyl++;
  15. lasttime=simtime;
  16. time[countcyl]=simtime;
  17. }
  18. if (simtime==lasttime ) {
  19. if (nodeenergy<2.0) {
  20. energysum=energysum+nodeenergy;
  21. sum[countcyl]=energysum;
  22. }
  23. else if (nodeenergy>=2.0) {         #节点初始的总能量为2
  24. energysum=energysum+2.0;
  25. sum[countcyl]=energysum;
  26. }
  27. }
  28. }
  29. END {                                          #对应时间段,得出能量消耗量并打印
  30. for(i=0;i<=countcyl;i++)
  31. printf ( "%f %f\n",time[i],sum[i]);
  32. }

4.gnuplot来画图

  1. set multiplot
  2. set origin 0.0,0.5
  3. set size 0.5,0.5
  4. plot 'leach.alive.rst' with linespoint,'leach-c.alive.rst' with linespoint
  5. set origin 0.5,0.5
  6. set size 0.5,0.5
  7. plot 'leach.data.rst' with linespoint,'leach-c.data.rst' with linespoint
  8. set origin 0.33,0.0
  9. set size 0.5,0.5
  10. plot 'leach.energy.rst' with linespoint,'leach-c.energy.rst' with linespoint

得到如下图:

明显实验结果说明leach-c死亡节点比较早,虽然bs收到数据量大,但是能量消耗是leach协议更关心的问题。

修改bs坐标为(0,0),再次计算得到如下结果:

从各方面来说c都比leach更优,有人说若bs在节点区域内部,则leach更优,若在外部则leach-c更优!

想知道为什么还需要看懂这两个协议喽。

接下来代码和理论分析。

 
0

leach和leach-c协议仿真的更多相关文章

  1. 基于eNSP的NAT/NAPT协议仿真实践

    一. 基本原理 eNSP(Enterprise Network Simulation Platform)是一款由华为提供的.可扩展的.图形化 操作的网络仿真工具平台,主要对企业网络路由器.交换机进行软 ...

  2. ICMP 协议仿真及ping命令用途

    1.实验目的 加深对 IPv4 协议首部各定义域的理解,掌握路由表的结构和基本配置命令,熟悉 ICMP 的调试操作. 2.实验原理 IPv4 协议定义,网络层协议的相关 RFC 定义和描述. 3.实验 ...

  3. 工业以太网EtherNet/IP协议安全分析整理

    1.     EtherNet/IP : 设备可以用户数据报协议(UDP)的隐式报文传送基于IO的资料 ,用户传输控制协议(TCP)显示报文上传和下参数,设定值,程式 ,用户主站的轮询 从站周期性的更 ...

  4. ns2.34 移植MFLOOD协议时出现的问题

    安全按照<NS网络模拟核协议仿真>第11章的步骤进行修改,但是make的时候出现了一下错误: make[1]: 正在进入目录 `/home/wang/ns/ns-allinone-2.34 ...

  5. MLD协议测试——网络测试仪实操

    一.简介 1. MLD简介 MLD · Multicast Listener Discovery Protocol · 组播侦听者发现协议 功能 · 在终端主机和与其直接相邻的组播路由器之间建立/维护 ...

  6. PPPoE协议测试——网络测试仪实操

    前言: 与传统的接入方式相比,PPPoE具有较高的性能价格比,它在包括小区组网建设等一系列应用中被广泛采用,目前流行的宽带接入方式 ADSL 就使用了PPPoE协议. 随着低成本的宽带技术变得日益流行 ...

  7. BGP协议测试—信而泰网络测试仪实操

    关键词  BGP; 协议仿真; 测试原理. 前言:当前信息化时代之下,数据传输已经成为了日常工作和生活必不可少的重要组成部分,网络服务的易得性和可靠性也因此得到广泛关注.这其中负责网络正常工作的诸多协 ...

  8. leach协议matlab仿真代码

    http://www.ilovematlab.cn/thread-177006-1-1.html LEACH協議clear;%清除內存變量 xm=100;%x軸範圍ym=100;%y軸範圍 sink. ...

  9. 前端MVVM框架avalon揭秘 - HTML编译器

    MVVM试图更加清晰的讲用户界面(UI)开发从应用程序的业务逻辑与行为中心分离,因为,很多这样的模式的实现都需要利用声明式数据绑定来实现讲View(视图)工作从其他层分离 所以出现了一大堆自定义的声明 ...

随机推荐

  1. .net程序集强命名(签名)

    要想得到强签名的dll有两种情况: 1.给项目添加强命名 在你的项目右键->属性->签名,勾选“为程序集签名”,新建 或 浏览已经新建过的.pfx文件,然后重新build项目,生成的dll ...

  2. .Net 内存溢出(System.OutOfMemoryException)的常见情况和处理方式总结

    .Net 内存溢出(System.OutOfMemoryException)的常见情况和处理方式总结 在什么情况下会出现OutOfMemonryException呢? 在我们试图新建一个对象时,而垃圾 ...

  3. Spring Batch实践

    Spring Batch在大型企业中的最佳实践 在大型企业中,由于业务复杂.数据量大.数据格式不同.数据交互格式繁杂,并非所有的操作都能通过交互界面进行处理.而有一些操作需要定期读取大批量的数据,然后 ...

  4. 3D数学基础:3D游戏动画中欧拉角与万向锁的理解

    首先来看一下什么是欧拉角(Euler angles)?构件在三维空间中的有限转动,可依次用三个相对转角表示,即进动角.章动角和自旋角,这三个转角统称为欧拉角.——引自百度百科莱昂哈德·欧拉用欧拉角来描 ...

  5. 存储过程中执行动态Sql语句

    MSSQL为我们提供了两种动态执行SQL语句的命令,分别是EXEC和sp_executesql;通常,sp_executesql则更具有优势,它提供了输入输出接口,而EXEC没有.还有一个最大的好处就 ...

  6. list to csv

    import csv # ============================== # list to csv # ============================== a = [1,2, ...

  7. Android 编程下 Touch 事件的分发和消费机制

    Android 中与 Touch 事件相关的方法包括:dispatchTouchEvent(MotionEvent ev).onInterceptTouchEvent(MotionEvent ev). ...

  8. Android使用service后台更新计划任务

    Service是Android的四大组件之一,这里就不再过多的去描述,下面主要实现启动应用时候利用service后台执行计划任务,退出应用后,关闭service,只存在整个应用的周期中. 首先使用se ...

  9. java系列: 在eclipse中调试时,输入的jsp或者servlet页面的地址要区分大小写

    比如在当前web工程中有一个jsp页面的名字是: Welcome.jsp 在eclipse中调试时,如果在浏览器中输入: http://localhost:8080/MavenWeb/welcome. ...

  10. GDB堆栈跟踪与汇编调试

    GDB堆栈跟踪与汇编调试 堆栈跟踪 源代码: 对预先编写的 stack.c 文件进行编译,并且使用 CGDB 进行调试,对堆栈进行跟踪,了解该代码堆栈是如何变化的. 在 CGDB 中,先设置 main ...