[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]

[ns] Problem in the wireless network




I had tried to simulate a wireless network with two mobile nodes and tcp 
connection between them. Now I want to the sequence no. of packets in order, 
transmitted  by the tcp source at intervals of time. I have tried to do 
that but what it showing is some constant value, please explain what 
actually is happening?
 

this the tcl code which iam running
---------------------------------------------------------------------------
# ======================================================================
# Default Script Options
# ======================================================================
set opt(chan)		Channel/WirelessChannel
set opt(prop)		Propagation/TwoRayGround
set opt(netif)		Phy/WirelessPhy
set opt(mac)		Mac/802_11
set opt(ifq)		Queue/DropTail/PriQueue
set opt(ll)		LL
set opt(ant)            Antenna/OmniAntenna
set opt(ifqlen)		50		;# max packet in ifq
set opt(nn)		2		;# number of nodes
set opt(seed)		0.0		;# random no. generation
set opt(stop)		100.0		;# simulation time
set opt(tr)		out0.tr		;# trace file
set opt(cp)		""
set opt(sc)		""
set opt(rp)             dsr            ;# routing protocol script
set opt(lm)             "off"           ;# log movement

# ======================================================================

set AgentTrace			ON
set RouterTrace			ON
set MacTrace			OFF

#link layer values
#LL set mindelay_		50us
LL set delay_			25us
LL set bandwidth_		0	;# not used
LL set off_prune_		0	;# not used
LL set off_CtrMcast_		0	;# not used

# default declaration for src and destination ports
Agent/Null set sport_		0
Agent/Null set dport_		0

Agent/CBR set sport_		0
Agent/CBR set dport_		0

Agent/TCPSink set sport_	0
Agent/TCPSink set dport_	0

Agent/TCP set sport_		0
Agent/TCP set dport_		0
Agent/TCP set packetSize_	1460

Queue/DropTail/PriQueue set Prefer_Routing_Protocols    1

# unity gain, omni-directional antennas

# set up the antennas to be centered in the node and 1.5 meters above it
Antenna/OmniAntenna set X_ 0
Antenna/OmniAntenna set Y_ 0
Antenna/OmniAntenna set Z_ 1.5
Antenna/OmniAntenna set Gt_ 1.0
Antenna/OmniAntenna set Gr_ 1.0

# Initialize the SharedMedia interface with parameters to make
# it work like the 914MHz Lucent WaveLAN DSSS radio interface
Phy/WirelessPhy set CPThresh_ 10.0
Phy/WirelessPhy set CSThresh_ 1.559e-11
Phy/WirelessPhy set RXThresh_ 3.652e-10
Phy/WirelessPhy set Rb_ 2*1e6
Phy/WirelessPhy set Pt_ 0.2818
Phy/WirelessPhy set freq_ 914e+6 
Phy/WirelessPhy set L_ 1.0

# ======================================================================
proc log-movement {} {
    global logtimer ns_ ns

    set ns $ns_
    source ../mobility/timer.tcl
    Class LogTimer -superclass Timer
    LogTimer instproc timeout {} {
	global opt node_;
	for {set i 0} {$i < $opt(nn)} {incr i} {
	    $node_($i) log-movement
	}
	$self sched 0.1
    }

    set logtimer [new LogTimer]
    $logtimer sched 0.1
}

# ======================================================================
# Main Program
# ======================================================================
#
# Initialize Global Variables
#
set ns_		[new Simulator]
set chan	[new $opt(chan)]
set prop	[new $opt(prop)]
set topo	[new Topography]

#for cmu tracing
set tracefd	[open $opt(tr) w]

#for nam tracing 
set fa [open out1.tr w]
set nf 	[open wireless3-out.nam w]
$ns_ namtrace-all-wireless $nf 670 670

proc stop1 {} {
	global ns_ tracefd nf 
	$ns_ flush-trace
	close $tracefd
	close $nf
	close $fa
	exec xgraph out1.tr -geometry 800x400
}
 
$topo load_flatgrid 670 670
$prop topography $topo

#
# Create God
#
set god_ [create-god $opt(nn)]


#
# log the mobile nodes movements if desired
#
if { $opt(lm) == "on" } {
    log-movement
}

#
#  Create the specified number of nodes $opt(nn) and "attach" them
#  the channel.
#  Each routing protocol script is expected to have defined a proc
#  create-mobile-node that builds a mobile node and inserts it into the
#  array global $node_($i)
#

if { [string compare $opt(rp) "dsr"] == 0} { 
	for {set i 0} {$i < $opt(nn) } {incr i} {
		set node$i [dsr-create-mobile-node $i]
	}
} elseif { [string compare $opt(rp) "dsdv"] == 0} { 
	for {set i 0} {$i < $opt(nn) } {incr i} {
		set node$i [dsdv-create-mobile-node $i]
	}
}



#
# Source the Connection and Movement scripts
#
if { $opt(cp) == "" } {
	puts "*** NOTE: no connection pattern specified."
        set opt(cp) "none"
} else {
	puts "Loading connection pattern..."
	source $opt(cp)
}

if { $opt(sc) == "" } {
	puts "*** NOTE: no scenario file specified."
        set opt(sc) "none"
} else {
	puts "Loading scenario file..."
	source $opt(sc)
	puts "Load complete..."
}

#provide initial (X,Y, for now Z=0) coordinates
$node0 set X_ 5.0
$node0 set Y_ 2.0
$node0 set Z_ 0.0

$node1 set X_ 40.0
$node1 set Y_ 41.0
$node1 set Z_ 0.0




#set up traffic flow between nodes
set tcp [new Agent/TCP/Reno]
$tcp set window_ 25
$tcp set class_ 2
 set sink [new Agent/TCPSink]
$ns_ attach-agent $node0 $tcp
$ns_ attach-agent $node1 $sink
$ns_ connect $tcp $sink


proc record {} {
	global tcp fa
	set ns_ [Simulator instance]
	set time 1
	set noofbytes [$tcp set t_seqno_]
	set now [$ns_ now]
	puts $fa  "$now $noofbytes"
	$ns_ at [expr $now+$time] "record"
}


set ftp [new Application/FTP]
$ftp attach-agent $tcp
$ns_ at 0.0 "$ftp start"


#
# Tell all the nodes when the simulation ends
#
for {set i 0} {$i < $opt(nn) } {incr i} {
    $ns_ at $opt(stop).000000001 "$node_($i) reset";
}
$ns_ at $opt(stop).00000001 "puts \"NS EXITING...\" ; $ns_ halt"
$ns_ at $opt(stop) "stop1"


puts $tracefd "M 0.0 nn $opt(nn) x 670 y 670 rp $opt(rp)"
puts $tracefd "M 0.0 sc $opt(sc) cp $opt(cp) seed $opt(seed)"
puts $tracefd "M 0.0 prop $opt(prop) ant $opt(ant)"

$ns_ at 0.0 "record"
puts "Starting Simulation..."
$ns_ run