кластеризация в сети vanet + мобильность файлов, созданная с помощью sumo + ns2

Я хочу создать несколько кластеров на дороге с файлами мобильности, созданными с помощью somo в ns2.
Файл mobility.tcl - это мобильность в сумо.

Мой код выглядит следующим образом:

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*

И ошибка:

madani@ubuntu:~/champ elysees$ ns paris2.tcl
  num_nodes is set 747
  Error!!
  str2addr:Address 32573 outside range of address field length 2048*

person somi Madani    schedule 20.05.2017    source источник
comment
1) К вашему файлу не подключен файл мобильности SUMO. 2) Ознакомьтесь с протестированными примерами кластеризации drive.google.com / file / d / 0B7S255p3kFXNM3g4d3FBRXFDM3c / ... 3) И еще несколько примеров с подключенными файлами сумо neo.lcc.uma.es/staff/jamal/vanet/?q=node/11 → urban-VANET-scene-U1.tar.gz, urban-VANET -scenario-U2.tar.gz, городской-VANET-сценарий-U3.tar.gz   -  person Knud Larsen    schedule 20.05.2017


Ответы (1)


Ваш код почти в порядке, если исправлены некоторые опечатки. Mac/802_11p сегодня Mac/802_11Ext. Если вы не использовали старый патч для 802_11p и не завершили сборку. Но я предполагаю, что это опечатка. Использование иерархии: узлы должны создаваться иерархически. Простое «создание узла» вызовет

Адрес 32573 вне диапазона длины адресного поля 2048

Опечатки: ns имеет два определения: ns и ns_.

node имеет два определения, n и node_ ..... Легко исправить с помощью:

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

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

Моделирование: я использовал файл мобильности SUMO с 40 узлами: mobmod-teatinos-M40A.tcl, из http://neo.lcc.uma.es/staff/jamal/vanet/?q=node/11. Ошибка сегментации возникает, когда файлы трассировки имеют размер около 80 МБ, что можно использовать. Нам анимация: ОК. Отредактированный файл 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 «n-hts120-0.tcl»: Vanet_n-802.11p.tar.gz https://drive.google.com/file/d/0B7S255p3kFXNcVcwSXhPWGUycDA/view?Usp=sharing

person Knud Larsen    schedule 03.06.2017