C4-sliding-window.tcl
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:3k
源码类别:

通讯编程

开发平台:

Visual C++

  1. # Slow start protocol in a heavily loaded network.
  2. # features : labeling, annotation, nam-graph, and window size monitoring
  3. #
  4. # n0    n5 
  5. #                / 
  6. # n1 -- n3 ---------- n4 -- n6
  7. #    /  
  8. # n2    n7
  9. set ns [new Simulator]
  10. $ns color 0 black
  11. $ns color 1 red
  12. #$ns trace-all [open C4-sliding-window.tr w]
  13. #$ns namtrace-all [open C4-sliding-window.nam w]
  14. ### build topology with 8 nodes
  15. foreach i " 0 1 2 3 4 5 6 7" {
  16. set n$i [$ns node]
  17. }
  18.         $ns at 0.0 "$n0 label SLIDING"
  19.         $ns at 0.0 "$n5 label SLIDING"
  20.         $ns at 0.0 "$n1 label CBR-1"
  21.         $ns at 0.0 "$n2 label CBR-2" 
  22.         $ns at 0.0 "$n6 label CBR-1"
  23.         $ns at 0.0 "$n7 label CBR-2"
  24.         $ns duplex-link $n0 $n3 5Mb 20ms DropTail
  25.         $ns duplex-link $n1 $n3 1Mb 20ms DropTail
  26.         $ns duplex-link $n2 $n3 1Mb 20ms DropTail
  27.         $ns duplex-link $n3 $n4 1Mb 50ms DropTail
  28. $ns duplex-link $n4 $n5 5Mb 20ms DropTail
  29.         $ns duplex-link $n4 $n6 1Mb 20ms DropTail
  30.         $ns duplex-link $n4 $n7 1Mb 20ms DropTail
  31.         $ns queue-limit $n3 $n4 15
  32.         $ns duplex-link-op $n0 $n3 orient right-down
  33.         $ns duplex-link-op $n1 $n3 orient right
  34.         $ns duplex-link-op $n2 $n3 orient right-up
  35.         $ns duplex-link-op $n3 $n4 orient right     
  36.         $ns duplex-link-op $n4 $n5 orient right-up
  37.         $ns duplex-link-op $n4 $n6 orient right     
  38.         $ns duplex-link-op $n4 $n7 orient right-down     
  39.         $ns duplex-link-op $n3 $n4 queuePos 0.5
  40. Agent/TCP set nam_tracevar_ true         
  41. Agent/TCP set window_ 20
  42. Agent/TCP set maxcwnd_ 8
  43. ### TCP between n0 and n5 (Black)
  44. #set sliding [new Agent/TCP/SlidingWindow]
  45. set sliding [new Agent/TCP]
  46. $sliding set fid_ 0
  47. $ns attach-agent $n0 $sliding
  48.         
  49. #set sink [new Agent/TCPSink/SlidingWindowSink]
  50. set sink [new Agent/TCPSink]
  51. $ns attach-agent $n5 $sink
  52. $ns connect $sliding $sink
  53. set ftp [new Application/FTP]
  54. $ftp attach-agent $sliding
  55. $ns add-agent-trace $sliding tcp
  56. $ns monitor-agent-trace $sliding
  57. $sliding tracevar cwnd_
  58. $sliding tracevar ssthresh_
  59. ### CBR traffic between (n1 & n6) and (n2 & n7)
  60. set cbr0 [new Agent/CBR]
  61. $ns attach-agent $n1 $cbr0
  62. $cbr0 set fid_ 1
  63. $cbr0 set packetSize_ 500
  64. $cbr0 set interval_ 0.01
  65. set null0 [new Agent/CBR]
  66. $ns attach-agent $n6 $null0
  67. $ns connect $cbr0 $null0
  68. set cbr1 [new Agent/CBR]
  69. $ns attach-agent $n2 $cbr1
  70. $cbr1 set fid_ 1
  71. $cbr1 set packetSize_ 1000
  72. $cbr1 set interval_ 0.02
  73. set null1 [new Agent/CBR]
  74. $ns attach-agent $n7 $null1
  75. $ns connect $cbr1 $null1 
  76. proc finish {} {
  77.         global ns
  78.         $ns flush-trace
  79. #        puts "filtering..."
  80. #        exec tclsh ../bin/namfilter.tcl C4-sliding-window.nam
  81.         puts "running nam..."
  82.         exec nam C4-sliding-window.nam &
  83.         exit 0
  84. }
  85. ### set operations
  86. $ns at 0.05 "$cbr0 start"
  87. $ns at 2.3 "$cbr0 stop" 
  88. $ns at 0.1 "$cbr1 start"
  89. $ns at 2.5 "$cbr1 stop"
  90. $ns at 0.5 "$ftp start"
  91. $ns at 2.5 "$ftp stop"
  92. $ns at 2.7 "finish"
  93. ### add annotations
  94. $ns at 0.05 "$ns trace-annotate "CBR-1 starts""
  95. $ns at 0.1 "$ns trace-annotate "CBR-2 starts""
  96. $ns at 0.5 "$ns trace-annotate "FTP starts""
  97. $ns at 2.55 "$ns trace-annotate "FTP stops""
  98. $ns run