2017-05-20 70 views
1

我想在ns2創建移動文件與somo的道路上創建多個羣集。
文件mobility.tcl是相撲移動性。羣集在網絡vanet +文件與sumo + ns2移動craeted

我的代碼如下:

set val(chan)   Channel/WirelessChannel ;# channel type 
set val(prop)   Propagation/TwoRayGround ;# radio-propagation model 
set val(netif1)   Phy/WirelessPhy   ;# network interface type 
set val(netif2)   Phy/WirelessPhy   ;# network interface type 
set val(mac)   Mac/802_11p    ;# MAC type 
set val(ifq)   Queue/DropTail/PriQueue ;# interface queue type 
set val(ll)    LL       ;# link layer type 
set val(ant)   Antenna/OmniAntenna  ;# antenna model 
set val(ifqlen)   400      ;# max packet in ifq 
set val(nn)    747      ;# number of mobilenodes 
set val(rp)    DSDV      ;# routing protocol 
set opt(x)    6162 
set opt(y)    6029 
# ====================================================================== 
# Main Program 
# ===================================================================== 
# 
# Initialize Global Variables 
# 
set ns_  [new Simulator] 
# set up for hierarchical routing 
$ns_ node-config -addressType hierarchical 

AddrParams set domain_num_ 10   
lappend cluster_num 2 6 2 3 6 1 5 5 2 6     
AddrParams set cluster_num_ $cluster_num 
lappend eilastlevel 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20 20    
AddrParams set nodes_num_ $eilastlevel 
set tracefd  [open paris.tr w] 
$ns_ trace-all $tracefd 
set namf [open paris.nam w] 
$ns_ namtrace-all-wireless $namf $opt(x) $opt(y) 
# set up topography object 
set topo  [new Topography] 
$topo load_flatgrid $opt(x) $opt(y) 
# 
# Create God 
# 
create-god $val(nn) 
# configure node 
    $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(netif1) \ 
     -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_($i) random-motion 0  ;# disable random motion 
      $ns_ initial_node_pos $node_($i) 30 
      } 
    $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(netif2) \ 
     -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_($i) random-motion 0  ;# disable random motion 
      $ns_ initial_node_pos $node_($i) 30 
      } 
    source mobility.tcl 

    set udp0 [new Agent/UDP] 
    $ns attach-agent $n(0) $udp0 
    set cbr0 [new Application/Traffic/CBR] 
    $cbr0 attach-agent $udp0 
    set udp1 [new Agent/UDP] 
    $ns attach-agent $n(1) $udp1 
    $udp1 set class_ 1 
    set cbr1 [new Application/Traffic/CBR] 
    $cbr1 attach-agent $udp1 
    set null0 [new Agent/Null] 
    $ns attach-agent $n(50) $null0 
    set null1 [new Agent/Null] 
    $ns attach-agent $n(80) $null1 
    $ns connect $udp0 $null0 
    $ns connect $udp1 $null1 
    $ns at 1.0 "$cbr0 start" 
    $ns at 1.1 "$cbr1 start" 
    set tcp [new Agent/TCP] 
    $tcp set class_ 2 
    set sink [new Agent/TCPSink] 
    $ns_ attach-agent $node_(0) $tcp 
    $ns_ attach-agent $node_(22) $sink 
    $ns_ connect $tcp $sink 
    set ftp [new Application/FTP] 
    $ftp attach-agent $tcp 
    $ns_ at 10.0 "$ftp start" 
    # 
    # Tell nodes when the simulation ends 
    # 
     for {set i 0} {$i < $val(nn) } {incr i} { 
    $ns_ at 500.0 "$node_($i) reset"; 
    } 
     $ns_ at 500.0 "stop" 
    $ns_ at 1000.01 "puts \"NS EXITING...\" ; $ns_ halt" 
    proc stop {} { 
global ns_ tracefd 
$ns_ flush-trace 
close $tracefd 
    } 
    puts "Starting Simulation..." 
    $ns_ run* 

和錯誤是:

[email protected]:~/champ elysees$ ns paris2.tcl 
    num_nodes is set 747 
    Error!! 
    str2addr:Address 32573 outside range of address field length 2048* 
+0

1)無SUMO流動性文件連接到您的文件。 2)請看一下經過測試的集羣示例https://drive.google.com/file/d/0B7S255p3kFXNM3g4d3FBRXFDM3c/view?usp=sharing ... 3)以及帶有相連的相撲文件http:// neo的vanet示例。 lcc.uma.es/staff/jamal/vanet/?q=node/11→urban-VANET-scenario-U1.tar.gz,urban-VANET-scenario-U2.tar.gz,urban-VANET-scenario-U3名爲.tar.gz –

回答

0

你的代碼幾乎是OK的時候,有些錯別字進行編輯。 Mac/802_11p今天是Mac/802_11Ext。除非你爲802_11p使用了一箇舊補丁,並且失敗了。但我猜這是一個錯字。使用分層結構:節點必須創建分層結構。一個簡單的 「節點創建」 將導致

地址32573範圍之外的地址字段長度的2048

錯別字:ns有兩個定義,nsns_

node有兩個定義,nnode_ .....容易地固定具有:

$ sed -i 's/ns/ns_/g' somiMadani.tcl && sed -i 's/ns__/ns_/g' somiMadani.tcl 

$ sed -i 's/n(/node_(/g' somiMadani.tcl 

仿真:我使用40個節點的移動性SUMO文件:mobmod-teatinos-M40A.tcl,從http://neo.lcc.uma.es/staff/jamal/vanet/?q=node/11。當跟蹤文件大約80MB時,會出現分段錯誤,這是可用的。南動畫:好的。編輯過的文件,somiMadani-vanet.tcl→→Dropbox的→https://www.dropbox.com/s/sv7p4tqc6pk0oje/somiMadani-vanet.tcl?dl=0和可讀性,somiMadani-vanet.tcl.txt https://www.dropbox.com/s/fy8valous07m5er/somiMadani-vanet.tcl.txt?dl=0

編輯,君5.層次:創建所需的分層節點:請參見ns-2.3x/tcl/{ex/{hier-rtg-10.tcl, hts100-0.tcl, test/hts1000.tcl}→→hts100-0。 tcl,hts1000.tcl由hier-rtg-100.tcl,hier-test-1000.tcl使用的 使用。

新的榜樣,你的代碼+的hts100-0.tcl片段 「正hts120-0.tcl」:Vanet_n-802.11p.tar.gz https://drive.google.com/file/d/0B7S255p3kFXNcVcwSXhPWGUycDA/view?usp=sharing