A5-slow-start-loss.tcl
上传用户:rrhhcc
上传日期:2015-12-11
资源大小:54129k
文件大小:3k
源码类别:

通讯编程

开发平台:

Visual C++

  1. # slow start mechanism with packet loss
  2. # features : labeling, annotation, nam-graph, and window size monitoring
  3. set ns [new Simulator]
  4. set n0 [$ns node]
  5. set n1 [$ns node]
  6. $ns at 0.0 "$n0 label Sender"
  7. $ns at 0.0 "$n1 label Receiver"
  8. set nf [open A5-slow-start-loss.nam w]
  9. $ns namtrace-all $nf
  10. set f [open A5-slow-start-loss.tr w]
  11. $ns trace-all $f
  12. $ns duplex-link $n0 $n1 0.2Mb 200ms DropTail
  13. $ns duplex-link-op $n0 $n1 orient right
  14. $ns queue-limit $n0 $n1 10
  15. Agent/TCP set nam_tracevar_ true
  16. set tcp [new Agent/TCP]
  17. $tcp set maxcwnd_ 8
  18. $tcp set windowOption_ 1
  19. $ns attach-agent $n0 $tcp
  20. set sink [new Agent/TCPSink]
  21. $ns attach-agent $n1 $sink
  22. $ns connect $tcp $sink
  23. set ftp [new Application/FTP]
  24. $ftp attach-agent $tcp
  25. $ns add-agent-trace $tcp tcp
  26. $ns monitor-agent-trace $tcp
  27. $tcp tracevar cwnd_
  28. $ns at 0.1 "$ftp start"
  29. # Packet loss 
  30. $ns at 1.87 "$ns queue-limit $n0 $n1 0"
  31. $ns at 1.91 "$ns queue-limit $n0 $n1 10"
  32. $ns at 3.0 "$ns detach-agent $n0 $tcp ; $ns detach-agent $n1 $sink"
  33. $ns at 3.5 "finish"
  34. $ns at 0.0 "$ns trace-annotate "Slow Start with maximum window size 8 (in congestion)""
  35. $ns at 0.05 "$ns trace-annotate "FTP starts at 0.1""
  36. $ns at 0.11 "$ns trace-annotate "Send Packet_0 : Initial window size = 1""
  37. $ns at 0.34 "$ns trace-annotate "Receive Ack_0"" 
  38. $ns at 0.56 "$ns trace-annotate "Send Packet_1,2 : Increase window size to 2""
  39. $ns at 0.79 "$ns trace-annotate "Receive Ack_1,2""
  40. $ns at 0.99 "$ns trace-annotate "Send Packet_3,4,5,6 : Increase window size to 4""
  41. $ns at 1.23 "$ns trace-annotate "Receive Ack_3,4,5,6  ""
  42. $ns at 1.43 "$ns trace-annotate "Send Packet_7,8,9,10,11,12,13,14 : Increase window size to 8""
  43. $ns at 1.67 "$ns trace-annotate "Receive Ack_7,8,9,10,11,12,13,14""
  44. $ns at 1.88 "$ns trace-annotate "Send Packet_15""
  45. $ns at 1.92 "$ns trace-annotate "Packet_16 is lost""
  46. $ns at 1.97 "$ns trace-annotate "Send Packet_17,18,19,20,21,22 : Keep maximum window size,8""
  47. $ns at 2.11 "$ns trace-annotate "Receive Ack_15s""
  48. $ns at 2.20 "$ns trace-annotate "Receive 6 more Ack_15s""
  49. $ns at 2.32 "$ns trace-annotate "Send Packet_23 : Send only 1 packet cause of window size""
  50. $ns at 2.48 "$ns trace-annotate "Re-send lost Packet_16 : Set window size to 1 (Slow Start Restart)""
  51. $ns at 2.55 "$ns trace-annotate "Receive Ack_15""
  52. $ns at 2.72 "$ns trace-annotate "Receive Ack_23""
  53. $ns at 2.91 "$ns trace-annotate "Send Packet_24,25 : Increase window size to 2""
  54. $ns at 3.1 "$ns trace-annotate "FTP stops""
  55. proc finish {} {
  56.         global ns nf
  57.         $ns flush-trace
  58.         close $nf
  59.         puts "filtering..."
  60.         exec tclsh ../bin/namfilter.tcl A5-slow-start-loss.nam
  61.         puts "running nam..."
  62.         exec nam A5-slow-start-loss.nam &
  63.         exit 0
  64. }
  65. $ns run