利用NS2进行无线网络模拟

http://blog.sina.com.cn/s/blog_67a12ca70100t1za.html

本博文的实验取材与《NS-2网络模拟基础与应用》无线网络实验。
场景是三个节点,在一个矩形区域,移动Ad hoc网络使用DSDV路由算法,然后在适当的时候设置它们的移动方向、速度,并在节点0和节点1之间尝试建立ftp连接。脚本代码如下:

set val(chan)      Channel/WirelessChannel         ;#信道类型
set val(prop)      Propagation/TwoRayGround        ;#无线传播模式
set val(netif)     Phy/WirelessPhy                 ;#网络接口类型
set val(mac)       Mac/802_11                      ;#MAC类型
set val(ifq)       Queue/DropTail/PriQueue         ;#接口队列类型
set val(ll)        LL                              ;#逻辑链路层类型
set val(ant)       Antenna/OmniAntenna             ;#天线类型
set val(ifqlen)    50                              ;#接口队列最大长度
set val(nn)        3                               ;#移动节点的数目
set val(rp)        DSDV                            ;#路由协议
set val(x)         500                             ;#移动拓扑的宽度
set val(y)         400                             ;#移动拓扑的长度
set val(stop)      150                             ;#模拟时间
#初始化模拟参数和跟踪对象
set ns [new Simulator]
set tracefd [open simple.tr w]
set windowVsTime2 [open win.tr w]
set namtrace [open simwrls.nam w]
$ns trace-all $tracefd
$ns namtrace-all-wireless $namtrace $val(x) $val(y)
#创建移动拓扑
set topo [new Topography]
#设定移动场景范围
$topo load_flatgrid $val(x) $val(y)
#创建God对象
create-god $val(nn)
#创建$val(nn)个移动节点并将它们连接到信道。
#配置节点属性
$ns node-config -adhocRouting $val(rp) \
                -llType $val(ll) \
                -macType $val(mac) \
                -ifqType $val(ifq) \
                -ifqLen $val(ifqlen) \
                -antType $val(ant) \
                -propType $val(prop) \
                -phyType $val(netif) \
                -channelType $val(chan) \
                -topoInstance $topo \
                -agentTrace ON \
                -routerTrace ON \
                -macTrace OFF \
                -movementTrace ON
#创建移动节点
for {set i 0} {$i < $val(nn)} {incr i} {
     set node_($i) [$ns node]
}
#设定移动节点的初始位置
$node_(0) set X_ 5.0  ;#设定节点0的初始位置(5,5,0),下同
$node_(0) set Y_ 5.0
$node_(0) set Z_ 0.0
$node_(1) set X_ 490.0
$node_(1) set Y_ 285.0
$node_(1) set Z_ 0.0
$node_(2) set X_ 150.0
$node_(2) set Y_ 240.0
$node_(2) set Z_ 0.0
#设定移动模式
#第10s节点0以3.0m/s速度向(250,250,0)移动,其余类推
$ns at 10.0 "$node_(0) setdest 250.0 250.0 3.0"
$ns at 15.0 "$node_(1) setdest 45.0 285.0 5.0"
$ns at 110.0 "$node_(0) setdest 480.0 300.0 5.0"
#在节点node_(0)和node(1)之间创建TCP连接
set tcp [new Agent/TCP/Newreno]
$tcp set class_ 2
set sink [new Agent/TCPSink]
$ns attach-agent $node_(0) $tcp
$ns attach-agent $node_(1) $sink
$ns connect $tcp $sink
set ftp [new Application/FTP]
$ftp attach-agent $tcp
$ns at 10.0 "$ftp start"
#定义统计窗口大小的过程
proc plotWindow {tcpSource file} {
     global ns
     set time 0.01
     set now [$ns now]
     set cwnd [$tcpSource set cwnd_]
     puts $file "$now $cwnd"
     $ns at [expr $now+ $time] "plotWindow $tcpSource $file"
     $ns at 10.1 "plotWindow $tcp $windowVsTime2"
}
#设置在nam中移动节点显示的大小,否则,nam中无法显示节点
for {set i 0} {$i < $val(nn)} {incr i} {
     $ns initial_node_pos $node_($i) 30
}
#模拟结束后重设节点
for {set i 0} {$i < $val(nn)} {incr i} {
     $ns at $val(stop) "$node_($i) reset"
}
#调度整个模拟过程的运行
$ns at $val(stop) "$ns nam-end-wireless $val(stop)"
$ns at $val(stop) "stop"
#$ns at 150.01 "puts \" end simulation\" ;$ns halt"
proc stop {} {
     global ns tracefd namtrace
     $ns flush-trace
     close $tracefd
     close $namtrace
     exec nam simwrls.nam &  ;#这一步是为了启动nam进行动画演示 
     exit 0
}
$ns run
}

与有线网络相比,无线网络的脚本多了许多配置,但基本的配置也是固定的类型,做过几个实验后,就会慢慢适应有线网络的配置。

你可能感兴趣的:(网络,tcp,ant,File,脚本,Class)