ns3 Programs

Download as pdf or txt
Download as pdf or txt
You are on page 1of 4

Mesh..... set val(stop) 10.0; set ns [new Simulator] set tracefile [open out.

tr w] $ns trace-all $tracefile set namfile [open out.nam w] $ns namtrace-all $namfile set n0 [$ns node] set n1 [$ns node] set n2 [$ns node] set n3 [$ns node] $ns duplex-link $n1 $n0 100.0Mb 10ms DropTail $ns duplex-link $n2 $n3 100.0Mb 10ms DropTail $ns duplex-link $n3 $n0 100.0Mb 10ms DropTail $ns duplex-link $n0 $n2 100.0Mb 10ms DropTail $ns duplex-link $n2 $n1 100.0Mb 10ms DropTail $ns duplex-link $n1 $n3 100.0Mb 10ms DropTail proc finish {} { global ns tracefile namfile $ns flush-trace close $tracefile close $namfile exec nam out.nam & exit 0 } $ns at $val(stop) "finish" $ns run Ring set ns [new Simulator] set tracefile [open out.tr w] $ns trace-all $tracefile set namfile [open out.nam w] $ns namtrace-all $namfile puts "number of nodes" gets stdin ans for { set i 1 } { $i <= $ans } { incr i } { set n($i) [$ns node] } for { set i 1 } { $i < $ans } { incr i } { $ns duplex-link $n($i) $n([expr $i + 1]) 10Mb 10ms DropTail } $ns duplex-link $n(1) $n($ans) 10Mb 10ms DropTail proc finish {} { global ns tracefile namfile $ns flush-trace close $tracefile close $namfile exec nam out.nam & exit 0 } $ns at 5.0 "finish" $ns run Star set ns [new Simulator] set tracefile [open out.tr w] $ns trace-all $tracefile set namfile [open out.nam w] $ns namtrace-all $namfile

puts "number of nodes" gets stdin ans for { set i 1 } { $i <= $ans } { incr i } { set n($i) [$ns node] } for { set i 2 } { $i <= $ans } { incr i } { $ns duplex-link $n($i) $n(1) 10Mb 10ms DropTail } proc finish {} { global ns tracefile namfile $ns flush-trace close $tracefile close $namfile exec nam out.nam & exit 0 } $ns at 5.0 "finish" $ns run Tcp set ns [new Simulator] $ns trace-all [open out.tr w] $ns namtrace-all [open out.nam w] set n0 [$ns node] set n1 [$ns node] $ns duplex-link $n0 $n1 1Mb 10ms DropTail set tcp1 [new Agent/TCP] set sink1 [new Agent/TCPSink] $ns attach-agent $n0 $tcp1 $ns attach-agent $n1 $sink1 $ns connect $tcp1 $sink1 set cbr1 [new Application/Traffic/CBR] $cbr1 set packetSize_ 500 $cbr1 set interval_ 0.5 $cbr1 attach-agent $tcp1 $ns at 0.5 "$cbr1 start" $ns at 4.5 "$cbr1 stop" $ns at 5.0 "exit 0" #set tf [open "cwnd.tr" w] #set tracer [new Trace/Var] #$tracer attach $tf #$tcp1 trace cwnd_ $tracer $ns at 5.5 "finish" $ns run Udp set val(stop) 10.0 set ns [new Simulator] set tracefile [open out.tr w] $ns trace-all $tracefile set namfile [open out.nam w] $ns namtrace-all $namfile set n0 [$ns node] set n1 [$ns node] $ns duplex-link $n0 $n1 100.0Mb 10ms DropTail set udp0 [new Agent/UDP]

set sink1 [new Agent/Null] $ns attach-agent $n0 $udp0 $ns attach-agent $n1 $sink1 $ns connect $udp0 $sink1 set cbr1 [new Application/Traffic/CBR] $cbr1 set packetSize_ 5000 $cbr1 set interval_ 0.5 $cbr1 attach-agent $udp0 $ns at 0.5 "$cbr1 start" $ns at 4.5 "$cbr1 stop" $ns at 5.0 "exit 0" proc finish {} { global ns tracefile namfile $ns flush-trace close $tracefile close $namfile exec nam out.nam & exit 0 } $ns at $val(stop) "finish" $ns run ------------------------------------------------------------set val(chan) Channel/WirelessChannel ; set val(prop) Propagation/TwoRayGround ; set val(netif) Phy/WirelessPhy ; set val(mac) Mac/802_11 ; 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 simwels.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) create-god $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 $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 $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" 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" 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 }$ns run

You might also like