leach协议的nam过程实现!(转)

2024-04-04 23:08
文章标签 实现 协议 过程 leach nam

本文主要是介绍leach协议的nam过程实现!(转),希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在网上搜了很久,很少有将leach协议的nam实现的。这里我将自己是怎么将leach协议的nam仿真的修改过程写出来。

1、在将wireless.tcl中加入一下一些代码:

# Initialize Global Variables
#
set ns_   [new Simulator]
set chan [new $opt(chan)]
set prop [new $opt(prop)]
set topo [new Topography]
#set tracefd [open $opt(tr) w]
set tracefd [open leach.tr w]
set namtrace [open leach.nam w]                  #nam文件名为leach.nam
$ns_ trace-all $tracefd
$ns_ namtrace-all-wireless $namtrace $opt(x) $opt(y)

 

#每个节点的跟踪设置

create-god $opt(nn)

$ns_ node-config -adhocRouting $opt(rp) /
      -llType $opt(ll) /
      -macType $opt(mac) /
      -ifqType $opt(ifq) /
      -ifqLen $opt(ifqlen) /
      -antType $opt(ant) /
      -propType $opt(prop) /
      -phyType $opt(netif) /
      -channel $opt(chan) /
       -topoInstance $topo /
      -agentTrace ON /
      -routerTrace ON /

      -macTrace ON /
      -wiredRouting OFF

 

#注意下面加载网络拓扑的代码一定要放在 initial_node_pos调用的前,否则出现下面很多人提到的问题,只显示BS节点,其实其它节点都已经显示了,但是位置都为(0,0),所以看不出来:

 

if { $opt(sc) == "" } {
    puts "*** NOTE: no scenario file specified."
        set opt(sc) "none"
} else {
    puts "Loading scenario file..."
    source $opt(sc)
    puts "Load complete..."
}

#有的wireless.tcl中可能没有上面这段,那就自己加入即可,其中的opt(sc)就是节点的拓扑图,通过genscen生成的那个文件.

 

#初始化节点的位置,如果不加这个,在nam仿真时会出现节点没有定义

for {set i 0} {$i<$opt(nn)} {incr i} {
$ns_ initial_node_pos $node_($i) 6
}

 

$ns_ at $opt(stop).0002 "puts/"NS EXITING.../";$ns_ halt"
$ns_ at $opt(stop).0001 "stop"

 

proc stop {} {

global ns_ tracefd namtrace
$ns_ flush-trace
close $tracefd
close $namtrace
exec nam leach.nam &
exit 0

}

这样wireless.tcl修改好了,其实这样已经可以实现leach协议的仿真,但是nam动画不好看

接下来我自己修改、添加了uamps.tcl和ns-leach.tcl,这样在仿真nam动画是可以标识出bsnode、簇头、同族节点

2、在uamps.tcl中添加一句:

      } else {
      puts "($opt(nn_) == BS)"
      set node_($id) [new MobileNode/ResourceAwareNode $BS_NODE]
      $node_($id) label "BS"
      $node_($id) label-color red
    }

这样bsnode在nam仿真时会在节点头顶出现一个红色的BS

3、在ns-leach.tcl文件中的createSchedule加入:

Application/LEACH instproc createSchedule {} {

global ns_ opt ADV_SCH MAC_BROADCAST BYTES_ID node_

$self instvar clusterNodes_ TDMAschedule_ rng_
$self instvar dist_ code_ now_ beginningE_


set colorarray(0) "red"
set colorarray(1) "yellow"
set colorarray(2) "blue"
set colorarray(3) "green"
set colorarray(4) "chocolate"
set colorarray(5) "brown"
set colorarray(6) "tan"
set colorarray(7) "blank"


set numNodes [llength $clusterNodes_]
set chID [$self nodeID]
if {$numNodes == 0} {
    set xmitOrder ""
    puts "Warning! There are no nodes in this cluster ($chID)!"
    $self SendMyDataToBS
} else {
    # Set the TDMA schedule and send it to all nodes in the cluster.
    set xmitOrder $clusterNodes_
    set msg [list $xmitOrder]
    set spreading_factor $opt(spreading)
    set datasize [expr $spreading_factor * $BYTES_ID * [llength $xmitOrder]]
    pp "$chID sending TDMA schedule: $xmitOrder at time [$ns_ now]"
    pp "Packet size is $datasize."
    set mac_dst $MAC_BROADCAST
    set link_dst $chID
    $self send $mac_dst $link_dst $ADV_SCH $msg $datasize $dist_ $code_
   
    set c_a_ [expr int([$rng_ uniform 0 7])]
    $node_($chID) add-mark A $colorarray($c_a_) square    #簇头是用正方形框住的
    for {set i 0} {$i<$numNodes} {incr i} {
       set n [lindex $xmitOrder $i]
    $node_($n) add-mark A $colorarray($c_a_) hexagon    #同一族的颜色是用和簇头相同颜色的六变形框住的
    }
}

这样修改完成。

说明,由于颜色只有8中,所以有可能簇头会出现相同的颜色,这样不是很容易区分。这是一个不完美的地方。

 

转自:http://hi.baidu.com/zhaochuanbiao/blog/item/058e1729059cd9f0e7cd405b.html


这篇关于leach协议的nam过程实现!(转)的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!


原文地址:
本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.chinasem.cn/article/877050

相关文章

MySQL更新某个字段拼接固定字符串的实现

《MySQL更新某个字段拼接固定字符串的实现》在MySQL中,我们经常需要对数据库中的某个字段进行更新操作,本文就来介绍一下MySQL更新某个字段拼接固定字符串的实现,感兴趣的可以了解一下... 目录1. 查看字段当前值2. 更新字段拼接固定字符串3. 验证更新结果mysql更新某个字段拼接固定字符串 -

java实现延迟/超时/定时问题

《java实现延迟/超时/定时问题》:本文主要介绍java实现延迟/超时/定时问题,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录Java实现延迟/超时/定时java 每间隔5秒执行一次,一共执行5次然后结束scheduleAtFixedRate 和 schedu

Java Optional避免空指针异常的实现

《JavaOptional避免空指针异常的实现》空指针异常一直是困扰开发者的常见问题之一,本文主要介绍了JavaOptional避免空指针异常的实现,帮助开发者编写更健壮、可读性更高的代码,减少因... 目录一、Optional 概述二、Optional 的创建三、Optional 的常用方法四、Optio

在Android平台上实现消息推送功能

《在Android平台上实现消息推送功能》随着移动互联网应用的飞速发展,消息推送已成为移动应用中不可或缺的功能,在Android平台上,实现消息推送涉及到服务端的消息发送、客户端的消息接收、通知渠道(... 目录一、项目概述二、相关知识介绍2.1 消息推送的基本原理2.2 Firebase Cloud Me

Spring Boot项目中结合MyBatis实现MySQL的自动主从切换功能

《SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能》:本文主要介绍SpringBoot项目中结合MyBatis实现MySQL的自动主从切换功能,本文分步骤给大家介绍的... 目录原理解析1. mysql主从复制(Master-Slave Replication)2. 读写分离3.

Redis实现延迟任务的三种方法详解

《Redis实现延迟任务的三种方法详解》延迟任务(DelayedTask)是指在未来的某个时间点,执行相应的任务,本文为大家整理了三种常见的实现方法,感兴趣的小伙伴可以参考一下... 目录1.前言2.Redis如何实现延迟任务3.代码实现3.1. 过期键通知事件实现3.2. 使用ZSet实现延迟任务3.3

基于Python和MoviePy实现照片管理和视频合成工具

《基于Python和MoviePy实现照片管理和视频合成工具》在这篇博客中,我们将详细剖析一个基于Python的图形界面应用程序,该程序使用wxPython构建用户界面,并结合MoviePy、Pill... 目录引言项目概述代码结构分析1. 导入和依赖2. 主类:PhotoManager初始化方法:__in

springboot filter实现请求响应全链路拦截

《springbootfilter实现请求响应全链路拦截》这篇文章主要为大家详细介绍了SpringBoot如何结合Filter同时拦截请求和响应,从而实现​​日志采集自动化,感兴趣的小伙伴可以跟随小... 目录一、为什么你需要这个过滤器?​​​二、核心实现:一个Filter搞定双向数据流​​​​三、完整代码

SpringBoot利用@Validated注解优雅实现参数校验

《SpringBoot利用@Validated注解优雅实现参数校验》在开发Web应用时,用户输入的合法性校验是保障系统稳定性的基础,​SpringBoot的@Validated注解提供了一种更优雅的解... 目录​一、为什么需要参数校验二、Validated 的核心用法​1. 基础校验2. php分组校验3

Python实现AVIF图片与其他图片格式间的批量转换

《Python实现AVIF图片与其他图片格式间的批量转换》这篇文章主要为大家详细介绍了如何使用Pillow库实现AVIF与其他格式的相互转换,即将AVIF转换为常见的格式,比如JPG或PNG,需要的小... 目录环境配置1.将单个 AVIF 图片转换为 JPG 和 PNG2.批量转换目录下所有 AVIF 图