⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 test-suite-simple.tcl

📁 柯老师网站上找到的
💻 TCL
📖 第 1 页 / 共 3 页
字号:
Class Test/reno5 -superclass TestSuiteTest/reno5 instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	reno5	$self next}Test/reno5 instproc run {} {	$self instvar ns_ node_ testName_	$ns_ queue-limit $node_(r1) $node_(k1) 9	set tcp1 [$ns_ create-connection TCP/Reno $node_(s1) TCPSink $node_(k1) 0]	$tcp1 set window_ 50	$tcp1 set bugFix_ false	set tcp2 [$ns_ create-connection TCP/Reno $node_(s2) TCPSink $node_(k1) 1]	$tcp2 set window_ 20	$tcp2 set bugFix_ false	set ftp1 [$tcp1 attach-app FTP]	set ftp2 [$tcp2 attach-app FTP]	$ns_ at 1.0 "$ftp1 start"	$ns_ at 1.0 "$ftp2 start"	$self tcpDump $tcp1 1.0	# Trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace 10.0 $testName_]	$ns_ run}Class Test/telnet -superclass TestSuiteTest/telnet instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	telnet	$self next}Test/telnet instproc run {} {	$self instvar ns_ node_ testName_	$ns_ queue-limit $node_(r1) $node_(k1) 8	$ns_ queue-limit $node_(k1) $node_(r1) 8	set tcp1 [$ns_ create-connection TCP/Reno $node_(s1) TCPSink $node_(k1) 0]	set tcp2 [$ns_ create-connection TCP/Reno $node_(s2) TCPSink $node_(k1) 1]	set tcp3 [$ns_ create-connection TCP/Reno $node_(s2) TCPSink $node_(k1) 2]	set telnet1 [$tcp1 attach-app Telnet]; $telnet1 set interval_ 1	set telnet2 [$tcp2 attach-app Telnet]; $telnet2 set interval_ 0	# Interval 0 designates the tcplib telnet interarrival distribution	set telnet3 [$tcp3 attach-app Telnet]; $telnet3 set interval_ 0	$ns_ at 0.0 "$telnet1 start"	$ns_ at 0.0 "$telnet2 start"	$ns_ at 0.0 "$telnet3 start"	$self tcpDump $tcp1 5.0	# Trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace 50.0 $testName_]	# use a different seed each time	#puts seed=[$ns_ random 0]	$ns_ run}Class Test/delayed -superclass TestSuiteTest/delayed instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	delayed	$self next}Test/delayed instproc run {} {	$self instvar ns_ node_ testName_	set tcp1 [$ns_ create-connection TCP $node_(s1) TCPSink/DelAck $node_(k1) 0]	$tcp1 set window_ 50	# lookup up the sink and set it's delay interval	[$node_(k1) agent [$tcp1 dst-port]] set interval 100ms	set ftp1 [$tcp1 attach-app FTP];	$ns_ at 1.0 "$ftp1 start"	$self tcpDump $tcp1 1.0	# Trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace 4.0 $testName_]	$ns_ run}Class Test/phase -superclass TestSuiteTest/phase instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	phase	$self next}Test/phase instproc run {} {	$self instvar ns_ node_ testName_	$ns_ delay $node_(s2) $node_(r1) 3ms	$ns_ delay $node_(r1) $node_(s2) 3ms	$ns_ queue-limit $node_(r1) $node_(k1) 16	$ns_ queue-limit $node_(k1) $node_(r1) 100	set tcp1 [$ns_ create-connection TCP $node_(s1) TCPSink $node_(k1) 0]	$tcp1 set window_ 32 	set tcp2 [$ns_ create-connection TCP $node_(s2) TCPSink $node_(k1) 1]	$tcp2 set window_ 32 	set ftp1 [$tcp1 attach-app FTP]	set ftp2 [$tcp2 attach-app FTP]	$ns_ at 5.0 "$ftp1 start"	$ns_ at 1.0 "$ftp2 start"	$self tcpDump $tcp1 5.0	# Trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace 25.0 $testName_]	$ns_ run}Class Test/phase1 -superclass TestSuiteTest/phase1 instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	phase1	$self next}Test/phase1 instproc run {} {	$self instvar ns_ node_ testName_	$ns_ delay $node_(s2) $node_(r1) 9.5ms	$ns_ delay $node_(r1) $node_(s2) 9.5ms	$ns_ queue-limit $node_(r1) $node_(k1) 16	$ns_ queue-limit $node_(k1) $node_(r1) 100	set tcp1 [$ns_ create-connection TCP $node_(s1) TCPSink $node_(k1) 0]	$tcp1 set window_ 32 	set tcp2 [$ns_ create-connection TCP $node_(s2) TCPSink $node_(k1) 1]	$tcp2 set window_ 32 	set ftp1 [$tcp1 attach-app FTP]	set ftp2 [$tcp2 attach-app FTP]	$ns_ at 5.0 "$ftp1 start"	$ns_ at 1.0 "$ftp2 start"	$self tcpDump $tcp1 5.0	# Trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace 25.0 $testName_]	$ns_ run}Class Test/phase2 -superclass TestSuiteTest/phase2 instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	phase2	$self next}Test/phase2 instproc run {} {	$self instvar ns_ node_ testName_	$ns_ delay $node_(s2) $node_(r1) 3ms	$ns_ delay $node_(r1) $node_(s2) 3ms	$ns_ queue-limit $node_(r1) $node_(k1) 16	$ns_ queue-limit $node_(k1) $node_(r1) 100	set tcp1 [$ns_ create-connection TCP $node_(s1) TCPSink $node_(k1) 0]	$tcp1 set window_ 32 	$tcp1 set overhead_ 0.01	set tcp2 [$ns_ create-connection TCP $node_(s2) TCPSink $node_(k1) 1]	$tcp2 set window_ 32 	$tcp2 set overhead_ 0.01	set ftp1 [$tcp1 attach-app FTP]	set ftp2 [$tcp2 attach-app FTP]	$ns_ at 5.0 "$ftp1 start"	$ns_ at 1.0 "$ftp2 start"	$self tcpDump $tcp1 5.0	# Trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace 25.0 $testName_]	$ns_ run}Class Test/timers -superclass TestSuiteTest/timers instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	timers	$self next}Test/timers instproc run {} {	$self instvar ns_ node_ testName_	$ns_ queue-limit $node_(r1) $node_(k1) 2	$ns_ queue-limit $node_(k1) $node_(r1) 100	set tcp1 [$ns_ create-connection TCP $node_(s1) TCPSink/DelAck $node_(k1) 0]	$tcp1 set window_ 4	# look up the sink and set its delay interval	[$node_(k1) agent [$tcp1 dst-port]] set interval_ 100ms	set tcp2 [$ns_ create-connection TCP $node_(s2) TCPSink/DelAck $node_(k1) 1]	$tcp2 set window_ 4	# look up the sink and set its delay interval	[$node_(k1) agent [$tcp2 dst-port]] set interval_ 100ms	set ftp1 [$tcp1 attach-app FTP]	set ftp2 [$tcp2 attach-app FTP]	$ns_ at 1.0 "$ftp1 start"	$ns_ at 1.3225 "$ftp2 start"	$self tcpDump $tcp1 5.0	# Trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace 10.0 $testName_]	$ns_ run}# Many small TCP flows.Class Test/manyflows -superclass TestSuiteTest/manyflows instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	manyflows	$self next}Test/manyflows instproc run {} {	$self instvar ns_ node_ testName_	# Set up TCP connections	set rng_ [new RNG]	## $rng_ seed [ns random 0]	set stoptime 5	set randomflows 10	for {set i 0} {$i < $randomflows} {incr i} {	    set tcp [$ns_ create-connection TCP $node_(s1) TCPSink $node_(k1) 1]	    set ftp [[set tcp] attach-app FTP]    	    set numpkts [$rng_ uniform 0 10]	    set starttime [$rng_ uniform 0 $stoptime]	    $ns_ at $starttime "[set ftp] produce $numpkts" 	    $ns_ at $stoptime "[set ftp] stop"  	}   	# Trace only the bottleneck link	#	# Actually, we now trace all activity at the node around the	# bottleneck link.  This allows us to track acks, as well	# packets taking any alternate paths around the bottleneck	# link.	#	$self traceQueues $node_(r1) [$self openTrace $stoptime $testName_]	$ns_ run}TestSuite instproc printpkts { label tcp } {	puts "tcp $label highest_seqment_acked [$tcp set ack_]"}TestSuite instproc printdrops { fid fmon } {	set fcl [$fmon classifier]; # flow classifier	#	# look up the flow using the classifier.  Because we are	# using a Fid classifier, the src/dst fields are not compared,	# and can thus be just zero, as illustrated here.  The "auto"	# indicates we don't already know which bucket in the classifier's	# hash table to find the flow we're looking for.	#	set flow [$fcl lookup auto 0 0 $fid]	puts "fid: $fid per-link total_drops [$flow set pdrops_]"	puts "fid: $fid per-link total_packets [$flow set pdepartures_]"	puts "fid: $fid per-link total_bytes [$flow set bdepartures_]"	#	# note there is much more date available in $flow and $fmon	# that isn't being printed here.	#}TestSuite instproc printstop { stoptime } {	puts "stop-time $stoptime"}TestSuite instproc printall { fmon } { 	puts "aggregate per-link total_drops [$fmon set pdrops_]"	puts "aggregate per-link total_packets [$fmon set pdepartures_]"}Class Test/stats -superclass TestSuiteTest/stats instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	stats	$self next}Test/stats instproc run {} {	$self instvar ns_ node_ testName_ 	$ns_ delay $node_(s2) $node_(r1) 200ms	$ns_ delay $node_(r1) $node_(s2) 200ms	$ns_ queue-limit $node_(r1) $node_(k1) 10	$ns_ queue-limit $node_(k1) $node_(r1) 10	set slink [$ns_ link $node_(r1) $node_(k1)]; # link to collect stats on	set fmon [$ns_ makeflowmon Fid]	$ns_ attach-fmon $slink $fmon	set stoptime 10.1 	set tcp0 [$ns_ create-connection TCP $node_(s1) TCPSink $node_(k1) 0]	$tcp0 set window_ 30	set tcp1 [$ns_ create-connection TCP $node_(s2) TCPSink $node_(k1) 1]	$tcp1 set window_ 30	set ftp0 [$tcp0 attach-app FTP]	set ftp1 [$tcp1 attach-app FTP]	$ns_ at 1.0 "$ftp0 start"	$ns_ at 1.0 "$ftp1 start"	$self tcpDumpAll $tcp0 5.0 tcp0	$self tcpDumpAll $tcp1 5.00001 tcp1	set almosttime [expr $stoptime - 0.001]	$ns_ at $almosttime "$self printpkts 0 $tcp0"	$ns_ at $almosttime "$self printpkts 1 $tcp1"	$ns_ at $stoptime "$self printdrops 0 $fmon; $self printdrops 1 $fmon"	$ns_ at $stoptime "$self printall $fmon"	# trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace $stoptime $testName_]	$ns_ run}Class Test/stats1 -superclass TestSuiteTest/stats1 instproc init topo {	$self instvar net_ defNet_ test_	set net_	$topo	set defNet_	net0	set test_	stats1	$self next}Test/stats1 instproc run {} {	$self instvar ns_ node_ testName_ 	$ns_ delay $node_(s2) $node_(r1) 200ms	$ns_ delay $node_(r1) $node_(s2) 200ms	$ns_ queue-limit $node_(r1) $node_(k1) 10	$ns_ queue-limit $node_(k1) $node_(r1) 10	set packetSize_ 100	Agent/TCP set packetSize_ $packetSize_	puts "TCP packetSize [Agent/TCP set packetSize_]"	set slink [$ns_ link $node_(r1) $node_(k1)]; # link to collect stats on	set fmon [$ns_ makeflowmon Fid]	$ns_ attach-fmon $slink $fmon	set stoptime 10.1 	set tcp0 [$ns_ create-connection TCP $node_(s1) TCPSink $node_(k1) 0]	$tcp0 set window_ 30	set tcp1 [$ns_ create-connection TCP $node_(s2) TCPSink $node_(k1) 1]	$tcp1 set window_ 30	set ftp0 [$tcp0 attach-app FTP]	set ftp1 [$tcp1 attach-app FTP]	set packets_ftp 10	set bytes_ftp [expr $packets_ftp * $packetSize_]	$ns_ at 1.0 "$ftp0 produce $packets_ftp"	puts "ftp 0 segments_produced $packets_ftp (using `FTP produce pktcnt')"	$ns_ at 1.0 "$ftp1 send $bytes_ftp"	puts "ftp 1 bytes_produced $bytes_ftp (using `FTP send nbytes')"	set almosttime [expr $stoptime - 0.001]	$ns_ at $almosttime "$self printpkts 0 $tcp0"	$ns_ at $almosttime "$self printpkts 1 $tcp1"	$ns_ at $stoptime "$self printdrops 0 $fmon; $self printdrops 1 $fmon"	$ns_ at $stoptime "$self printall $fmon"	# trace only the bottleneck link	$self traceQueues $node_(r1) [$self openTrace $stoptime $testName_]	$ns_ run}TestSuite runTest### Local Variables:### mode: tcl### tcl-indent-level: 8### tcl-default-application: ns### End:

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -