感谢支持
我们一直在努力

NS2.29中Tdma的实现分析

1.  NS2中的Tdma时帧结构如下图:

 其中前导的数据结构为:static int *tdma_preamble_;
 tdma_preamble_ = new int[max_slot_num_]; //max_slot_num_为节点总数
 tdma_preamble_[slot_num_] = ETHER_ADDR(MAC_TDMA(pktTx_)->dh_da);
 //前导中存储的是目标节点的Mac地址(4个字节),slot_num_表示当时隙号。
 
在前导时隙这段时间,完成的主要工作就是设置tdma_preamble_[0]到
 tdma_preamble_[ max_slot_num_ – 1]的值,代表从0到max_slot_num_-1个数据时隙各个时隙中要发送数据的目标节点地址。

2. 整个Tdma的类图如下:

3.  Tdma执行过程和关键的时隙控制函数如下图:

4.  设置前导中数据的函数makePreamble过程:

5.  发送函数流程图:

 

6.  接收函数流程图:

7.  一个例子分析,场景:三个节点,相互可见,单信道下节点0和1几乎同时在0.020001秒即20毫秒的时候给2发送数据,2只接收不发送,仿真在1秒时结束。
 
Mac层采用NS2自带的Tdma协议,则:
 Tdma的时帧结构为:

输出的结果显示:

 <0>, 0.000000, make the new preamble now.
 <0>, 0.000000, write NO_PKT to slot 0 in preamble
 <1>, 0.000000, make the new preamble now.
 <1>, 0.000000, write NO_PKT to slot 1 in preamble
 <2>, 0.000000, make the new preamble now.
 <2>, 0.000000, write NO_PKT to slot 2 in preamble
 
<0>, 0.006000, time to send.
 <1>, 0.006000, preamble[0]=-2, nothing to do now.
 <2>, 0.006000, preamble[0]=-2, nothing to do now.
 
<0>, 0.012000, preamble[1]=-2, nothing to do now.
 <1>, 0.012000, time to send.
 <2>, 0.012000, preamble[1]=-2, nothing to do now.
 
<0>, 0.018000, preamble[2]=-2, nothing to do now.
 <1>, 0.018000, preamble[2]=-2, nothing to do now.
 <2>, 0.018000, time to send.
 

<0>, 0.024000, make the new preamble now.
 <0>, 0.024000, write -1 to slot 0 in preamble
 <1>, 0.024000, make the new preamble now.
 <1>, 0.024000, write -1 to slot 1 in preamble
 <2>, 0.024000, make the new preamble now.
 <2>, 0.024000, write NO_PKT to slot 2 in preamble
 
<0>, 0.030000, time to send.
 <1>, 0.030000, preamble[0]=-1, I am supposed to receive now.
 <2>, 0.030000, preamble[0]=-1, I am supposed to receive now.
 
<0>, 0.036000, preamble[1]=-1, I am supposed to receive now.
 <1>, 0.036000, time to send.
 <2>, 0.036000, preamble[1]=-1, I am supposed to receive now.
 
<0>, 0.042000, preamble[2]=-2, nothing to do now.
 <1>, 0.042000, preamble[2]=-2, nothing to do now.
 <2>, 0.042000, time to send.
 …….
 
从上面可以看出,NS2中自带的Tdma的实现是极其简单的,时隙分配算法也特别简单。

Ubuntu 13.04 安装NS2.35 http://www.linuxidc.com/Linux/2014-03/98266.htm

Linux平台下NS2.35安装 http://www.linuxidc.com/Linux/2013-11/93055.htm

NS2.33在Ubuntu 12.10的完整安装过程及相关问题 http://www.linuxidc.com/Linux/2013-05/84032.htm

NS2.33中安装Noah协议 http://www.linuxidc.com/Linux/2012-06/63764.htm

NS2使用tcl脚本debug工具tcl-debug-2.0 http://www.linuxidc.com/Linux/2012-06/63761.htm

本文永久更新链接地址:http://www.linuxidc.com/Linux/2014-05/102377.htm

赞(0) 打赏
转载请注明出处:服务器评测 » NS2.29中Tdma的实现分析
分享到: 更多 (0)

听说打赏我的人,都进福布斯排行榜啦!

支付宝扫一扫打赏

微信扫一扫打赏