6.4 Commands at a glance
Following is a list of common link commands used in simulation scripts:
$ns_ simplex-link node1 node2 bw delay qtype args
This command creates an unidirectional link between node1 and node2 with
specified bandwidth (BW) and delay characteristics. The link uses a queue
type of <qtype> and depending on the queue type different arguments are
passed through <args>.
$ns_ duplex-link node1 node2 bw delay qtype args
This creates a bi-directional link between node1 and node2. This procedure
essentially creates a duplex-link from two simplex links, one from node1
to node2 and the other from node2 to node1. The syntax for duplex-link is
same as that of simplex-link described above.
$ns_ duplex-intserv-link n1 n2 bw dly sched signal adc args
This creates a duplex-link between n1 and n2 with queue type of intserv, with
specified BW and delay. This type of queue implements a scheduler with two
level services priority. The type of intserv queue is given by <sched>, with
admission control unit type of <adc> and signal module of type <signal>.
$ns_ simplex-link-op n1 n2 op args
This is used to set attributes for a simplex link. The attributes may be
the orientation, color, label, or queue-position.
$ns_ duplex-link-op n1 n2 op args
This command is used to set link attributes (like orientation of the links,
color, label, or queue-position) for duplex links.
$ns_ link-lossmodel lossobj from to
This function generates losses (using the loss model <lossobj> inserted in
the link between <from> node and <to> node) in the link that can be
visualized by nam.
$ns_ lossmodel lossobj from to
This is used to insert a loss module in regular links.
Following is a list of internal link-related procedures:
$ns_ register-nam-linkconfig link
This is an internal procedure used by "$link orient" to
register/update the order in which links should be created in nam.
$ns_ remove-nam-linkconfig id1 id2
This procedure is used to remove any duplicate links (duplicate links may be
created by GT-ITM topology generator).
$link head
Returns the instance variable head_ for the link. The head_ is
the entry pont to the link and it points to the first object in the link.
$link add-to-head connector
This allows the <connector> object to be now pointed by the head_
element in the link, i.e, <connector> now becomes the first object in the
link.
$link link
Returns the instance variable link_. The link_ is the element
in the link that actually models the link in terms of delay and bandwidth
characteristics of the link.
$link queue
Returns the instance variable queue_. queue_ is queue element
in the link. There may be one or more queue elements in a particular link.
$link cost c
This sets a link cost of <c>.
$link cost?
Returns the cost value for the link. Default cost of link is set to 1.
$link if-label?
Returns the network interfaces associated with the link (for multicast routing).
$link up
This sets the link status to "up". This command is a part of network
dynamics support in ns.
$link down
Similar to up, this command marks the link status as "down".
$link up?
Returns the link status. The status is always "up" as default, if link
dynamics is not enabled.
$link all-connectors op
This command applies the specified operation <op> to all connectors in the
link. Like, $link all-connectors reset or
$link all-connectors isDynamic.
$link install-error errmodel
This installs an error module after the link_ element.
In addition to the Link and link-related commands listed above, there are
other procedures to support the specific requirements of different types of
links derived from the base class "Link" like simple-link (SimpleLink),
integrated service (IntServLink), class-based queue (CBQLink), fair queue
(FQLink) and procedures to support multicast routing, sessionsim, nam etc.
These and the above procedures may be found in ns/tcl/lib(ns-lib.tcl,
ns-link.tcl, ns-intserv.tcl, ns-namsupp.tcl, ns-queue.tcl),
ns/tcl/mcast/(McastMonitor.tcl, ns-mcast.tcl),
ns/tcl/session/session.tcl.
Tom Henderson
2014-12-17