nam-example-em.tcl
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:2k
源码类别:

通讯编程

开发平台:

Visual C++

  1. #
  2. # example of new ns support for nam trace, adapted from Kannan's srm2.tcl
  3. #
  4. # $Header: /cvsroot/nsnam/ns-2/tcl/ex/nam-example-em.tcl,v 1.3 1999/09/09 03:29:44 salehi Exp $
  5. #
  6. if [string match {*.tcl} $argv0] {
  7. set prog [string range $argv0 0 [expr [string length $argv0] - 5]]
  8. } else {
  9. set prog $argv0
  10. }
  11. ns-random 1
  12. set ns [new Simulator -multicast on]
  13. Node expandaddr
  14. #$ns trace-all [open out.tr w]
  15. $ns namtrace-all [open out.nam w]
  16. # define color index
  17. $ns color 0 red
  18. $ns color 1 blue
  19. $ns color 2 chocolate
  20. $ns color 3 red
  21. $ns color 4 brown
  22. $ns color 5 tan
  23. $ns color 6 gold
  24. $ns color 7 black
  25. # create node with given shape and color
  26. set n(0) [$ns node]
  27. $n(0) color "red" 
  28. $n(0) shape "square"
  29. set n(1) [$ns node]
  30. $n(1) color "blue" 
  31. $n(1) shape "circle"
  32. set n(2) [$ns node]
  33. $n(2) color "blue" 
  34. $n(2) shape "circle"
  35. # create links and layout
  36. $ns duplex-link $n(0) $n(1) 1.5Mb 10ms DropTail
  37. $ns duplex-link-op $n(0) $n(1) orient right-down
  38. $ns duplex-link $n(0) $n(2) 1.5Mb 10ms DropTail
  39. $ns duplex-link-op $n(0) $n(2) orient left-down
  40. # set routing
  41. set group [Node allocaddr]
  42. set cmc [$ns mrtproto CtrMcast {}]
  43. $ns at 0.3 "$cmc switch-treetype $group"
  44. # set group members
  45. set udp0 [new Agent/UDP]
  46. $ns attach-agent $n(0) $udp0
  47. $udp0 set dst_addr_ $group
  48. $udp0 set dst_port_ 0
  49. # set traffic source
  50. set packetSize 800
  51. set s [new Application/Traffic/CBR]
  52. $s set packetSize_ $packetSize
  53. $s set interval_ 0.5
  54. $s attach-agent $udp0
  55. set rcvr0 [new Agent/LossMonitor]
  56. $ns attach-agent $n(1) $rcvr0 
  57. set rcvr1 [new Agent/LossMonitor]
  58. $ns attach-agent $n(2) $rcvr1
  59. set em0 [new SelectErrorModel]
  60. $em0 drop-packet 2 2 1 ;# Drop 1 CBR out of 2
  61. $ns lossmodel $em0 $n(0) $n(1)
  62. $ns at 1.0 "$n(0) join-group $udp0 $group"
  63. $ns at 1.0 "$n(1) join-group $rcvr0 $group"
  64. $ns at 1.5 "$n(2) join-group $rcvr1 $group"
  65. $ns at 1.0 "$s start"
  66. $ns at 0.1 "$n(0) label CBR"
  67. $ns at 0.1 "$n(1) label rcvr0"
  68. $ns at 0.1 "$n(2) label rcvr1"
  69. $ns at 10.0 "finish"
  70. proc finish {} {
  71.     global s 
  72.     $s stop
  73.     global ns 
  74.     $ns flush-trace ;# NB>  Did not really close out.tr...:-)
  75.     global argv0
  76.     if [string match {*.tcl} $argv0] {
  77. set prog [string range $argv0 0 [expr [string length $argv0] - 5]]
  78.     } else {
  79. set prog $argv0
  80.     }
  81.     puts "running nam..."
  82.     exec nam -f dynamic-nam.conf out.nam &
  83.     exit 0
  84. }
  85. $ns at 0.0 "$ns set-animation-rate 0.1ms"
  86. $ns run