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

📄 util.tcl

📁 对IEEE 802.11e里的分布式信道接入算法EDCA进行改进
💻 TCL
字号:
# scheduling disciplines for Agent/TCP/Sessionset FINE_ROUND_ROBIN 1set COARSE_ROUND_ROBIN 2set RANDOM 3# configure RED parametersQueue/RED set setbit_ trueQueue/RED set drop_tail_ falseQueue/RED set fracthresh_ trueQueue/RED set fracminthresh_ 0.15Queue/RED set fracmaxthresh_ 0.6Queue/RED set q_weight_ 0.01Queue/RED set wait_ falseQueue/RED set linterm_ 10#Queue/RED set linterm_ 5Queue set interleave_ falseQueue set acksfirst_ falseQueue set filteracks_ falseQueue set replace_head_ falseQueue set ackfromfront_ falseQueue set priority_drop_ falseQueue set random_drop_ falseAgent/TCP set disable_ecn_ 0Agent/TCP set restart_bugfix_ trueAgent/TCP/Fack set ss-div4 0Agent/TCP/Fack set rampdown 0Agent/TCP set timestamps_ trueAgent/TCP set fast_loss_recov_ trueAgent/TCP set fast_reset_timer_ trueAgent/TCP set count_bytes_acked_ trueAgent/TCP set windowOption_ 0Agent/TCP/Int set rightEdge_ 0Agent/TCP/Int set uniqTS_ 1Agent/TCP/Int set winInc_ 1Agent/TCP/Int set winMult_ 0.5Agent/TCP/Session set ownd_ 0Agent/TCP/Session set owndCorr_ 0Agent/TCP/Session set proxyopt_ falseAgent/TCP/Session set fixedIw_ falseAgent/TCP/Session set count_bytes_acked_ falseAgent/TCP/Session set schedDisp_ $FINE_ROUND_ROBINAgent/TCP/Session set fs_enable_ falseAgent/TCP/Session set disableIntLossRecov_ falseAgent/TCP/Newreno/FS set fs_enable_ falseAgent/TCPSink set ts_echo_bugfix_ trueproc processtrace { midtime turnontime turnofftime { qtraceflag false } { dir "." } } {	exec gawk --lint -v dir=$dir -f ../../../ex/asym/tcp-trace.awk $dir/tcp-raw.tr	exec gawk --lint -v dir=$dir -f ../../../ex/asym/seq.awk $dir/out.tr	exec gawk --lint -v dir=$dir -v mid=$midtime -v turnon=$turnontime -v turnoff=$turnofftime -f ../../../ex/asym/tcp.awk $dir/tcp.tr	exec gawk --lint -v dir=$dir -f ../../../ex/asym/tcp-burst.awk $dir/tcp.tr	if { $qtraceflag } {		exec gawk --lint -f ../../../ex/asym/queue.awk $dir/q.tr	}}	proc plotgraph {graph connGraphFlag midtime turnontime turnofftime { qtraceflag false } { dir "." } } {	global env	upvar $connGraphFlag graphFlag	set if [open seq-index.out r]	while {[gets $if i] >= 0} {		if {$graph || $graphFlag($i)} {			set seqfile [format "%s/seq-%s.out" $dir $i]			set ackfile [format "%s/ack-%s.out" $dir $i]			exec xgraph -display $env(DISPLAY) -bb -tk -m -x time -y seqno $seqfile $ackfile &		}	}	close $if	set if [open index.out r]	while {[gets $if i] >= 0} {		if {$graph || $graphFlag($i)} {			set cwndfile [format "%s/cwnd-%s.out" $dir $i]			set ssthreshfile [format "%s/ssthresh-%s.out" $dir $i]			set owndfile [format "%s/ownd-%s.out" $dir $i]			set owndcorrfile [format "%s/owndcorr-%s.out" $dir $i]			set srttfile [format "%s/srtt-%s.out" $dir $i]			set rttvarfile [format "%s/rttvar-%s.out" $dir $i]			set cwnd_meaningful [exec gawk {BEGIN {flag=0;} {if (NR > 2 && $2 != 1) {flag=1; exit;}} END {print flag;}} $cwndfile]			if {$cwnd_meaningful == 1} {				exec xgraph -display $env(DISPLAY) -bb -tk -m -x time -y window $cwndfile $owndfile $owndcorrfile &			}		}	}	close $if	if { $qtraceflag } {		set qif [open qindex.out r]		while {[gets $qif i] >= 0} {			exec xgraph -display $env(DISPLAY) -bb -tk -m -x time -y "# packets" $i &		}		close $qif	}}proc monitor_queue {ns n0 n1 queuetrace sampleInterval} {	if {$queuetrace == 0} {		return	}	set id0 [$n0 id]	set id1 [$n1 id]	set l01 [$ns set link_($id0:$id1)]	$ns monitor-queue $n0 $n1 $queuetrace $sampleInterval	$l01 set qBytesEstimate_ 0	$ns at [$ns now] "$l01 queue-sample-timeout"}proc trace_queue {ns n0 n1 queuetrace} {	set id0 [$n0 id]	set id1 [$n1 id]	set l01 [$ns set link_($id0:$id1)]	$ns monitor-queue $n0 $n1 $queuetrace	$ns at [$ns now] "$l01 start-tracing"}proc createTcpSource { type { maxburst 0 } { tcpTick 0.1 } { window 100 } { slow_start_restart false } { fs_enable false } {ssthresh 0} {flr true} {frt true} } {	set tcp0 [new Agent/$type]	$tcp0 set class_ 1	$tcp0 set maxburst_ $maxburst	$tcp0 set tcpTick_ $tcpTick	$tcp0 set window_ $window	$tcp0 set maxcwnd_ $window	$tcp0 set ecn_ 1	$tcp0 set g_ 0.125	$tcp0 set slow_start_restart_ $slow_start_restart	if {$fs_enable} {		$tcp0 set fs_enable_ $fs_enable	}	if {$ssthresh > 0} {		$tcp0 set ssthresh_ $ssthresh	}	$tcp0 set fast_loss_recov_ $flr	$tcp0 set fast_reset_timer_ $frt	return $tcp0} proc enableTcpTracing { tcp tcptrace } {	if {$tcptrace == 0} {		return	}	$tcp attach $tcptrace	$tcp trace "t_seqno_" 	$tcp trace "rtt_" 	$tcp trace "srtt_" 	$tcp trace "rttvar_" 	$tcp trace "backoff_" 	$tcp trace "dupacks_" 	$tcp trace "ack_" 	$tcp trace "cwnd_"	$tcp trace "ssthresh_" 	$tcp trace "maxseq_" 	$tcp trace "seqno_"#	$tcp trace "exact_srtt_"#	$tcp trace "avg_win_"	$tcp trace "nrexmit_"}proc setupTcpTracing { tcp tcptrace { sessionFlag false } } {	if {$tcptrace == 0} {		return	}	enableTcpTracing $tcp $tcptrace	if { $sessionFlag } {		set dst [$tcp set dst_addr_]		set session [[$tcp set node_] createTcpSession $dst]		enableTcpTracing $session $tcptrace		$session trace "ownd_"		$session trace "owndCorr_"	}}proc setupGraphing { tcp connGraph connGraphFlag {sessionFlag false} } {	upvar $connGraphFlag graphFlag	set saddr $tcp set agent_addr_]	set sport [$tcp set agent_port_]	set daddr [$tcp set dst_addr]	set dport [$tcp set dst_port_]	set conn [format "%d,%d-%d,%d" $saddr $sport $daddr $dport]	set graphFlag($conn) $connGraph	if { $sessionFlag } {		set dst [expr ([$tcp set dst_addr]		set session [[$tcp set node_] createTcpSession $dst]		set sport [expr [$session set agent_port_]		set dport 0		set conn [format "%d,%d-%d,%d" $saddr $sport $daddr $dport]		set graphFlag($conn) $connGraph	}}proc createTcpSink { type {sinktrace 0} { ackSize 40 } { maxdelack 25 } } {	set sink0 [new Agent/$type]	$sink0 set packetSize_ $ackSize	if {[string first "Asym" $type] != -1} { 		$sink0 set maxdelack_ $maxdelack	}	if {$sinktrace != 0} {		$sink0 attach $sinktrace	}	return $sink0}proc setupTcpSession { tcp { count_bytes_acked false } { schedDisp $FINE_ROUND_ROBIN} {fs_enable false} {disableIntLossRecov false} } {	set dst [$tcp set dst_addr_]	if {![[$tcp set node_] existsTcpSession $dst]} {		set session [[$tcp set node_] createTcpSession $dst]		$session set maxburst_ [$tcp set maxburst_]		$session set slow_start_restart_ [$tcp set slow_start_restart_]		$session set fs_enable_ $fs_enable		$session set restart_bugfix_ [$tcp set restart_bugfix_]		$session set packetSize_ [$tcp set packetSize_]		$session set ecn_ [$tcp set ecn_]		$session set window_ [$tcp set window_]		$session set maxcwnd_ [$tcp set maxcwnd_]		$session set count_bytes_acked_ $count_bytes_acked		$session set schedDisp_ $schedDisp		$session set disableIntLossRecov_ $disableIntLossRecov		return true	}	return false}		proc createFtp { ns n0 tcp0 n1 sink0 } {	$ns attach-agent $n0 $tcp0	$ns attach-agent $n1 $sink0	$ns connect $tcp0 $sink0	set ftp0 [new Source/FTP]	$ftp0 attach $tcp0	return $ftp0}proc configQueue { ns n0 n1 type {qtrace 0} { size -1 } { nonfifo 0 } { acksfirst false } { filteracks false } { replace_head false } { priority_drop false } { random_drop false } { random_ecn false } { reconsacks false } } { # proc configQueue { ns n0 n1 type qtrace rtrace { size -1 } { nonfifo 0 } { acksfirst false } { filteracks false } { replace_head false } { priority_drop false } { random_drop false } { reconsacks false } }  	if { $size >= 0 } {		$ns queue-limit $n0 $n1 $size	}	set id0 [$n0 id]	set id1 [$n1 id]	set l01 [$ns set link_($id0:$id1)]	set q01 [$l01 set queue_]	if {$nonfifo} {		set spq [new PacketQueue/Semantic]		$spq set acksfirst_ $acksfirst		$spq set filteracks_ $filteracks		$spq set replace_head_ $replace_head		$spq set priority_drop_ $priority_drop		$spq set random_drop_ $random_drop		$spq set random_ecn_ $random_ecn		if { $reconsacks == "true"} {			set recons [new AckReconsControllerClass]			# Set queue_ of controller.  This is 			# used by the individual reconstructors			$recons set queue_ $q01			$spq set reconsAcks_ 1			$spq ackrecons $recons		}		$q01 packetqueue-attach $spq	}#	if {[string first "RED" $type] != -1} {#		configREDQueue $ns $n0 $n1 [$q01 set q_weight_] 1#	}#	$q01 trace $trace#	if { $qtrace != 0 } {	trace_queue $ns $n0 $n1 $qtrace#	}	$q01 reset}proc configREDQueue { ns n0 n1 { redtrace } { q_weight -1 } { fracthresh 0 } { fracminthresh 0.4 } { fracmaxthresh 0.8} } {	set id0 [$n0 id]	set id1 [$n1 id]	set l01 [$ns set link_($id0:$id1)]	set q01 [$l01 set queue_]	if {$redtrace != 0} {		$q01 attach $redtrace	}	if {$q_weight >= 0} {		$q01 set q_weight_ $q_weight	}	if { $fracthresh } {		set lim [$q01 set limit_]		$q01 set thresh_ [expr $fracminthresh*$lim]		$q01 set maxthresh_ [expr $fracmaxthresh*$lim]	}	$q01 set setbit_ true}

⌨️ 快捷键说明

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