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

相关文章

Oracle查询优化之高效实现仅查询前10条记录的方法与实践

《Oracle查询优化之高效实现仅查询前10条记录的方法与实践》:本文主要介绍Oracle查询优化之高效实现仅查询前10条记录的相关资料,包括使用ROWNUM、ROW_NUMBER()函数、FET... 目录1. 使用 ROWNUM 查询2. 使用 ROW_NUMBER() 函数3. 使用 FETCH FI

Python脚本实现自动删除C盘临时文件夹

《Python脚本实现自动删除C盘临时文件夹》在日常使用电脑的过程中,临时文件夹往往会积累大量的无用数据,占用宝贵的磁盘空间,下面我们就来看看Python如何通过脚本实现自动删除C盘临时文件夹吧... 目录一、准备工作二、python脚本编写三、脚本解析四、运行脚本五、案例演示六、注意事项七、总结在日常使用

Java实现Excel与HTML互转

《Java实现Excel与HTML互转》Excel是一种电子表格格式,而HTM则是一种用于创建网页的标记语言,虽然两者在用途上存在差异,但有时我们需要将数据从一种格式转换为另一种格式,下面我们就来看看... Excel是一种电子表格格式,广泛用于数据处理和分析,而HTM则是一种用于创建网页的标记语言。虽然两

Java中Springboot集成Kafka实现消息发送和接收功能

《Java中Springboot集成Kafka实现消息发送和接收功能》Kafka是一个高吞吐量的分布式发布-订阅消息系统,主要用于处理大规模数据流,它由生产者、消费者、主题、分区和代理等组件构成,Ka... 目录一、Kafka 简介二、Kafka 功能三、POM依赖四、配置文件五、生产者六、消费者一、Kaf

使用Python实现在Word中添加或删除超链接

《使用Python实现在Word中添加或删除超链接》在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能,本文将为大家介绍一下Python如何实现在Word中添加或... 在Word文档中,超链接是一种将文本或图像连接到其他文档、网页或同一文档中不同部分的功能。通过添加超

windos server2022里的DFS配置的实现

《windosserver2022里的DFS配置的实现》DFS是WindowsServer操作系统提供的一种功能,用于在多台服务器上集中管理共享文件夹和文件的分布式存储解决方案,本文就来介绍一下wi... 目录什么是DFS?优势:应用场景:DFS配置步骤什么是DFS?DFS指的是分布式文件系统(Distr

NFS实现多服务器文件的共享的方法步骤

《NFS实现多服务器文件的共享的方法步骤》NFS允许网络中的计算机之间共享资源,客户端可以透明地读写远端NFS服务器上的文件,本文就来介绍一下NFS实现多服务器文件的共享的方法步骤,感兴趣的可以了解一... 目录一、简介二、部署1、准备1、服务端和客户端:安装nfs-utils2、服务端:创建共享目录3、服

C#使用yield关键字实现提升迭代性能与效率

《C#使用yield关键字实现提升迭代性能与效率》yield关键字在C#中简化了数据迭代的方式,实现了按需生成数据,自动维护迭代状态,本文主要来聊聊如何使用yield关键字实现提升迭代性能与效率,感兴... 目录前言传统迭代和yield迭代方式对比yield延迟加载按需获取数据yield break显式示迭

Python实现高效地读写大型文件

《Python实现高效地读写大型文件》Python如何读写的是大型文件,有没有什么方法来提高效率呢,这篇文章就来和大家聊聊如何在Python中高效地读写大型文件,需要的可以了解下... 目录一、逐行读取大型文件二、分块读取大型文件三、使用 mmap 模块进行内存映射文件操作(适用于大文件)四、使用 pand

python实现pdf转word和excel的示例代码

《python实现pdf转word和excel的示例代码》本文主要介绍了python实现pdf转word和excel的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价... 目录一、引言二、python编程1,PDF转Word2,PDF转Excel三、前端页面效果展示总结一