NetSim Guide for Network Modelers
NetSim Guide for Network Modelers
Contents
1
2.1.2
2.1.3
Basics ............................................................................................................................. 18
2.1.4
Utilities .......................................................................................................................... 19
2.1.5
Help ............................................................................................................................... 19
2.2.2
2.2.3
2.2.4
2.2.5
Simulation .................................................................................................................... 24
2.3 Network Opening, Saving, Deleting scenarios and Printing results ......................................... 25
2.3.1
2.3.2
Saving an Experiment.................................................................................................... 28
2.3.3
2.4 Adding and deleting users (Not present in Pro version) ............................................................. 31
2.4.1
2.4.2
Deleting User................................................................................................................. 34
New Experiment............................................................................................................ 35
3.1.2
3.1.3
3.1.4
3.1.5
3.1.6
3.1.7
3.1.8
New Experiment............................................................................................................ 50
3.2.2
3.2.3
3.2.4
3.2.5
3.2.6
New Experiment............................................................................................................ 52
3.3.2
3.3.3
3.3.4
3.3.5
3.3.6
Enable Packet Trace, Event Trace & Dynamic Metrics (Optional) ................................ 54
3.3.7
New Experiment............................................................................................................ 55
3.4.2
3.4.3
3.4.4
3.4.5
Enable Packet Trace, Event Trace & Dynamic Metrics (Optional) ................................ 56
3.4.6
3.5 MPLS............................................................................................................................................ 58
3.5.1
New Experiment............................................................................................................ 58
3.5.2
3.5.3
3.5.4
3.5.5
New Experiment............................................................................................................ 60
3.6.2
3.6.3
3.6.4
Enable Packet Trace, Event Trace & Dynamic Metrics (Optional) ................................ 61
3.6.5
New Experiment............................................................................................................ 62
3.7.2
3.7.3
3.7.4
3.7.5
3.7.6
New Experiment............................................................................................................ 67
3.8.2
3.8.3
3.8.4
3.8.5
3.8.6
3.8.7
New Experiment............................................................................................................ 72
3.9.2
3.9.3
3.9.4
Enable Packet Trace, Event Trace & Dynamic Metrics (Optional) ................................ 73
3.9.5
New Experiment............................................................................................................ 75
3.10.2
3.10.3
3.10.4
Enable Packet Trace, Event Trace & Dynamic Metrics (Optional) ................................ 76
3.10.5
3.11.1
New Experiment............................................................................................................ 77
3.11.2
3.11.3
3.11.4
3.11.5
3.11.6
3.11.7
5.2.1
5.2.2
6.8.1
6.8.2
6.8.3
6.8.4
7.1.2
7.1.3
7.1.4
7.2.2
7.2.3
7.3.2
7.3.3
9.2.2
9.2.3
9.5.2
9.5.3
9.5.4
9.5.5
9.5.6
9.5.7
9.5.8
9.5.9
9.5.10
9.5.11
9.5.12
9.5.13
9.5.14
9.5.15
9.5.16
9.5.17
9.5.18
9.5.19
9.5.20
Error Detection Code - Cyclic Redundancy Check (CRC) CCITT ................................ 236
9.5.21
9.5.22
9.5.23
9.5.24
9.5.25
9.5.26
9.5.27
9.5.28
9.5.29
9.5.30
9.5.31
9.5.32
9.5.33
9.5.34
9.5.35
9.5.36
9.5.37
9.5.38
9.5.39
9.5.40
9.5.41
9.5.42
9.5.43
9.5.44
9.5.45
9.5.46
9.5.47
9.5.48
9.5.49
9.5.50
9.5.51
9.5.52
9.5.53
9.5.54
9.5.55
9.5.56
9.5.57
9.5.58
10
10.2.1
10.2.2
10.3.2
10.3.3
10.3.4
10.3.5 Example Application 5 JPerf Network performance measurement graphical tool (One
way Communication) .................................................................................................................. 397
11
11.1.2
11.1.3
11.1.4
11.1.5
11.2.2
11.2.3
11.2.4
Simulation terminates and NetSim Backend has stopped working displayed: ....... 406
11.3.2
11.5.2
11.5.3 Emulation closed, yet clients are sending network packets to NetSim Emulation Server
IP Address.................................................................................................................................... 410
12
1 NetSim Introduction
1.1 Introduction to modeling and simulation of networks
A network simulator enables users to virtually create a network along with its components
such as devices, links, and applications etc. to study the behavior and performance of the
Network.
Some examples of applications of network simulators are
Building the model Create a network scenario with devices, links, applications etc
Running the simulation - Run the discrete event simulation (DES) and log different
performance metrics
Visualizing the simulation- Use a packet animator to view the flow of packets
Explorer
Academic
Standard
Pro
Basics
Understand networking concepts using
more than 400 animations
Performance Reporting
Performance metrics available for
Network and Sub-network
Packet Animator
Used to animate the packet flow in
network
Packet Trace and Event Trace
Available in tab ordered .txt format for
easy post processing
Protocol Library Source Codes with
Documentation
Protocol C source codes and appropriate
header files with extensive documentation
Wireshark Interface
Capture NetSim simulation packets using
wire-shark
10
Integrated debugging
Users can write their own code, link their
code to NetSim and debug using Visual
Studio
Dynamic Metrics
Allows users to plot the value of a
parameter over simulation time
Emulator (Add on)
Connect to real hardware running live
application
Target Users and Pricing
Student
Educational
Educational
Commercial
11
Component No
Component 1
(Base.
Required for
all
components)
Networks / Protocols
International Standards
Internetworks
Ethernet - Fast & Gigabit
Address Resolution Protocol
WLAN - 802.11 a, b, g , n, ac and e
Propagation - Free space, Log-normal
Shadowing, Rayleigh Fading
IP v4 with VPN
Firewalls
Routing - RIP, OSPF
Queuing - Round Robin, FIFO, Priority
TCP, UDP
IEEE 802.3
RFC 826
802.11 a/b/g/n/ac/e
RFC 2453,2328
RFC's 793, 2001 and 768
Common Modules
Applications (Traffic Generator): Voice,
Video, FTP, Database, HTTP, Email,
Peer-to-peer and Custom
Virtual Network Stack
Simulation Kernel
Command Line Interface
Metrics Engine with packet and event
trace
Packet Animator
Component 2
Legacy Networks
Aloha - Pure & Slotted
CSMA/CD
Token ring
Token bus
ATM
X.25
Frame Relay
Real Time (Frame Capture)
Multi-Protocol Label Switching (MPLS)
Component 3
BGP Networks
Border Gateway Protocol (BGP)
12
IEEE 802.3
IEEE 802.4
IEEE 802.5
ATM Forum
ITU Forum
IETF RFC 3031
Component 4
Component 5
Cellular Networks
GSM
CDMA
(Component 4
required)
Component 7
IEEE 802.22
Component 8
3GPP
Military Radio
TDMA Link 16
----
Component 6
Component 9
(Component 4
required)
13
Dynamic Metrics enables users to plot the value of a parameter over simulation time.
GSM and CDMA have been integrated with NetSim's virtual stack. Users can now
model the mobile switching center (MSC) also.
BGP integration with stack: BGP protocol has been integrated with NetSim's virtual
network stack
NetSim's C source code is now based on Doxygen, the de facto standard tool for
generating source code help
The wireless suite covered in NetSim is 802.11 a, b, g, n and 802.11 ac (Gigabit WiFi)
P2P (bit-torrent), HTTP and E-Mail application models have been added
The IP layer of Inter Network component of NetSim now includes VPN, Firewall
and ICMP
Router to router links now support data rates upto 100 Gbps
Visual studio based solution files for very easy custom code development
Start time and end time can be now set for any application
The icons of all the devices and the link design can be modified.
14
In Pro Version
Displays all the Help related to NetSim. Help covers
Simulation Experiments also.
Opens the Simulation menu consisting of New, Open and Delete. User can simulate,
Internetworks, Legacy, Cellular, BGP, Advanced Wireless Networks, Wireless Sensor
Networks, Cognitive Radio Networks and LTE Networks
15
16
Upon selection, the following screen will appear. Please refer Section 9 for detailed help.
Using the User mode users can link and run their
own source code.
17
2.1.3 Basics
In this menu, various network concepts are explained using animations. Note: This menu is
available only in Academic and Explorer Version.
18
2.1.4 Utilities
This menu contains the following options,
Login As - This option is used to log in with another user account. This can be done
based on the access provided.
User Accounts - This option is used to Add or Delete user accounts. Also, password
and mode of the users can be changed. Also experiments can be deleted.
2.1.5 Help
This menu contains all the Help related to NetSim.
NetSim User Manual - It contains the documentation about the working of NetSim.
NetSim Source Code Help It contains the documentation about network protocol source
code (Available with NetSim Standard as well as Pro Version)
NetSim Experiment Manual It contains selected experiments which can be performed in
NetSim.
Shortcut Keys it contains shortcut keys for all menus and sub menus.
19
20
21
can
set
values
according to requirement.
In above scenario, default
values already present in the
properties are accepted.
22
In above scenario, default values already present in the properties are accepted. The
Source_Id is 2 and Destination_Id is 5. Click on Accept.
23
2.2.5 Simulation
For simulating the network scenario created, click on Run
Simulation present in the Ribbon
24
Click on Browse and select the configuration file you want to open
Select the User (Note: This option is available in Admin login only)
Select the Protocol(Note: Protocols present under Legacy Network will be displayed)
25
Click on Browse and select the Metrics.txt file (present with the saved experiment) you want
to open
26
Select the User (Note: This option is available in Admin login only)
Select the Protocol(Note: Protocols present under Legacy Network will be displayed)
27
Step 2: Specify the Experiment Name and Save Path and click on OK
Step 2: Specify the Experiment Name and Save Path and click on OK
28
To delete Experiments the user needs to follow the below given steps,
Click the Delete/Delete All button to enter into the next window.
Delete Click the Delete button to delete single experiment.
Delete All Click the Delete All button to delete all the saved experiments.
29
After clicking on the Delete button a message appears which says Are you
sure you want to delete this Experiment(s)? Click on Yes to continue
deleting the Experiment(s), else click on No to cancel deleting.
Click on OK button in the The experiment is deleted or The
experiments have been deleted window.
Note:
Admin User: An option called User Name is available only in when the User has
logged into Admin. This option can be made use for deleting experiments under
any User.
Local User: A User who has a normal privilege other than Admin can delete
experiments only which are created by that particular user.
30
Add User - This button is used for creating new users. The following fields have to be
filled in,
o Username - Name of the new user needs to be entered in the field provided.
o Password The password for the user should be provided.
o Category - By default student is selected.
o Mode - Either Practice / Exam mode needs to be selected.
o Click on Accept / Cancel button to accept / cancel the changes.
Delete User - This button is used for deleting the existing users.
Change Password - This button is used to change the password of the user which is
selected currently in the left side of the User Accounts. Administrator can change the
password of all the users, whereas other user (other than Administrator) can change
his/her password only.
Experiment Deletion Section: This section is used to delete the saved experiments in
NetSim. Administrator can delete the saved experiments of all the users, whereas other
user (other than Administrator) can delete his/her saved experiments only.
31
Note: Experiment Deletion Section can be used to delete the saved experiments in
Legacy Networks and MPLS. Saved experiments in Internetworks, BGP Networks,
Advanced Wireless Networks MANET and Fixed Wi-Max, Wireless Sensor
Networks, Personal Area Networks, Cellular Networks, LTE Networks and Cognitive
Radio Networks cannot be deleted through Experiment Deletion Section since these
experiments are saved as configuration files in user specified locations.
Select Admin present inside Add and Delete User panel and then click on Add User
Add User Name and Password, select the Mode of your choice.
32
33
34
Select the appropriate link in the toolbar and connect the devices by
clicking on the device 1 and device 2.
35
Right click on the appropriate node or link and select Properties. Then modify the
parameters according to the requirements.
Select the Application Button on the ribbon and click on the empty region between the
Grid Environment and the ribbon. Now right click on Application and select Properties.
Multiple applications can be generated by using add button in Application properties.
36
If you create a network with two wired nodes and a switch, the IP addresses are assigned as
10.0.1.2 and 10.0.1.3 for the two wired nodes. The default subnet mask is assigned to be
255.255.0.0. It can be edited to 255.0.0.0 (Class A) or 255.255.255.0 (Class C) subnet masks.
Both the nodes are in the same network (10.0.0.0).
Similarly, if you create a network with a router and two wired nodes, the IP addressed are
assigned as 11.1.1.2 and 11.2.1.2 for the two wired nodes. The subnet mask is default as in
above case, i.e., 255.255.0.0. The IP address of the router is 11.1.1.1 and 11.2.1.1
37
respectively for the two interfaces. Both the nodes are in different networks (11.1.0.0 and
11.2.0.0) in this case.
38
Path loss can be represented by the path loss exponent, whose value is normally in the range
of 2 to 4, where 2 is for propagation in free space.
In NetSim, the default value for path loss exponent is taken as 2.
Path loss is usually expressed in dB. In its simplest form, the path loss can be calculated
using the formula
L=10log (d0/d)
Where L is the path loss in decibels, is the path loss exponent and d is the distance between
transmitter and the receiver, usually measured in meters.
A simplified formula for the path loss between two isotropic antennas in free space:
L (in dBm) = 20log10 (4d0/)
Where L is the path loss in decibels, _ is the wavelength and d is the transmitter-receiver
distance in the same units as the wavelength.
The code for calculating the Path loss is included in the function
fn_NetSim_WLAN_CalculateReceivedPower, which is present in the file 802_11_PHY.c,
path for the file is NetSim Standard\src\Simulation\WLAN.
3.1.7.2.2 Shadowing
Slow shadowing in wireless network is the attenuation caused by buildings or any obstacles
between a transmitter and a receiver. In the model with shadowing, the shadowing value X
typically defined in dB, is added to (or subtracted from) the average received power zero
means Gaussian distributed random variable with standard deviation. The default value for
standard deviation is chosen as 5 dB.
The code for calculating the shadow loss is present in file 802_11_PHY.c, path for the file is
NetSim Standard\src\Simulation\WLAN.
3.1.7.2.3 Fading
In wireless communications, fading is deviation of the attenuation affecting a signal over
certain propagation media. The fading may vary with time, geographical position or radio
frequency, and is often modelled as a random process.
39
In NetSim, the Rayleigh Fading, which follows Rayleigh Probability Distribution with mean
of 1, is used. The code for calculating fading loss is present in the file 802_11_PHY.c, path
for the file is NetSim Standard\src\Simulation\WLAN.
The interference power is the difference between the total power received by the receiver and
the power received from one particular transmitter.
The code for calculating SNR and implementation of SNR vs. BER is included in the
function fn_NetSim_WLAN_802_11x_BER of the file 802_11_x.c (where x=a, b, g and n),
you can find it in the following path NetSim Standard\src\Simulation\WLAN.
40
(Reference: From Page 221 Digital Communications by Bernard Sklar 2nd Edition)
41
BER
10 -1
10
-2
10
-3
5.5CCK
11CCK
TextEnd
10 -4
10
-5
10
-6
5
Eb/No
10
(Reference: Higher Rate 802.11b: Double the Data Rate Chris Heegard, Matthew Shoemake & Sid
Schrum Doc: IEEE 802.11-00/091)
(Reference: BER Comparison of M-ary QAM by Mukthar Hussain MATLAB File Exchange)
42
BPSK
QPSK
7.00E-02
6.00E-02
5.00E-02
4.00E-02
2.50E-02
1.50E-02
1.00E-02
9.50E-03
9.00E-03
7.00E-03
5.00E-03
2.50E-03
1.50E-03
8.50E-04
7.00E-04
2.00E-04
9.00E-05
6.00E-05
3.00E-05
1.50E-05
1.00E-06
1.00E-07
1.00E-08
1.00E-09
1.00E-09
1.00E-09
1.00E-09
2.50E-01
2.45E-01
2.40E-01
2.35E-01
2.25E-01
2.15E-01
2.05E-01
1.95E-01
1.85E-01
1.75E-01
1.65E-01
1.55E-01
1.45E-01
1.35E-01
1.25E-01
1.15E-01
9.50E-01
8.75E-02
7.50E-02
6.50E-02
5.00E-02
2.50E-02
1.50E-02
9.50E-03
7.00E-03
2.00E-03
1.00E-06
16QAM
1.50E-01
1.35E-01
1.15E-01
1.00E-01
9.50E-02
9.00E-02
8.00E-02
7.00E-02
6.00E-02
5.00E-02
4.00E-02
3.00E-02
2.00E-02
1.00E-02
9.50E-03
8.00E-03
6.50E-03
5.00E-03
3.50E-03
2.00E-03
1.00E-03
7.00E-04
3.00E-04
1.00E-05
1.00E-06
1.00E-07
1.00E-07
43
64QAM
1.75E-01
1.70E-01
1.65E-01
1.60E-01
1.50E-01
1.40E-01
1.30E-01
1.20E-01
1.10E-01
1.00E-01
9.80E-02
9.20E-02
8.40E-02
7.60E-02
6.80E-02
6.00E-02
5.00E-02
4.00E-02
3.00E-02
2.50E-02
9.50E-03
6.50E-03
3.50E-03
9.50E-04
7.00E-04
3.50E-04
1.00E-05
5.5 CCK
4.50E-01
4.50E-01
1.75E-01
1.75E-01
9.50E-02
9.50E-02
4.50E-02
4.50E-02
9.50E-03
9.50E-03
6.00E-03
6.00E-03
1.50E-03
1.50E-03
6.00E-04
6.00E-04
7.00E-05
7.00E-05
7.00E-06
7.00E-06
8.00E-07
9.50E-08
2.50E-09
1.00E-10
1.00E-10
1.00E-10
1.00E-10
11 CCK
5.50E-01
5.50E-01
2.75E-01
2.75E-01
1.50E-01
1.50E-01
8.50E-02
8.50E-02
3.50E-02
3.50E-02
6.00E-03
6.00E-03
1.50E-03
1.50E-03
6.50E-04
6.50E-04
9.50E-05
9.50E-05
1.50E-06
1.50E-06
1.50E-07
5.50E-08
9.50E-09
1.00E-10
1.00E-10
1.00E-10
1.00E-10
In 802.11n, a single block acknowledgement is sent for the entire A-MPDU. The block ack
acknowledges each packet that is received. It consists of a bitmap(compressed bitmap) of
64bits or 8 bytes. This bitmap can acknowledge upto 64 packets, 1bit for each packet. The
value of a bitmap field is 1 if respective packet is received without error else it is 0. Only the
error packets are resent until a retry limit is reached. The number of packets in an A-MPDU
is restricted to 64 since the size of block ack bitmap is 64bits.
44
A user can vary the number of packets to aggregate by changing the appropriate
parameters in the GUI.
NetSim ignores the padding bytes added to the MPDU since its effect is negligible.
NetSim aggregates packets to the same receiver id and not to the destination ID.
Packets arriving from the NETWORK Layer gets queued up in an access buffer from which
they are sorted according to their priority in the respective QOS buffer according to the IEEE
802.11e standard. An event MAC_OUT with SubEvent CS (Carrier Sense CSMA) is
added to check if the medium is free
In CS, if the medium is free, then the NAV is checked. This is enabled if RTS/CTS
mechanism is enabled which can be done so by adjusting the RTS Threshold. If the
45
Present_Time>NAV, then an Event MAC_OUT with SubEvent DIFS End is added at the
time Present_Time + DIFS time.
The medium is checked at the end of DIFS time period and a random time BackOff is
calculated based on the Contention Window (CW). An Event MAC_OUT with SubEvent
Backoff is added at time Present_Time + BackOff Time.
Once Backoff is successful, NetSimstarts the transmission process wherein it gets the
aggregated packet from the QOS buffer and stores it in the Retransmit buffer. If the A-MPDU
size is > RTS Threshold, then it enables RTS/CTS mechanism which is an optional feature.
NetSim sends the packet by calling the PHY_OUT Event with SubEventAMPDU_Frame.
Note that the implementation of A-MPDU is in the form of a linked list.
46
Whenever a packet is transmitted, the medium is made busy and a Timer Event with
SubEvent Update Device Status is added at the transmission end time to set the medium again
as idle.
802.11n
802.11ac
Spatial Streams
Up to 4 streams
Up to 8 streams
MIMO
Multi-User MIMO
20 and 40 MHz
BPSK, QPSK,
Channel
Bandwidth
Modulation
Max Aggregated
Packet Size
1048576 octets
47
MAC layer improvements include only the increment of number of aggregated packets from
64 to 1024. The MCS index for different modulation and coding rates
MCS Index
Modulation
Code Rate
BPSK
1/2
QPSK
1/2
QPSK
3/4
16QAM
1/2
16QAM
3/4
64QAM
2/3
64QAM
3/4
64QAM
5/6
256QAM
3/4
256QAM
5/6
Receiver sensitivity for different modulation schemes in 802.11ac (for a 20MHz Channel
bandwidth)
MCS Index
-82
-79
-77
-74
-70
-66
-65
-64
-59
-57
48
PHY Standard
Subcarriers
802.11n/802.11ac 20MHz
x1.0
802.11n/802.11ac 40MHz
x2.1
802.11n/802.11ac 80MHz
x4.5
802.11n/802.11ac 160MHz
x9.0
20MHz in 802.11ac
Now with the knowledge of MCS index and bandwidth of the channel data rate is set in the
following manner
Step1: Get the number subcarriers that are usable for the given bandwidth of the medium.
Step2: Get the Number of Bits per Sub Carrier (NBPSC) from selected MCS
Step3: Number of Coded Bits Per Symbol (NCBPS) = NBPSC*Number of Subcarriers
Step4: Number of Data Bits Per Symbol (NDBPS) = NCBPS*Coding Rate
Step5: Physical level Data Rate = NDBPS/Symbol Time (4micro sec for long GI and 3.6
micro sec for short GI)
49
Click on the Node icon in the tool bar and click and drop inside the grid. (Note: This is
applicable for Pure Aloha and Slotted Aloha)
Adding Hub:
Click on the Hub icon in the tool bar and click it onto the environment. By default a Hub
has eight ports. (Note: This is applicable for Traditional Ethernet and Token Bus)
Adding Concentrator:
Click on the Concentrator icon in the tool bar and click it onto the environment. By
default a Concentrator consists of eight ports. (Note: This is applicable for Token Ring)
Click on the CPE icon in the tool bar, click and drop the CPE on the environment. (Note:
This is applicable for ATM, X.25 and Frame Relay)
Switch to Switch.
(Note: Depending upon the simulation, choose either ATM Switch or X.25 Switch or Frame
Relay Switch)
Set Node Properties or CPE Properties
Right Click on the appropriate node or CPE and select Properties
Set the Properties for the devices and links
Right click over the devices and then select Properties to set the properties of the links and
the devices
Wireless
Networks
MANET
Click on the Node icon in the tool bar, select Wireless Node and click
and drop it inside the grid. (Note: A Node cannot be placed on another
Node. A Node cannot float outside of the grid.)
Adding Base Station and Subscriber (Note: This is applicable for WiMAX)
Click on the Base Station icon in the tool bar and click it onto the
environment.
Click on the Wi-Max Subscriber icon in the tool bar and click and
drop it onto the environment.
Right click on the appropriate Wireless Node to select Properties. (Note: This is
applicable for MANET)
Right click on the Base Station (BS) and set Properties. (Note: This is applicable for
Wi-MAX)
52
Right Click on the appropriate Wi-Max Subscriber to select Properties. (Note: This is
applicable for Wi-MAX)
Right click on the Environment and click Properties. (Note: This is applicable for
MANET)
Right click on the appropriate node or link and select Properties. Then modify the
parameters according to the requirements.
Select the Application Button on the ribbon and click on the empty region between the
Grid Environment and the ribbon. Now right click on Application and select Properties.
Multiple applications can be generated by using add button in Application properties.
53
3.3.6 Enable Packet Trace, Event Trace & Dynamic Metrics (Optional)
Click Packet Trace / Event Trace icon in the tool bar. Set the name and path and select the
required attributes. To get detailed help, please refer section 6.5, 6.6 and 6.3 respectively.
Select Dynamic Metrics icon for enabling Dynamic Metrics and click OK.
54
3.4 BGP
3.4.1 New Experiment
In the Simulation menu select Simulation New
BGP Networks
Click and drop the Border Router icon from the tool bar. (Note: Maximum you can
have 3 Autonomous systems in a single scenario.)
Click on the Internal Router icon in the tool bar and drop the Internal Router onto the
Autonomous systems created. By default a Router has eight ports.
Establishing Connections
The steps for connecting devices in BGP networks are as follows,
The connections between two wired nodes cannot be made in the network.
Right click on the appropriate node or link and select Properties. Then modify the
parameters according to the requirements.
Select the Application Button on the ribbon and click on the empty region between the
Grid Environment and the ribbon. Now right click on Application and select Properties.
Multiple applications can be generated by using add button in Application properties.
55
3.4.5 Enable Packet Trace, Event Trace & Dynamic Metrics (Optional)
Click Packet Trace / Event Trace icon in the tool bar. Set the name and path and select the
required attributes. To get detailed help, please refer section 6.5, 6.6 and 6.3 respectively.
Select Dynamic Metrics icon for enabling Dynamic Metrics and click OK.
56
57
3.5 MPLS
3.5.1 New Experiment
In the Simulation menu select Simulation
New MPLS Networks
58
59
Click on the Mobile Station icon in the tool bar, click and drop it on the Base Station
coverage area.
Mobile Station cannot be placed on another Mobile Station. It has to be clicked and
placed on the Base Station coverage area.
Right click on the appropriate node or link and select Properties. Then modify the
parameters according to the requirements.
Select the Application Button on the ribbon and click on the empty region between the
Grid Environment and the ribbon. Now right click on Application and select Properties.
Multiple applications can be generated by using add button in Application properties.
60
3.6.4 Enable Packet Trace, Event Trace & Dynamic Metrics (Optional)
Click Packet Trace / Event Trace icon in the tool bar. Set the name and path and select the
required attributes. To get detailed help, please refer section 6.5, 6.6 and 6.3 respectively.
Select Dynamic Metrics icon for enabling Dynamic Metrics and click OK.
Right click on the appropriate node or link and select Properties. Then modify the
parameters according to the requirements.
Select the Application Button on the ribbon and click on the empty region between the
Grid Environment and the ribbon. Now right click on Application and select Properties.
Multiple applications can be generated by using add button in Application properties.
62
63
other
interfering
signals)
and
the
power
of
some
background
noise.
The interference power is the difference between the total power received by the receiver and
the power received from one particular transmitter.
The background thermal noise in dBm at room temperature is given by:
P (in dBm) =
where f is the Bandwidth in Hertz. For 802.15.4, f = 2 MHz
P (in mW) =
( )
( )
))
Propagation Loss:
Three different and mutually independent propagation phenomena influence the power of the
received signal: path loss, shadowing and multipath fading.
64
Shadowing:
Slow shadowing in wireless network is the attenuation caused by buildings or any obstacles
between a transmitter and a receiver. In the model with shadowing, the shadowing value X,
typically defined in dB, is added to (or subtracted from) the average received power. X is a
zero means Gaussian distributed random variable with standard deviation .
The Probability Density Function (PDF) of the lognormal distribution is:
Path Loss:
Pathloss is the reduction in power density of an electromagnetic wave as it propagates
through space. Path loss may be due to many effects, such as free-space loss, refraction,
diffraction, reflection, aperture-medium coupling loss, and absorption.
Path loss can be represented by the path loss exponent, whose value is normally in the range
of 2 to 4, where 2 is for propagation in free space and 4 is for relatively loss environments. In
NetSim, the default value for path loss exponent is taken as 2.
Path loss is usually expressed in dB. In its simplest form, the path loss can be calculated
using the formula
transmitter and the receiver, usually measured in meters, and C is a constant which accounts
for system losses.
A simplified formula for the path loss between two isotropic antennas in free space:
L (in dBm) =
Where L is the path loss in decibels, is the wavelength and d is the transmitter-receiver
distance in the same units as the wavelength.
65
The path loss model used is described in IEEE Standard 802.15.2-2003[B9], which stipulates
a two-segment function with a path loss exponent of 2.0 for the first 8 m and then a path loss
exponent of 3.3 thereafter. The formula given in IEEE Standard 802.15.2 is shown in
Equation (E.1).
pl(d) = {
( )
Reference: IEEE Standard 802.15.4 2006 Part 15.4: Wireless Medium Access Control
(MAC) and Physical Layer (PHY) Specifications for Low-Rate Wireless Personal Area
Networks (WPANs).
66
3.8 Zigbee
3.8.1 New Experiment
In the Simulation menu select Simulation
New Personal Area Networks
For example, to arrive ZigBee
In the Simulation menu select Simulation
New Personal Area Networks
ZigBee
Click on the ZigBee icon in the toolbar and click and drop it inside the grid (i.e.
Visibility Range - The systems can move and communicate in this range only).
A Node cannot be placed on another Node. A Node cannot float outside the grid.
Adding PAN Coordinator - Click on the PAN Coordinator icon in the toolbar and click
and drop inside the grid.
Set Environment Properties
Right click in side of the on the Environment and click Properties.
Right click on the appropriate node or link and select Properties. Then modify the
parameters according to the requirements.
67
Select the Application Button on the ribbon and click on the empty region between the
Grid Environment and the ribbon. Now right click on Application and select Properties.
Multiple applications can be generated by using add button in Application properties.
68
other
interfering
signals)
and
the
power
of
some
background
noise.
The interference power is the difference between the total power received by the receiver and
the power received from one particular transmitter.
The background thermal noise in dBm at room temperature is given by:
P (in dBm) =
where f is the Bandwidth in Hertz. For 802.15.4, f = 2 MHz
P (in mW) =
BER = ( )
( )
( )
))
Propagation Loss:
Three different and mutually independent propagation phenomena influence the power of the
received signal: path loss, shadowing and multipath fading.
Shadowing:
Slow shadowing in wireless network is the attenuation caused by buildings or any obstacles
between a transmitter and a receiver. In the model with shadowing, the shadowing value X,
typically defined in dB, is added to (or subtracted from) the average received power. X is a
zero means Gaussian distributed random variable with standard deviation .
The Probability Density Function (PDF) of the lognormal distribution is:
Path Loss:
Pathloss is the reduction in power density of an electromagnetic wave as it propagates
through space. Path loss may be due to many effects, such as free-space loss, refraction,
diffraction, reflection, aperture-medium coupling loss, and absorption.
Path loss can be represented by the path loss exponent, whose value is normally in the range
of 2 to 4, where 2 is for propagation in free space and 4 is for relatively loss environments. In
NetSim, the default value for path loss exponent is taken as 2.
Path loss is usually expressed in dB. In its simplest form, the path loss can be calculated
using the formula
70
transmitter and the receiver, usually measured in meters, and C is a constant which accounts
for system losses.
A simplified formula for the path loss between two isotropic antennas in free space:
(
L (in dBm) =
Where L is the path loss in decibels, is the wavelength and d is the transmitter-receiver
distance in the same units as the wavelength.
Calculation of Received Power:
In general,
(
The path loss model used is described in IEEE Standard 802.15.2-2003[B9], which stipulates
a two-segment function with a path loss exponent of 2.0 for the first 8 m and then a path loss
exponent of 3.3 thereafter. The formula given in IEEE Standard 802.15.2 is shown in
Equation (E.1).
pl(d) = {
( )
71
Cognitive Radio Networks comes with the palette of various devices like Cognitive Radio
CPE, Cognitive Radio Base Station, Switch, Router, Wired Node, Wireless Node, Access
point, Incumbent etc.
Select the desired devices in the toolbar and click and drop on the environment.
To remove devices, right click on the particular device and then click Remove.
Right click on the appropriate node or link and select Properties. Then modify the
parameters according to the requirements.
Select the Application Button on the ribbon and click on the empty region between the
Grid Environment and the ribbon. Now right click on Application and select Properties.
Multiple applications can be generated by using add button in Application properties.
72
3.9.4 Enable Packet Trace, Event Trace & Dynamic Metrics (Optional)
Click Packet Trace / Event Trace icon in the tool bar. Set the name and path and select the
required attributes. To get detailed help, please refer section 6.5, 6.6 and 6.3 respectively.
Select Dynamic Metrics icon for enabling Dynamic Metrics and click OK.
73
CR BS allocates max one symbol per CPE. If the generation rate is more than the data
filled in one symbol then allocation fails and it results in zero throughput.
The first symbol is reserved for CR control frames or any broadcast PDU
74
MAC layer
3.10 LTE
3.10.1
New Experiment
3.10.2
Create Scenario
Adding MME- Click on the Router icon in the tool bar, click and drop the MME (Mobility
Management Entity) onto the environment.
Adding ENB - Click on the Evolved node B (ENB) icon in the toolbar and click it onto the
environment.
Adding UE
Click on the UE (User Equipment) icon from the Node icon in the toolbar, click and
drop it on the ENB coverage area.
UE cannot be placed on another UE. It has to be clicked and placed on the ENB node
coverage area.
3.10.3
Right click on the appropriate node or link and select Properties. Then modify the
parameters according to the requirements.
Select the Application Button on the ribbon and click on the empty region between the
Grid Environment and the ribbon. Now right click on Application and select Properties.
Multiple applications can be generated by using add button in Application properties.
75
3.10.4 Enable Packet Trace, Event Trace & Dynamic Metrics (Optional)
Click Packet Trace / Event Trace icon in the tool bar. Set the name and path and select the
required attributes. To get detailed help, please refer section 6.5, 6.6 and 6.3 respectively.
Select Dynamic Metrics icon for enabling Dynamic Metrics and click OK.
76
New Experiment
3.11.2
Create Scenario
Click on the Node icon in the Toolbar, and then click on Wireless Node.
Next, click on the environment where you want to drop it inside the grid.
(Note: A Node cannot be placed on another Node. A Node cannot float
outside of the grid.)
3.11.3
77
3.11.4
78
3.11.5
Modifying/Viewing/Accepting Properties
On opening an already configured properties of environment, the input fields will be frozen
(i.e. the input cannot be changed).To modify these values click on the Modify button in the
screen. Now the input value can be changed. Click on the Accept button, the modified values
will be saved.
3.11.6
Enable Packet Trace, Event Trace & Dynamic
Metrics(Optional)
Click Packet Trace / Event Trace icon in the tool bar. Set the name and path and select the
required attributes. To get detailed help, please refer section 6.5, 6.6 and 6.3 respectively.
Select Dynamic Metrics icon for enabling Dynamic Metrics and click OK.
3.11.7
Run Simulation
79
CBR
Custom
Database
FTP
Email
HTTP
PEER_TO_PEER
Video
Voice
To set up the application click and drop the application icon from the tool bar as shown
below.
80
This properties window allows you to set the traffic. You can add (or) delete one or more
applications.
4.2 CBR
Packet Size
Distribution: The options available for distribution is
Constant
Packet Size (Bytes): Sets the size of the packets being generated by the chosen
distribution. By default 1460 bytes is entered.
81
Constant
Inter Arrival Time: Enter the average inter-arrival time between packets. A lower interarrival time would lead to a higher generation rate and the vice versa. By default 20000
Micro Sec is entered.
4.3 Custom
Packet Size
Distribution: The options available for distribution are,
Constant
Exponential
Packet Size (Bytes): Sets the size of the packets being generated by the chosen
distribution. By default 1460 bytes is entered.
Inter Arrival Time
This indicates the time gap between packets.
Distribution: The options available for distribution are,
Constant
Exponential
Inter Arrival Time: Enter the average inter-arrival time between packets. A lower interarrival time would lead to a higher generation rate and the vice versa. By default 20000
Micro Sec is entered.
4.4 Voice
Codec
Codec is the component of any voice system that translates between analog speech and
the bits used to transmit them. Every codec transmits a burst of data in a packet that can
be reconstructed into voice. Five different standards of voice codecs are given which can
be selected depending on the variations required.
82
Packet Size
Distribution: The options available for distribution are,
Constant
Exponential
Packet Size (Bytes): Sets the size of the packets being generated by the chosen
distribution. By default 1460 bytes is entered.
Inter Arrival Time
This indicates the time gap between packets.
Distribution: The options available for distribution are,
Constant
Exponential
Inter Arrival Time: Enter the average inter-arrival time between packets. A lower interarrival time would lead to a higher generation rate and the vice versa. By default 20000
Micro Sec is entered.
Service Type
CBR - CBR stands for Constant Bit Rate. Packets of constant size are generated at
constant inter arrival times.
VBR - VBR stands for Variable Bit Rate. The two types of Suppression Model that
can be selected are,
Deterministic
Markov Chain
4.5 Video
Video is an electronic medium for the recording, copying and broadcasting of moving
visual images.
Model Type
Continuous Normal VBR This model is the simplest of all models. It uses
Normal Distribution for the generation of bits per pixel. In this model, consecutive
packet sizes are independent of each other.
83
Quantized State Continuous Time Markov In this model the bit rate is
quantized into finite discreet levels. This model takes uniform quantization step as
A bits/pixel.
between levels are assumed to occur with exponential rates that may depend on
the current level. This model is approximating the bit rate by a continuous time
process (t) with discreet jumps at random Poisson time.
o Frames per second Number of frames arriving per second. This is in
the range of 10 50.
o Pixels per frame - Number of pixels in each frame. This is in the range
of 10000 100000.
84
Simple IPB Composite ModelIn this model, the frames are organized as
IBBPBBPBBPBBIBBPBB
i.e.,
12
frames
in
Group
of
= 2 2H
Distribution of these data is Gaussian. For data to be Beta distributed, the
following mapping is being used
Yk = F-1 (FN(Xk)), k>0
Xk :Self-similar Gaussian process,
FN :The cumulative probability of normal distribution,
F-1: The inverse cumulative probability functions of the Beta model.
o Frames per second Number of frames arriving per second. This is in
the range of 10 50.
o Hurst IRefer i-button help of Simple IPB Composite Model.
o Hurst B Refer i-button help of Simple IPB Composite Model.
o Hurst P Refer i-button help of Simple IPB Composite Model.
o Gamma I Refer i-button help of Simple IPB Composite Model.
o Gamma B Refer i-button help of Simple IPB Composite Model.
o Gamma P Refer i-button help of Simple IPB Composite Model.
o Eta I Refer i-button help of Simple IPB Composite Model.
o Eta B Refer i-button help of Simple IPB Composite Model.
o Eta P Refer i-button help of Simple IPB Composite Model.
4.6 FTP
File Size
Distribution: The options available for distribution are,
Constant
Exponential
File Size (Bytes): Sets the size of the packets being generated by the chosen distribution.
By default 1000000 bytes is entered.
File_Inter Arrival Time
This indicates the time gap between packets.
Distribution: The options available for distribution are,
Constant
86
Exponential
Inter Arrival Time: Enter the average inter-arrival time between packets. A lower interarrival time would lead to a higher generation rate and the vice versa. By default 5 Sec is
entered.
4.7 Database
Transaction Size
Distribution: The options available for distribution are,
Constant
Exponential
Packet_Size (Bytes): Sets the size of the packets being generated by the chosen
distribution. By default 10000 bytes is entered.
Transaction Inter Arrival Time
This indicates the time gap between packets.
Distribution: The options available for distribution are,
Constant
Exponential
Inter Arrival Time: Enter the average inter-arrival time between packets. A lower interarrival time would lead to a higher generation rate and the vice versa. By default 1000000
Micro Sec is entered.
Constant
Exponential
87
Piece size (Bytes): Each file is divided into equal sized pieces and then the piece of the
data is transmitted. This property represents the size of each piece.
4.9 HTTP
Http_request_interarrival_time
This indicates the time gap between the pages.
Distribution: The options available for distribution are,
Constant
Exponential
Inter Arrival Time (micro sec): This represents the rate at which client sends the
requests.
Page_property
Distribution: The options available for distribution are,
Constant
Exponential
Page Count: This represents the number of pages received from the server.
Page Size (Bytes): This represents the size of each page that is received from the server.
4.10 Email
Email_Receive
This represents the rate at which emails are received.
Duration_Distribution: The options available for distribution are,
Constant
Exponential
Constant
Exponential
88
Constant
Exponential
Constant
Exponential
Priority Value
Priority
QoS Class
High
RTPS
High
UGS
Video
Medium
nRTPS
FTP
Low
BE
Database
Low
BE
Custom
Low
BE
Note: Priority of Normal has a Priority Value of 4 and nRTPS QoS Class. Ex: Video
over TCP.
89
If 1200 packets generated per minute that, on average, one packet is generated every 60 /
1200 = 0.05 seconds. So, lets define a variable = 1/ 0.05 = 20 and call it the rate
parameter. The rate parameter is a measure of frequency: the average rate of events
(packets) per unit of time (in this case, seconds).
Knowing this, we can ask questions like, what is the probability that a packet will be
generated within the next second? Whats the probability within the next 10 seconds? Theres
a well-known function to answer such questions. Its called the cumulative distribution
function for the exponential distribution, and it looks like this:
F(x) =1ex
Basically, the more time passes, the more likely it is that, a packet is generated. The word
exponential, in this context, actually refers to exponential decay. As time passes, the
probability of having no packets generated decays towards zero and correspondingly, the
probability of having at least one packet generated increases towards one.
90
The probability of generating a packet within the next 0.05 seconds is F(0.05) 0.63
In particular, note that after 0.05 seconds the prescribed average time between packets the
probability is F(0.05) 0.63 .
In
the
case
exponential
fFirstArg = args[0];
nRandOut = fnRandomNo(10000000, &fRand, uSeed, uSeed1);
fRandomNumber = (double) (fRand);
fFirstArg = 1 / fFirstArg;
*fDistOut = (double) -(1 / fFirstArg)* (double) logl(1 - fRandomNumber);
The simple way of selecting this via the UI is to selecting exponential distribution for interarrival time when modelling application properties.
91
Advanced users can model their simulation via a config file (which can be created without
the NetSim GUI) and run the simulation from command line. This is typically done in cases
where very large networks are to be simulated (it takes too long to create it in the GUI), or to
run a series of simulations automatically (Ref Help on NetSim Batch Processing). The config
file contains all required information to run the simulation including the network topology,
devices, links, traffic, statistics, traces etc.
To run Simulation in NetSim through command line interface (CLI), the following steps have
to be followed.
Step 1: Note the App Path
App path is the file location in the system in which NetSim has been installed.
The app path can be found out by right clicking the NetSim Shortcut in the desktop and
selecting Open file location (In Vista and Windows 7) or Find Target (In Windows XP). The
app path will be something like C:\Program Files\NetSim Standard\bin, depending on
where NetSim is installed.
Note: The path to the bin folder of the app path must be mentioned
Step 2: Note the IO Path
IO path (Input/output Path) is the path where the input and output files of an application is
written. This is similar to the temp path of windows OS. For NetSim, the IO path can be got
by Start -> Run-> %temp%/NetSim. Once you reach this folder, the user can notice that the
path would be something like C:\Users\Ram\AppData\Local\Temp\NetSim
92
The IO path is the path where the Configuration.xml (NetSim Config file) of the scenario,
that will be simulated, should be present.
App path and IO path can also be same, i.e., Configuration.xml can be placed inside the app
path (if the app path has write permission). Otherwise, users can create a folder for IO path
and Configuration.xml can be placed inside that folder.
Note: Sample configuration.xml files are available in the <NetSim installed Directory>/Docs/
Sample_Configurations folder of the NetSim install directory inside the respective protocol
folder names.
For floating/roaming licenses, type the following in the command prompt.The type of license
can be seen by clicking on NetSim Help About NetSim
>NetSimCore.exe<space> -apppath<space><app path><space>-iopath<space><io
path><space>-license<space>5053@<Server IP Address>
Where,
5053 is the port number through which the system communicates with the license server
i.e the system in which the dongle is running (for floating license users)
<Server IP Address> is the ip address of the system where NetSim license server (dongle)
is running. Please contact your network administrator / lab in charge to know the IP
address of the PC where the NetSim license server is running.
93
The following screenshot is the example of running NetSim through CLI where the ip address
of the NetSim license server is 192.168.0.2
Where,
The following screenshot is the example of running NetSim through CLI for the node locked
license.
Simulation will be completed successfully and the text files that are requested by the end user
in Configuration.xml will be written in the <iopath>.
94
Note: If the folder name contains white space, then mention the folder path within double
quotes while specifying the folder name in the command prompt. For example, if app path
contains white space, then the app path must be mentioned within double quotes in the
command prompt as given below.
To know more about the options that are available to run NetSim via CLI, type the following
in the command prompt.
>cd <app path>
>NetSimCore.exe -h
95
96
GUI
Using CLI
Configuratio
n.xml
Metrics.txt
Protocol
Engine +
Stack +
Kernel
97
98
EXPERIMENT_INFORMATION
GUI_INFORMATION
NETWORK_CONFIGURATION
SIMULATION_PARAMETER
PROTOCOL_CONFIGURATION
STATISTICS_COLLECTION
EXPERIMENT_INFORMATION:
This section contains the details about the user credentials, such as the user mode
(Admin or Exam or Practice), experiment name, date on which the experiment is created and
the comments about the experiment. This section plays a significant role while running
NetSim through GUI.
GUI_INFORMATION:
This section contains the GUI information like the environment length, view type etc.
and the network name which is desired to be run.
NETWORK_CONFIGURATION:
This section is used to configure the devices and the links of the desired network at
the each layer of the OSI stack. It consists of DEVICE_CONFIGURATION, CONNECTION
and APPLICATION_CONFIGURATION. DEVICE_CONFIGURATION configures the
devices in the desired network while the CONNECTION configures the links in the desired
network and APPLICATION configures the Applications.
SIMULATION_PARAMETER:
Simulation time and seed values are described in this section.
99
PROTOCOL_CONFIGURATION:
IPV4 and static ARP are enabled or disabled in this section. The text files illustrating
the static routing and static ARP can be obtained by enabling the corresponding tags in the
Configuration.xml.
STATISTICS_COLLECTION:
The packet trace and the event trace can be observed in the text files which are created
by enabling the tags in this section. The required fields of the packet trace can be enabled in
the PACKET_TRACE while the event trace can be enabled in the EVENT_TRACE of this
section.
100
6 Analysis
6.1 Performance Metrics
NetSim provides distinct quantitative metrics at various abstraction levels such as Network
Metrics, Link Metrics, TCP Metrics, Application Metrics, etc at the end of simulation. With
the help of metrics, users can analyze the behavior of the modeled network and can compare
the impact of different algorithms on end-to-end behavior.
After simulation of a scenario is performed, the NetSim Performance Metrics are shown on
the screen as shown below
Queue Metrics: Displays the values of the queue metrics for the devices containing
buffer queue like routers, access points etc.
Port Id-Unique id number of the port of the device. This is also called as
interface id.
Protocol metrics: Displays the protocol based metrics which are implemented in
Network scenario. Metrics will vary depending upon the type of network simulated.
Device metrics: Displays device related metrics like ARP table, IP forwarding tables.
This is also dependent upon the type of network
Application Metrics: Displays the various metrics based on the Application running
in the network scenario.
Source Id-It is the unique Id of the device running that particular application.
Delay-It is the average amount of time taken calculated for all the packets to
reach the destination from the source.
Note about metrics: The metrics are calculated at each layer and might not be equivalent to
the same metric calculated at a different layer. For exactness and precision we recommend
users also verify the results with the event trace & packet trace generated by NetSim.
Note about packet transmission: The Network Stack forms the core of NetSims architecture.
The Stack consists of five IN and OUT events: PHYSICAL_IN, MAC_IN, NETWORK_IN,
TRANSPORT_IN, APPLICATION_IN and APPLICATION_OUT,TRANSPORT_OUT,
NETWORK_OUT, MAC_OUT, PHYSICAL_OUT. All the packets when transferred
between devices go through the above events in order. IN events occur when the packet is
entering a device and all the OUT events occur when packet leaves a device.
The following table lists the various files that will be written in the NetSim install directory/
IO path on completion of simulation.
103
S. No
File
Contents
Metrics.txt
MetricsGraph.txt
LicenseErrorLog.txt
ConfigLog.txt
Provides errors if there are errors in
the configuration file.
LogFile.txt
PacketTrace.txt
EventTrace.txt
If NetSim runs via the UI, then the metrics will be displayed automatically at the end of
simulation with illustrative pie charts and tables.
If NetSim runs via CLI, then the metrics will be written into Metrics.txt and
MetricsGraph.txt.
104
No animation,
Record the animation and
Play and record animation while running simulation.
The packet animation would then be recorded and the user can view the animation from the
metrics screen as shown below:
105
When packet animation is enabled, a screen with the following toolbar appears:
While viewing packet animation, user can see the flow of packets as well as the type of
packet. Blue color packet denotes control packet, green color is used for data packet and red
color is error/collided packet.
Example showing packet animation: In first figure, Custom data packet is flowing from
Switch F to Node G (green color) and TCP_ACK is sent from Node G to Switch F in second
figure (blue color).
106
As of NetSim v8, link and application throughputs can be dynamically plotted. These plots
can be done offline or during simulation. Note that enabling them to be plotted during
simulation would consume a lot of memory and slow down the simulation significantly.
Dynamic metrics can be set by clicking on the dynamic metrics icon in the GUI, and
selecting those metrics that you wish to monitor.
Upon completion of the simulation dynamic metrics plots can be viewed by clicking on Link
throughput in Metrics screen.
107
User: This Option can be used to compare different experiments created by a single
user. As Admin is a Super User, he/she can compare all the experiments created by all
the users. Things that cannot be done are,
User to User comparison cannot be made, i.e. two or more different
experiments created by two or more different users cannot be compared.
Experiments of a particular Network cannot be compared with experiments of
other Networks.
In Tool Bar, there are various tabs available like Internetworks, Legacy Networks,
BGP Networks, MPLS Networks, Advanced Wireless Networks - MANET,
Advanced Wireless Networks WiMAX, Cellular Networks, Wireless Sensor
Networks, Personal Area Networks, Cognitive Radio Networks and LTE networks.
Click on the particular Network tab for comparing the performance of protocols
under that Network.
For Internetworks, Advanced Wireless Networks MANET, BGP Networks,
Wireless Sensor Networks, Personal Area Networks, LTE networks and
Cognitive Radio Networks, select the Metrics FileSelect the Metrics File to
add it onto the Metrics Table by using Browse button.
For Other Networks, select the Experiment based on the tab selected. When
one of the tabs is selected, all the experiments saved under the particular
Network will be listed. Click on the Experiment Name to add it onto the
Metrics Table.
Export to .csv - Click on Export to .csv to export the Metrics Table to a
.csv format. This action button will export the contents to a .csv format
that is available.
Print - Click on the Print option to print the Metrics Table. This action
button will fetch the Print dialogue box.
108
The Metrics Table- This is the table that is generated when the Experiments are
selected using the Select the Metrics File/ Experiment option.
The first column in the Metrics Table consists of the Check Boxes that are
used to select (i.e. by default all the Experiments are selected) or deselect the
selected Experiments. If an Experiment is selected, then that Experiment
would be compared along with other Experiments, else the Experiment would
not be compared with other Experiments.
The second column in the Metrics Table X button is available. This X
button is used for deleting the Experiment.
109
110
Step 2: Select the file click import, the following window will appear,
Step 3: Click next, the following window will appear, in that select the check box as
mentioned in the following window, and then click Finish button.
111
SEGMENT_ID
PACKET_TYPE
CONTROL_PACKET_TYPE
SOURCE_ID
DESTINATION_ID
TRANSMITTER_ID
RECEIVER_ID
APP_LAYER_ARRIVAL_TIME
device
TRX_LAYER_ARRIVAL_TIME
NW_LAYER_ARRIVAL_TIME
MAC_LAYER_ARRIVAL_TIME
PHY_LAYER_ARRIVAL_TIME
PHY_LAYER_START_TIME
PHY_LAYER_END_TIME
APP_LAYER_PAYLOAD
TRX_LAYER_PAYLOAD
NW_LAYER_PAYLOAD
MAC_LAYER_PAYLOAD
PHY_LAYER_PAYLOAD
PHY_LAYER_OVERHEAD
PACKET_STATUS
LOCAL_ADDRESS
FOREIGN_ADDRESS
CWND
SEQ_NO
ACK_NO
RTT
RTO
CONNECTION_STATE
CW
BO_TIME
DATARATE
RX_POWER
RX_SENSITIVITY
Every device in NetSim has an instance of the Network Stack shown above. Switches
& Access points have a 2 layer stack, while routers have a 3 layer stack. End-nodes have a 5
layer stack.
The protocol engines are called based on the layer at which the protocols operate. For
example, TCP is called during execution of Transport IN or Transport OUT events, while
802.11b WLAN is called during execution of MAC IN, MAC OUT, PHY IN and PHY OUT
events.
114
When these protocols are in operation they in turn generate events for NetSim's
discrete event engine to process. These are known as SUB EVENTS. All SUB EVENTS, fall
into one of the above 10 types of EVENTS.
Each event gets added in the Simulation kernel by the protocol operating at the
particular layer of the Network Stack. The required sub events are passed into the Simulation
kernel. These sub events are then fetched by the Network Stack in order to execute the
functionality of each protocol. At the end of Simulation, Network Stack writes trace files and
the Metrics files that assist the user in analyzing the performance metrics and statistical
analysis.
Event Trace:
The event trace records every single event along with associated information such as
time stamp, event ID, event type etc in a text file or .csv file which can be stored at a user
defined location.
Apart from a host of information, the event trace has two special information fields
for diagnostics
a) A log of the file name and line number from where the event was generated (Please refer
Help Event Trace -Writing file name and line number of the code which generated the
event) and
b) Previous event which triggered the current event.
Note: Turning
Event
Trace
will slow
down the
significantly
NetSim
provideson
users
with
the option
of turning
on simulation
"Event Traces".
How to enable Event Trace via GUI?
If NetSim runs via GUI, event trace can be turned on by clicking the Event Trace icon
in the tool bar in the Internetworks menu and selecting the required fields in the event trace.
How to enable Event Trace via CLI?
If NetSim runs via CLI, then the event trace can be turned on by enabling the event
trace in the STATISTICS_COLLECTION tag of the configuration file.
115
Event_Type
Specifies the type of event being performed, for eg APPLICATION_IN, APPLICATION_OUT, MAC_OUT, MAC_IN,
PHYSICAL_OUT, PHYSICAL_IN,etc
Event_Time
Device_Type
Specifies the type of device in which the current event is being executed
Device_Id
Interface_Id
Application_Id
Packet_Id
Segment_Id
Prev_Event_Id
116
Step 2: Go to Data menu and click on filter icon to enable the auto filter.
in the header of the column you want to filter. In the list of text or
numbers, uncheck the (Select All) box at the top of the list, and then check the boxes of the
items you want to show.
For example, click on arrow of SOURCE_ID and uncheck the Select all check box and
select NODE 2 then click on ok.
All the rows which are having NODE 2 as source id will be shown.
117
Select all check box and select the packet id which you want to observe, for example 1, and
then click on ok.
118
Scenario is as shown below and traffic flow is from Wired Node 1 to Wired Node 2.
Flow of packet 1 can be observed from the packet trace as shown below.
Note: In the trace file device IDs are shown not device names. Wired Node 1s ID is 2 so it is
Shown as NODE-2, Wired Node 2s ID is 3 so it is shown as NODE -3, Router-1 ID is 1 so it
is shown as ROUTER-1. Device IDs are shown on the top of the device icon in the above
scenario.
In a scenario source and destinations are fixed but transmitter and receiver are changed. For
example in the above scenario NODE-2 is the source and NODE-3 is the destination, but
when NODE- 2 sending the packet to the ROUTER-1 then NODE-2 is the transmitter and
ROUTER-1 is the receiver. When ROUTER-1 sending the packet to the NODE-3, ROUTER1 is the transmitter and NODE-3 is the receiver.
119
The detail of the contents of the selected packet can be seen in the below panes.
120
TREE View
BYTE View
In the above figure, the details of the packet are displayed in both tree form and bytes form.
In the tree form, user can expand the data by clicking on the part of the tree and view
detailed information about each protocol in each packet.
You can also build display filters that compare values using a number of different
comparison operators like ==, != , >, <, <=, etc.
121
Following is an example displaying filtered packets whose SYN Flag and ACK Flag are
set to 1 in a TCP Stream.
Different types of protocols will be available. User can select the specific conversation by
going to the desired protocol. For example, in the following diagram, we have selected TCP.
User can also analyze each of the conversation with respect to the direction of flow of traffic.
122
User can create graphs of the each of the conversation flows by clicking on Graph AB
or Graph B A button. Then navigate to Graph type tab as shown below:
RTT
123
Throughput
Window scaling
124
To view the graph for specific packets, provide filters and click on the Graph button. The
colors will be different for all the graphs. Up to 5 graphs can be compared at the same time.
125
126
127
b)
Note: Sometimes you may get the following warning message. Then click on ok
and proceed.
Step 2: Inside Solution Explorer pane in Visual Studio 2010, double click on DSR. Then
open DSR.C file by double clicking on it.
Step 3: Add fprintf (stderr, Hello World); statement inside the source code of DSR as
shown below to print Hello World.
128
Note: - Use fprintf (stderr,Hello World) instead of printf ( ) to write to standard out.
stdout is redirected to LogFile.txt which is present in <iopath>. So you can see Hello
World Statement (or whatever you write inside the printf) inside the LogFile.txt.
Once this is done click to save the changes and overwrite the file (in case of write
protection).
NOTE: To create DLL file of all the protocols actively displayed inside solution pane, click
on Build->Build Solution
129
Check that the build is successful and necessary DLL files have been built.
Step 2: Inside the simulation folder (present on the desktop) a Dll folder will be created and
inside, the DLLs are built.
It will contain custom DLLs which have been built per the modifications done.
130
Original DLL
131
Step 4: Place the custom DLL obtained from Step 1 inside the NetSim Standard->bin
folder.
Note: Ensure that the name of the DLL which is pasted is exactly the same as
the original DLL (before it was renamed). For the example case of DSR, the DLL
must be libDSR.dll.
132
Create DLL and Link the DLL to the NetSim as explained in Section 7.1. And run the
simulation, you can see the following output on the console.
133
Step 1: Create a file with the name Output1.txt in the <IOPath> . The file will contain two
columns: one being the Node ID of the device to be failed and other being the failure time (in
microseconds).
For example, to fail Node Id 2 at XXX time, the output1 file will be as follows:
Step 3: The function fn_NetSim_DSR_Init() will execute before the protocol execution
starts. So in this function, we will read the Output1.txt and save information regarding which
nodes will fail at which time. Add the following code inside the specified function.
int i;
FILE *fp1;
char *pszFilepath;
char pszConfigInput[1000];
pszFilepath = fnpAllocateMemory(36,sizeof(char)*50);
strcpy(pszFilepath,pszAppPath);
strcat(pszFilepath,"/Output.txt");
fp1 = fopen(pszFilepath,"r");
i=0;
if(fp1)
{
while(fgets(pszConfigInput,500,fp1)!= NULL)
{
sscanf(pszConfigInput,"%d %d",&NodeArray[i],&TimeArray[i]);
i+=1;
}
}
fclose(fp1);
134
Step 4: The fn_NetSim_DSR_Run( ) is the main function to handle all the protocol
functionalities. So add the following code to the function at the start.
int i,nFlag=1;
if(nFlag)
{
for(i=0;i<100;i++)
if((pstruEventDetails->nDeviceId== NodeArray[i])&&(pstruEventDetails>dEventTime >= TimeArray[i]))
{
pstruEventDetails->nInterfaceId = 0;
return 0;
}
}
Step 6: Create DLL and Link the DLL to the NetSim as explained in Section 7.1. And run the
simulation, you can see Packet Animation to check the node failure after the mentioned time.
135
4.
In Sensor.c , the code must be modified at specified places in red color. Add the
modified code:
#include "main.h"
#include "List.h"
#include "802_15_4.h"
#define MAX_PAYLOAD 70
int fn_NetSim_FindAgentPos(double* dXPos, double* dYPos, int nAgentId,double
dSensingTime,AGENT** pstruAgent);
double fn_Sensor_CalculateDistance(POS_2D* pstruPos1, POS_2D* pstruPos2);
#ifdef _FILE_SEND_
typedef struct file_info
{
char Packet[100];
long len;
int Packet_Id;
_ele* ele;
}FILE_INFO,*PFILE_INFO;
#define FILE_INFO_ALLOC()
(PFILE_INFO)list_alloc(sizeof(FILE_INFO),offsetof(FILE_INFO,ele))
PFILE_INFO fileinfo=NULL;
static int nPacketId=0;
char file_name[100][50] = {"send.txt"};
char outfile_name[100][50] = {"receive.txt"};
int fnWriteFile(int PacketId)
{
char *packet;
static FILE *file_receive=NULL;
PFILE_INFO file_rec=fileinfo;
size_t siz;
if(!file_receive)
file_receive = fopen(outfile_name[0],"wb");
while(file_rec)
{
if(file_rec->Packet_Id == PacketId)
{
136
137
PstruPacket->nPacketPriority = Priority_Low;
PstruPacket->nQOS =(NETSIM_ID)QOS_BE;
PstruPacket->nSourceId = (NETSIM_ID)nSensorLoop;
//Update the Transport layer information
PstruPacket->pstruTransportData->nSourcePort = SOURCEPORT;
PstruPacket->pstruTransportData->nDestinationPort =
DESTINATIONPORT;
//Update the Network layer information
PstruPacket->pstruNetworkData->szSourceIP =
IP_COPY(fn_NetSim_Stack_GetFirstIPAddressAsId((NETSIM_ID)nSensorLoop));
PstruPacket->pstruNetworkData->szDestIP =
IP_COPY(fn_NetSim_Stack_GetFirstIPAddressAsId(PstruPacket->nDestinationId));
PstruPacket->pstruNetworkData->nTTL = MAX_TTL;
//Update the Application layer information
//For transferring file from Sensor to sink node
//70 bytes at a time
file =FILE_INFO_ALLOC();
memcpy(file->Packet,str,siz);
file->Packet_Id = PstruPacket->nPacketId;
file->len = siz;
LIST_ADD_LAST((void**)&fileinfo,file);
PstruPacket->szPayload = NULL;
PstruPacket->pstruAppData->dPayload = siz;
PstruPacket->pstruAppData->dOverhead = 0;
PstruPacket->pstruAppData->dPacketSize = PstruPacket>pstruAppData->dPayload + PstruPacket->pstruAppData->dOverhead;
PstruPacket->pstruAppData->dArrivalTime = pstruEventDetails>dEventTime;
PstruPacket->pstruAppData->dEndTime = pstruEventDetails>dEventTime;
PstruPacket->pstruAppData->dStartTime =
pstruEventDetails-
>dEventTime;
if(NETWORK->ppstruDeviceList[nSensorLoop-1]>pstruTransportLayer->isUDP)
PstruPacket->pstruTransportData>nTransportProtocol=TX_PROTOCOL_UDP;
else if(NETWORK->ppstruDeviceList[nSensorLoop-1]>pstruTransportLayer->isTCP)
PstruPacket->pstruTransportData>nTransportProtocol=TX_PROTOCOL_TCP;
else
PstruPacket->pstruTransportData->nTransportProtocol=0;
if(NETWORK->ppstruDeviceList[nSensorLoop-1]>pstruSocketInterface->pstruSocketBuffer[0]->pstruPacketlist==NULL)
{
fn_NetSim_Packet_AddPacketToList((NETWORK>ppstruDeviceList[nSensorLoop-1]->pstruSocketInterface>pstruSocketBuffer[0]),PstruPacket,3);
pstruEventDetails->dPacketSize=PstruPacket>pstruAppData->dPacketSize;
pstruEventDetails->nDeviceType = SENSOR;
pstruEventDetails->nApplicationId=0;
pstruEventDetails->nProtocolId=PstruPacket>pstruTransportData->nTransportProtocol;
138
pstruEventDetails->nDeviceId=(NETSIM_ID)nSensorLoop;
pstruEventDetails->nInterfaceId=0;
pstruEventDetails->nEventType=TRANSPORT_OUT_EVENT;
pstruEventDetails->nSubEventType=0;
pstruEventDetails->pPacket=NULL;
fnpAddEvent(pstruEventDetails);
}
else
{
fn_NetSim_Packet_AddPacketToList((NETWORK>ppstruDeviceList[nSensorLoop-1]->pstruSocketInterface>pstruSocketBuffer[0]),PstruPacket,3);
}
}
fclose(file_transfer);
return 0;
}
#endif
/** In this function the sensors sense the agent, creates a packet and
forwards it to sink node.*/
int fn_NetSim_Zigbee_SensorEvent(int nSensorLoop,NETSIM_ID
nGlobalPANCoordinatorId,AGENT** pstruAgent,SENSORS* pstru_Sensor,METRICS**
pstruMetrics,NetSim_EVENTDETAILS* pstruEventDetails)
{
int nFlag = 0;
static int nPacketId;
char str[500];
int nAgentLoop;
POS_2D* pstruPos;
double dDistance;
POS_2D* pstruTemppos;
NetSim_PACKET *PstruPacket;
#ifdef _FILE_SEND_
fnsendfile((NETSIM_ID)nSensorLoop);
return 0;
#endif
pstruPos = (POS_2D*)fnpAllocateMemory(sizeof(POS_2D),1);
pstruTemppos = (POS_2D*)fnpAllocateMemory(sizeof(POS_2D),1);
for(nAgentLoop =0;nAgentLoop<MAXAGENT;nAgentLoop++)
{
if(pstruAgent[nAgentLoop] == NULL)
continue;
5. Copy the input file (file to be transferred) in NetSim bin folder (C:\Program
Files\NetSim Standard\bin) and rename it as send.txt. (Note: User can either change
the name of the input file or in the code. Both the names should be same)
6. In Sensor.c, user can edit the name of the input file in file_name[] and output file in
outfile_name[] in the code. For example, currently it is receive.txt for output file.
7. Build Zigbee (Please refer section 7.1)
139
8. Copy the dll in bin folder of NetSim. Take care to rename the original libZigbee.dll so
as to preserve the original binaries of NetSim
9. Next, to run the code, follow these steps:
In this section we create a sample scenario to transfer file from Sensor to Sink Node in WSN:
Step 1: Create a scenario in NetSim as follows
Note: Due to retransmissions and errors, sometimes the output file is not reproduced
correctly. To get exact file, user has to enable TCP (WSN works on UDP).
140
Step 2:- Build the protocol and replace the dll in bin folder in NetSim. Do not close Visual
Studio.
Step 3:- In NetSim, create a network scenario and simulate. The simulation wont start and
will pause (because of getch())
Step 4:- In Visual Studio, put break point inside the source code where you want to debug.
Step 5:- Go to Debug->Attach to Process in Visual studio as shown and attach to
NetSimCore.exe.
141
Click on Attach.
Press enter in the command window .Then control goes to the project and stops at the break
point in the source code as shown below.
142
All debugging options like step over (F10), step into (F11), step out (Shift + F11),
continue (F5) are available.
After execution of the function, the control goes back to NetSim and then comes back to the
custom code the next time the function is called in the simulation.
To stop debugging and continue execution, remove all breakpoint and press F5 (key). This
then gives the control back to NetSim, for normal execution to continue.
143
Step 4:- Open/Create the Project in Visual Studio and put break point inside the source code.
Step 5:- Go to Debug->Attach to Process
144
Attach to NetSimCore.exe.
Click on Attach.
Step 6:- Go to command prompt which is already opened in Step 3. Enter the Event Id.
Note: If you dont want to stop at any event you can specify 0 as event id.
145
Press enter then control goes to the project and stops at the break point in the source code as
shown below.
All debugging options like step over (F10), step into (F11), step out (Shift + F11),
continue(F5) are available.
146
After execution of the function, the control goes back to NetSim and then comes back to the
custom code the next time the function is called in the simulation.
To stop debugging and continue execution, remove all breakpoint and press F5 (key). This
then gives the control back to NetSim, for normal execution to continue.
Step 2: Run the NetSim via CLI in debug mode (Refer NetSim Help ->Running Netsim via CLI)
with d as the fourth parameters
Press enter
Step 3: Enter -1 as the event ID
147
Upon running, NetSim will write the file name and line number of the source code that generated each
event.
Note: In the above trace file Event Id 2 is triggered inside the 802_22_lib.c file which is present in
Cognitive radio.lib.Since all the lib files are opaque to the end user, you cannot see the source code of
the lib file. However, Event Id 4 is triggered at line number 80 of sch.c file and you can find the
location of the event by opening the sch.c file as shown below.
File name
Line number
148
Adding the variable to watch Watch the change in the variable as the code progress by right clicking on the variable
& clicking on "add watch" tab. This is useful if to continuously monitor the change in the
variable as the code progresses.
149
Viewing external variables During the process of debug users would come across variables that are defined
outside the source file being built as a .dll. Such variables cannot be viewed directly when
added in the watch tab, as this would throw the error
CX0017: Error:symbol Variable_Namenot found.
In the call stack window one can find the file in which that variable is situated. Right
click on the dll file name in the call stack window, in this case NetworkStack.dll. Then in the
pull down menu which appears, select "load symbols from" and give the path of the
pdb(program database) file.
A program database (.pdb) file, also called a symbol file, maps the identifiers that a
user creates in source files for classes, methods, and other code to the identifiers that are used
in the compiled executablesof the project. The .pdb file also maps the statements in the
source code to the execution instructions in the executables. The debugger uses this
information to determine: the source file and the line number displayed in the Visual Studio
IDE and the location in the executable to stop at when a user sets a breakpoint. A symbol file
also contains the original location of the source files, and optionally, the location of a source
server where the source files can be retrieved from.
When a user debugs a project in the Visual Studio IDE, the debugger knows exactly
where to find the .pdb and source files for the code. If the user wants to debug code outside
their project source code, such as the Windows or third-party code the project calls, the user
has to specify the location of the .pdb (and optionally, the source files of the external code)
and those files need to exactly match the build of the executables.
The pdb files are usually available in NetSims install directory, else write to
support@tetcos.com for the latest copy of these debug files.
150
Note: If the load symbols menu option is greyed, then it means symbols are already loaded
In the watch window, the variable which the user has to watch should be edited by
double clicking on it and prefixing {,,NetworkStack.dll} to the variable name and pressing
enter. (The name of the respective file in which the variable is defined should be mentioned in this case NetworkStack.dll).
151
In the main function where a user wishes to find the dTotalReceivedPower, the variable must
be assigned the respective value. In the above case, the following line of code must be written
inside fn_NetSim_WLAN_PhysicalIn() function in WLAN.c file present inside WLAN
folder
var1 = DEVICE_PHYVAR(nDeviceId, nInterfaceId);
Note that the parameters given in the macro or any function which assigns a value to
the variable must be defined beforehand in the code. Here nDeviceId and nInterfaceId are
defined beforehand.
152
The modified WLAN.h file along with other header files on which it depends (802_11e.h and
802_11abgnac.h), present inside <Installed Directory> \src \Simulation \WLAN\ folder must
be copied and pasted in the DSR solution folder <Installed Directory>\src\Simulation\DSR
and must be included in the DSR solution in visual studio.
153
The WLAN.h header file which was included in DSR solution must be edited and the
line where _declspec(dllexport) PHY_VAR *var1; was written must be replaced with
_declspec(dllimport) PHY_VAR *var1;
For viewing the variable value in the command prompt, the following lines must be
added in DSR.c.
#include WLAN.h
if(var1)
fprintf (stderr,"\n Received Power- %lf\n",var1->dTotalReceivedPower);
154
The
solution
must
be
built
and
the
resulting
dll
file
<Installed
155
For
detailed
help
please
refer
the
appropriateheader
(.h)
files
inside:
Include all the header (.h) files from the include folder
NetworkStack.lib is a import library file and has the definitions for the functions
present in the NetworkStack.dll
When developing new protocols users should create their own protocol.h and declare
all the protocol specific variables here. Stack & packet related variables should be
used from stack.h and packet.h
int
(*fn_NetSim_protocol_init)(conststruct
stru_NetSim_Network*,conststruct
stru_NetSim_EventDetails*,constchar*,constchar*,int,constvoid**);
Using this API the stack passes all the relevant pointers to variables, paths etc needed for
the protocol. Inside this function a) local variables should be initialized, b) Initial events if
any should be written,eg: Hello packet in RIP, STP in Ethernet c) File pointers for
reading & writing protocol_specific_IO files.
int
(*fn_NetSim_protocol_Configure)(
conststruct
stru_NetSim_Network*,
int
The stack calls this API when reading the config file. Upon reaching the appropriate
protocol definition in the XML file, the stack calls this and passes all these pointers to the
protocol
char* (*fn_NetSim_protocol_trace)(int): This called by the stack to write the event trace
char*
(*fn_NetSim_protocol_ConfigPacketTrace)(constvoid*
xmlNetSimNode);
To
char*
(*fn_NetSim_protocol_WritePacketTrace)(const
NetSim_PACKET*);
157
To
8 Advanced Features
8.1 Random number Generator and Seed Values
All network simulations involve an element of randomness. Some examples are a. It is possible to configure the traffic sources in the simulation to generate traffic in a
perfectly regular pattern. However, this is typically not the case in the real world.
b. Node back-offs after collisions are random to resolve contention issues
c. The exact bit which is errored, based on Bit error probability of a wireless channel, is
decided randomly
NetSim uses an in-built Linear Congruential Random Number Generator (RNG) to generate
the randomness. The RNG uses two seeds values to initialize the RNG.
Having the same set of seed values ensures that for a particular network configuration the
same output results will be got, irrespective of the PC or the time at which the simulation is
run. This ensures repeatability of experimentation.
Modifying the seed value will lead to the generation of a different set of random numbers and
thereby lead to a different sequence of events in NetSim. When simulations are run for a
network configuration with different seed values, the results will likely be slightly different.
More advanced users may note that Confidence can be established by analyzing a set of
results with different seed values for the same network scenario.
158
Using CLI
Step1: In internetworks, Static Routes can be set for any scenario having a minimum of 3
routers, 2 switches and 3 wired nodes. The easiest way to do this is to first run the scenario
with routing protocol set as RIP/OSPF and save the Configuration file
Step 2: Open the Configuration file with Visual studio. Expand the Router configuration and
set the Static Routing information in Application Layer property of the device, by enabling
the Static routing status. Then set the appropriate Static routing file name and file path.
RIP
By default:
<LAYERTYPE="APPLICATION_LAYER">
<ROUTING_PROTOCOLNAME="RIP"SETPROPERTY="true">
159
<PROTOCOL_PROPERTYFILE_NAME="StaticRouting.txt"FILE_PATH="C:\Program
Files\NetSim
standard\Docs\Sample_Configuration\Internetworks"GARBAGE_COLLECTION_TIMER="
120"STATIC_ROUTING_STATUS="DISABLE"TIMEOUT_TIMER="180"UPDATE_TIMER="30"VERS
ION="2"/>
</ROUTING_PROTOCOL>
</LAYER>
Change to:
<LAYERTYPE="APPLICATION_LAYER">
<ROUTING_PROTOCOLNAME="RIP"SETPROPERTY="true">
<PROTOCOL_PROPERTYFILE_NAME="StaticRouting.txt"FILE_PATH="C:\Program
Files\NetSim
standard\Docs\Sample_Configuration\Internetworks"GARBAGE_COLLECTION_TIMER="
120"STATIC_ROUTING_STATUS="ENABLE"TIMEOUT_TIMER="180"UPDATE_TIMER="30"VERSI
ON="2"/>
</ROUTING_PROTOCOL>
</LAYER>
OSPF
By default:
<LAYERTYPE="APPLICATION_LAYER">
<ROUTING_PROTOCOLNAME="OSPF"SETPROPERTY="true">
<PROTOCOL_PROPERTYFILE_NAME="StaticRouting.txt"FILE_PATH="C:\Program
Files\NetSim standard\Docs\Sample_Configuration\Internetworks"
LS_REFRESH_TIME="1800"MAX_AGE="3600"ROUTER_PRIORITY="1"STATIC_ROUTING_STATU
S="DISABLE"VERSION="2"/>
</ROUTING_PROTOCOL>
</LAYER>
Change to:
<LAYERTYPE="APPLICATION_LAYER">
<ROUTING_PROTOCOLNAME="OSPF"SETPROPERTY="true">
<PROTOCOL_PROPERTYFILE_NAME="StaticRouting.txt"FILE_PATH="C:\Program
Files\NetSim standard\Docs\Sample_Configuration\Internetworks"
LS_REFRESH_TIME="1800"MAX_AGE="3600"ROUTER_PRIORITY="1"STATIC_ROUTING_STATU
S="ENABLE"VERSION="2"/>
</ROUTING_PROTOCOL>
</LAYER>
160
Note:
1. Update this information in any one of the router
2. A sample StaticRouting.txt file will be available inside C:\Program Files\NetSim
standard\Docs\Sample_Configuration\Internetworks. Appropriately modify it for the
scenario.
The StaticRouting.txt file contains
1. Device Id of the Router
2. List of entries to add in the routing table
DEVICE_ID:1
Step 3: After this, run this configuration file through CLI and static routes will be used for
routing.
161
162
Given below are important sections of the source code of this batch program.
#define apppath C:\\Program Files (x86)\\NetSim pro7\\bin
// change to your
app path
#define iopath F:\\NetSim_Batch_Processing
// change to your IO
Path
#define license 5053@192.168.0.10
running
Flow of the batch program code and important functions
main ( )
{
{// iterate from MIN to MAX for all of the devices to create configuration
files
If
Else
{
//Create configuration file
fnCreateExperimentInformation(fpConfigurationFilePointer);
fnCreateNetworkConfiguration(fpConfigurationFilePointer);
fnCreateSimulationParameter(fpConfigurationFilePointer);
fnCreateStatisticsCollection(fpConfigurationFilePointer);
}
163
fnConfigureAccessPoints(fpConfigurationFilePointer);
fnConfigureWirelessNodes(fpConfigurationFilePointer);
}
fnCreateConnectionConfiguration(FILE* fpConfigurationFilePointer){
fnCreateRouterRouterLinks(fpConfigurationFilePointer);
fnCreateRouterSwitchLinks(fpConfigurationFilePointer);
fnCreateSwitchWiredNodeLinks(fpConfigurationFilePointer);
fnCreateSwitchAccessPointLinks(fpConfigurationFilePointer);
fnCreateAccessPointWirelessNodesLinks(fpConfigurationFilePointer);
}
fnConfigureRouters(FILE* fpConfigurationFilePointer){
{
}
}
fnConfigureSwitches(FILE* fpConfigurationFilePointer){
{
}
}
fnConfigureWiredNodes(FILE* fpConfigurationFilePointer){
{
fnCreateWiredNodeInterface(fpConfigurationFilePointer,
nLoopCounterI);
fnCreateWiredNodeTransportLayer(fpConfigurationFilePointer);
fnCreateWiredNodeApplicationLayer(fpConfigurationFilePointer,
nLoopCounterI);
}
}
fnConfigureAccessPoints(FILE* fpConfigurationFilePointer){
{
fnCreateAccessPointInterfaces(fpConfigurationFilePointer,
nLoopCounterI);
}
}
fnConfigureWirelessNodes(FILE* fpConfigurationFilePointer){
{
fnCreateWirelessNodeInterface(fpConfigurationFilePointer,
nLoopCounterI);
fnCreateWirelessNodeTransportLayer(fpConfigurationFilePointer);
fnCreateWirelessNodeApplicationLayer(fpConfigurationFilePointer,
nLoopCounterI);
}
}
164
Sample Input:
Device
Minimum
Maximum
Routers
Switches
Wired Nodes
Access Points
Wireless Nodes
1
5
2
8
12
3
6
2
9
13
On entering the above details the following configuration files are created and simulation is
run for all these configuration files.
Routers
Switches
Wired
Access Points
Nodes
1
1
1
1
1
5
5
5
5
6
2
2
2
2
2
Wireless
Configuration file
Nodes
8
8
9
9
8
12
13
12
13
12
165
Configuration1.5.2.8.12.xml
Configuration1.5.2.8.13.xml
Configuration1.5.2.9.12.xml
Configuration1.5.2.9.13.xml
Configuration1.6.2.8.12.xml
1
1
1
2
2
2
2
2
2
2
2
3
3
3
3
3
3
3
3
6
6
6
5
5
5
5
6
6
6
6
5
5
5
5
6
6
6
6
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
2
8
9
9
8
8
9
9
8
8
9
9
8
8
9
9
8
8
9
9
13
12
13
12
13
12
13
12
13
12
13
12
13
12
13
12
13
12
13
Configuration1.6.2.8.13.xml
Configuration1.6.2.9.12.xml
Configuration1.6.2.9.13.xml
Configuration2.5.2.8.12.xml
Configuration2.5.2.8.13.xml
Configuration2.5.2.9.12.xml
Configuration2.5.2.9.13.xml
Configuration2.6.2.8.12.xml
Configuration2.6.2.8.13.xml
Configuration2.6.2.9.12.xml
Configuration2.6.2.9.13.xml
Configuration3.5.2.8.12.xml
Configuration3.5.2.8.13.xml
Configuration3.5.2.9.12.xml
Configuration3.5.2.9.13.xml
Configuration3.6.2.8.12.xml
Configuration3.6.2.8.13.xml
Configuration3.6.2.9.12.xml
Configuration3.6.2.9.13.xml
Output Files:
Configuration1.5.2.8.12.xml_Metrics.txt is the metrics file created for configuration file
Configuration1.5.2.8.12.xml. Similarly other output files like
Configuration1.5.2.8.12.xml_log_file.txt are created. Output files for all the configuration
files with the name of the configuration file as the prefix are generated.
All the configuration files which are not created due to various reasons (explained in the
programs code comments) are listed in NetSim_Batch_Log.txt.
166
9 Programming Exercises
This menu contains network programming exercises and is not available in Pro version.
Run down the menu and select the desired programming exercise. The programs available are
as follows,
Cryptography
o Substitution
o Transposition
o XOR
o Advanced
RSA
Framing Sequence
o Bit Stuffing
o Character Stuffing
IPV4 Addressing
o Address Mask
o Binary Conversion
o Classless InterDomain Routing
o Network Address
o Special Addresses
167
o Subnetting
IPV6 Addressing
o EUI - 64 Interface Identifier
o Host Addresses
o Subnetting
PC to PC Communication
o Socket Programming
o Chat Application
Scheduling
Shortest Path
Sorting Techniques
Spanning Tree
NetSims Programming Lab has been designed to provide hands - on network programming
skills to students. The labs come with a GUI where students can first run the experiment in
Sample mode and subsequently link their own code and visualize its working. Programs
can be written in C and the executable can be linked to NetSim.
168
9.1 Architecture
The following Architecture is applicable for all the exercises under the Programming
menu. Each exercise has two modules
Using the Input - Output module inputs are given and output is viewed. The working of the
concept/algorithm is done in the process module. The link between the Input - Output
module and process module is as follows
Input - Output
Input
Process
Input Text file
(Input.txt)
Read Input
Process
Output
Write Output
Process is the module for which the user has to write and link the written code when using the
user mode.
The code can be written either by C or C++, the executable file created should be linked to
the software.
The input and output file format should be as required, as they form the link between the
software and the user executable file.
169
2. Select Win32Console Application. Name the project and select location to save the
project and then click OK button.
170
3. Click Next Check Whether Console application is selected or not. If selected, then
select Empty Project, otherwise select Console application and Empty Project and
finally click Finish button.
4. Add source codes to the project. Right click on the Source FilesAddNew Item
171
5. Select c++ File (.cpp) and name the file with extension of .c
172
8. Select the mode for creating the exe i.e., debug or release mode by choosing the
required option as shown in the figure. The preferred setting is debug mode.
173
174
There are three cases for creating Exe (.exe) file using GCC.
Case 1: C programs
1. Set the path as C program path
4. Once exe file is created link that exe file with NetSim Programming User mode
175
4. Once exe file is created link that exe file with NetSim Programming User mode
Case 3: Socket programs
1. Set the path to Socket program location.
176
4. Once exe file is created link that exe file with NetSim Programming User mode
Dev C++ will create the exe file in the same location where the C source code file is
located
2. Once exe file is created , link that exe file with NetSim Programming User mode
Note: For Windows 8 and above, use Dev C++ v 5.11
177
In the C Includes tab add the follwing path in the text box provided and click on add button.
C:\Dev-Cpp\lib\gcc\mingw32\3.4.2\include
178
179
Step 2:
For user to write their own C Code in NetSim and check the result, click on Concept
Algorithm Pseudo Code and Flowchart (present in Help in the left pane) and understand the
working of the algorithm.
Step 3:
Then click on Interface Source Code (present in Help in the left pane).
Open Dev C++ or any GNU C compiler based IDK and copy the code from the Interface
Source Code.
The user needs to edit the Interface Source Code at the following location. For Example,
int fnCrc12(char* pszString)
{
// Write your own code here
}
So the user needs to write the code, create exe and attach it with NetSim to run.
Step 4:
Create .exe file. In the left panel, select the Mode as User. Select the .exe file created above.
Set the input and click Run. So presently NetSim will run code which is written by the user
and will display the result graphically.
In case of any error, ERROR IN USER CODE message will be displayed.
180
3. Right click on your project in the Solution Explorer pane and select properties as shown
below
181
4. Inside the properties window select Debugging and edit the Command Arguments as
shown
Files
(x86)\NetSim
Standard\bin\NetSim.exe"
"C:\Users\George
6. Now add a breakpoint to your code in your function or in the main ( ), and proceed with
de-bugging
7. At the end check if the output.txt present in the %temp%\NetSim path and the temp.txt
present in the %temp%\NetSim path are exactly similar. Exact similarity would indicate
that your code will work fine when you run it in use mode the next time.
183
An example format of input.txtis given below, The second line has the flag value
(important) that is used for the animation.
Number_of_Nodes=3
The result for the above is:
Node1_IP_Address=192.168.1.1
Node2_IP_Address=192.168.1.2
Source is Class C.Destination is present in
Node3_IP_Address=192.168.1.3
that class 2
Source_Node_IP_ Address=192.168.1.3
Destination_Node_IP_Address=192.168.1.1
184
Sample Scenario:
Objective - To find the Medium Access Control (MAC) Address of the Destination Node
using Address Resolution Protocol (ARP).
How to Proceed? - The objective can be executed in NetSim by using the programming
exercise available. In the Programming menu select Address Resolution Protocol(ARP).
Sample Input - By using the Input Panel that is available on the left hand side a Sample
Scenario is created. The Steps involved in creating are as follows,
List of NodesNumbers along with their IPAddresses that would be availed are,
Node Numbers
IP Address
1
2
3
4
5
6
192.168.1.1
192.168.1.2
192.168.1.3
192.168.1.4
192.168.1.5
192.168.1.6
ARP Request System and ARP Reply System needs to be selected. That is,
1. ARP Request System 192.168.1. 1 (Any one Node Number to be
selected)
2. ARP Reply System 192.168.1. 6 (Any one Node Number to be selected)
185
The Source Node (i.e. Node Number 1 in the above example) sends the ARP
Request to the Connecting Device.
The Connecting Device then broadcasts the ARP Request to all the Nodes
available in the network.
The Destination Node (i.e. Node Number 6 in the above example) sends an
acknowledgement in the form of ARP Reply (i.e. The Destination MAC MAC Address of the Destination Node) to the Connecting Device.
The Device then transmits the ARP Reply (i.e. The Destination MAC - MAC
Address of the Destination Node) only to the Source Node.
Once the sample experiment is done, then Refresh button can be clicked to
create new samples.
186
Number_of_Sites=2
Number_of_Concentrators=2
Sites_per_Concentrator=1
Selected_Priority=1>0>
Distance
1>2>
3>4>
2>1>
1>2>
In each line, the first character indicates the
site and the rest indicates the concentrators.
The second character (excluding the >
symbol) is the first concentrator found with
minimum distance/cost. The third character
is a concentrator, which has the minimum
distance/cost compared to the previous one
and so on.
Sample Scenarios:
Objective - To allocate the resource which is concentrator to the require system which is
sites based on the distance for each sites to concentrator.
How to proceed? - The objective can be executed in NetSim using the programming exercise
available, under programming user has to select Assignment of Sites to Concentrator.
Sample Input - By using the Input Panel that is available on the left hand side a Sample
Scenario is created. The Steps involved in creating are as follows,
Number of Sites need to be selected. The value that has selected ranges from 1 to
7.
Number of Sites / Concentrators need to be selected. The value that has selected
ranges from 1 to 7.
Click on the image to select Priority. Click on Change Priority to reset the
Priority of the Sites.
Enter the Distance in the given table. Distance should be in the range, 1 to 99 km.
Then Run button need to be clicked. Refresh button can be used if new Inputs
have to be given.
Click on Concept, Algorithm, Pseudo Code & Flow Chart to get help on it.
188
The site which has the highest priority searches for a concentrator which is the
nearest.
A red line appears between the site and a concentrator. This indicates the only
shortest path available between the site and the concentrators. Hence, it
indicates the site has been allocated to that concentrator.
A site can have only one concentrator, whereas a concentrator can have many
sites linked to it.
Once the sample experiment is done, then Refresh button can be clicked to
create New Samples.
189
Cryptographic_Method=Encryption
t>u>v>
Plain_Text:
e>f>g>
tetcos
t>u>v>
Key_Text:
c>d>e>
o>p>q>
for
the
s>t>u>
191
Cryptographic_Method=Decryption
v>u>t>
Cipher_Text:
g>f>e>
vgvequ
v>u>t>
Key_Text:
e>d>c>
q>p>o>
u>t>s>
Sample Scenarios:
Objective - Encrypt and decrypt the message with the same key value using Substitution.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under programming user has to select Cryptography Substitution.
Encryption:
Sample Input: In the Input panel the following steps need to be done,
Enter the Plain Text that needs to be encrypted. Maximum of 8 alphabets need
to be entered.
Enter the Key Value. This is an Integer which is within the range 0 to 26.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
Decryption:
Sample Input: In the Input panel the following steps need to be done,
Cipher Text obtained while encryption is filled in the Plain Text and also the
Key Text is same as that entered while encrypting.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
194
Cryptographic_Technique=Transposition
Cryptographic_Method=Encryption
Plain_Text:
TETCOS
Key_Text:
BLORE
1>3>4>5>2>
T>E>T>C>O>S>T>E>T>C>
T>S>O>C>E>T>T>E>C>T>
Cryptographic_Technique=Transposition
BELOR>
Cryptographic_Method=Decryption
1>5>2>3>4>
Cipher_Text:
T>O>E>T>C>S>C>T>E>T>
TSOCETTECT
Key_Text:
BLORE
Interface Source Code
Interface Source code written in C is given using this the user can write only the
Transposition-Decryption inside the function fnTranspositionDecryption() using the variables
already declared.
To view the interface source code, go to
NetSim Installation path / src / Programming/ TranspDecrypt.c
To find NetSims Installation path right click NetSim icon and select
196
Sample Scenarios:
Objective - Encrypt and decrypt the message with the same key text using Transposition.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under programming user has to select Cryptography Transposition.
Encryption:
Sample Input: In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
Once the sample experiment is done, then Refresh button can be clicked
to create New Samples.
Decryption:
Sample Input: In the Input panel the following steps need to be done,
The Cipher Text obtained for Encryption is the Cipher Text for
Decryption. This would be automatically taken. Maximum of 14
Characters can be entered.
197
Enter the Key Value will also be taken internally. Maximum of 8 alphabets
can be entered.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
The entered Key Value would be displayed first. This is arranged in such a
way that the order is changed when compared to Encryption.
Once the sample experiment is done, then Refresh button can be clicked
to create New Samples.
198
Cryptographic_Technique=XOR
Cryptographic_Method=Encryption
Plain_Text:
TETCOS
Key_Text:
BNLORE
01010100>01000010>00010110>
01000101>01001110>00001011>
01010100>01001100>00011000>
01000011>01001111>00001100>
01001111>01010010>00011101>
01010011>01000101>00010110>
Cryptographic_Technique=XOR
00010110>01000010>01010100>
Cryptographic_Method=Decryption
00001011>01001110>01000101>
Cipher_Text:
00011000>01001100>01010100>
00010110000010110001100000001100000
1110100010110
00001100>01001111>01000011>
Key_Text:
00010110>01000101>01010011>
00011101>01010010>01001111>
BNLORE
To find NetSims Installation path right click NetSim icon and select
Sample Scenarios:
Objective - Encrypt and Decrypt the message by using the same KeyText in XOR.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming menu select Cryptography XOR.
Note:Encryption should be done first and then Decryption should be done.
Encryption:
Sample Inputs - By using the InputPanel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
o SampleMode should be selected.
o EncryptionMode needs to be selected.
o PlainText and KeyValue need to be entered in the fields available. That
is,
Note: If the length of the PlainText and Key Value differs then an error
would pop out.
o Then Run button need to be clicked.
Output - Output for the above Sample is as follows,
o Plain Text
t e t c o s
o Key Text
1 2 3 4 5 6
01110011
00110110
o XOR Value
01000101
o ASCII Equivalent
69 87 71 87 90 69
o Cipher Text
201
W G
Decryption:
Sample Inputs - By using the InputPanel that is available on the left hand side a Sample
Scenario is created. The Steps involved in creating are as follows,
o SampleMode should be selected.
o After completing the Encryption part, DecryptionMode needs to be
selected.
o CipherText (this field is automatically filled) and KeyValue (this should
be same as the one that is entered in Encryption) need to be entered in the
fields available. That is,
CipherText
010001010101011101000111010101110101101001000101 (Cipher
Text in Binary Format Maximum 64 bits)
Note - Both Cipher Text and Key Text is automatically taken when
Decryption button is selected (i.e. after undergoing Encryption).
o Then Run button need to be clicked.
Output - Output for the above Sample is as follows,
E
o Cipher Text
o Key Text
116
99
01000101
00110110
o XOR Value
01110011
o ASCII Equivalent
116 101
o Plain Text
111
115
Note o Text in the Input of the Encryption and Output of the Decryption
should be the same if the Key Value is same.
o The Cipher Text in case of Encryption is Alpha Numeric (i.e. for the
user to understand in a better manner)and in case of Decryption the tool
converts it to Binary form (i.e. since, the tool doesnt recognize Alpha
Numeric).
202
203
204
205
206
207
To find NetSims Installation path right click NetSim icon and select
Sample Scenarios:
Objective - Encrypt and decrypt the message with the using DES.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under programming user has to select
CryptographyAdvancedDataEncryptionStandard.
Encryption:
Sample Inputs - In the Input panel the following steps need to be done,
Enter the Key Text in the provided field. Only hexadecimal characters
have to be entered. Maximum of 16 characters can be entered in this field.
Characters more than 16 will be filled in the Data field.
Data needs to be entered in this field that has to be encrypted. Data can be
entered only when the Enter Key Text field is filed with 16 hexadecimal
characters. Maximum of 1500 characters can be stuffed into this field.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
Output
Click on Copy button and then on the Paste button to make use of the
Cipher text for Decryption.
209
Once the sample experiment is done, then Refresh button can be clicked
to create New Samples.
Decryption:
Sample Inputs - In the Input panel the following steps need to be done,
Once the Encryption is done, click on Copy and Paste buttons. The
encrypted data is filled in the data field available in the Decryption view.
Fields such as Enter the Key Text, Number of Iteration and Data is filled
in automatically when Copy and Paste button is clicked.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
The Data that was entered in the Encryption view would be encrypted and
displayed.
Once the sample experiment is done, then Refresh button can be clicked to
create New Samples.
210
211
Sample Scenario:
Objective - Encrypt and decrypt the message with the using DES.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under programming user has to select
CryptographyAdvancedRSA.
Sample Inputs - In the Input panel the following steps need to be done,
Plain Text of only one character has to be entered in the field available.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
212
Cryptographic_Method=Encryption
Data:
Initialization Vector
TETCOS
Key Text
Cipher Text
Ex:
8A699C
0123456789
364130B9CA018D5B760383CD85528751
To find NetSims Installation path right click NetSim icon and select
214
Plain text
Initialization_Vector=8A699C
Ex:
Key=0123456789
TETCOS
Data: 364130B9CA018D5B760383CD85528751
215
Sample Scenarios:
Objective - Encrypt and Decrypt the message by using WEP.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In Programming menu select CryptographyAdvancedWired
Equivalent Privacy.
Note: Encryption should be done first and then Decryption should be done.
Encryption
Sample Inputs - By using the Input Panel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
o SampleMode should be selected.
o Under CryptographicMethod, Encryption Mode needs to be selected.
o InputData (Maximum of 1500 Characters) - NetSim TetCos
Bangalore
o Then Run button need to be clicked.
216
Key : ABCDEF0123
217
Router_ID=1>Router_Name=Router_1>No_Of_Neig
hbour=2>Neighbours_ID=2>5
Router_ID=2>Router_Name=Router_2>No_Of_Neig
hbour=1>Neighbours_ID=1
Router_ID=3>Router_Name=Router_3>No_Of_Neig
hbour=0
Ex:
Router_ID=4>Router_Name=Router_4>No_Of_Neig
hbour=0
0>1>5>1>0
Router_ID=5>Router_Name=Router_5>No_Of_Neig
hbour=1>Neighbours_ID=1
0>5>1>1>0
Router_ID=6>Router_Name=Router_6>No_Of_Neig
hbour=0
0>1>2>1>0
0>2>1>1>0
1>1>2>1>0
1>1>5>1>0
1>2>1>1>0
1>2>5>2>1
1>5>1>1>0
1>5>2>2>1
218
2>1>2>1>0
2>1>5>1>0
2>2>1>1>0
2>2>5>2>1
2>5>1>1>0
2>5>2>2>1
Sample Scenarios:
Objective - Find the Shortest Path using Distance Vector Routing.
How to Proceed? - The objective can be executed in NetSim by using the programming
exercise available. In the Programming menu selectDistance Vector Routing.
Sample Input -Follow the below given steps,
Click on two Routers to establish a Path (i.e. 1st Click on Router number 1
and 2, then similarly on Router number 2 and 3, 3 and 4, 4 and 5, 5 and 6,
& 6 and 1).
219
Initial button can be clicked to view the initial table of the all router.
Intermediate button can be clicked to view the intermediate table of the all router.
Final button can be clicked to view the final table of the all router.
220
9.5.15
Programming Guidelines
This section guides the user to link his/her own code for Dynamic Host Configuration
Protocol to NetSim.
Pre - Conditions
The user program should read the input from text file named Input with extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note: The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Input File Format
Number_of_Clients = 4
Start_Address = 192.168.0.105
End_Address = 192.168.0.109
Mask = 255.255.255.0
DHCP_DISCOVER>
Node1>Node2>
Node1>Node3>
Node1>Node4>
Node1>Server
DHCP_OFFER>
Server>Node1
DHCP_REQUEST>
Node1>Server
DHCP_ACK>
Server>192.168.0.105
DHCP_DISCOVER>
Node2>Node1>
Node2>Node3>
Node2>Node4>
Node2>Server
DHCP_OFFER>
Server>Node2
DHCP_REQUEST>
Node2>Server
221
DHCP_ACK>
Server>192.168.0.106
DHCP_DISCOVER>
Node3>Node1>
Node3>Node2>
Node3>Node4>
Node3>Server
DHCP_OFFER>
Server>Node3
DHCP_REQUEST>
Node3>Server
DHCP_ACK>
Server>192.168.0.107
DHCP_DISCOVER>
Node4>Node1>
Node4>Node2>
Node4>Node3>
Node4>Server
DHCP_OFFER>
Server>Node4
DHCP_REQUEST>
Node4>Server
DHCP_ACK>
Server>192.168.0.108
Sample Scenarios:
Objective - Find the Shortest Path using Dynamic Host Configuration Protocol.
222
How to Proceed? - The objective can be executed in NetSim by using the programming
exercise available. In the Programming menu selectDynamic Host Configuration
Protocol.
Sample Input -Follow the below given steps,
223
9.5.16
Programming Guidelines
This section guides the user to link his/her own code for Hamming Code Generator to
NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
The path of the input file and the output file can be viewed on clicking the Button Path in
NetSim.
Note: The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
Input file format
Parity=Odd
Data=a
Error_Position=7
Data_Bits_Original=01100001 1 and 2 are the check bits that vary in the Hamming String. The
last value is the actual position in the Hamming Code generated
Data_Bits_Error=00100001
where the data bits has been changed.
4 - The number of check bits introduced
3>5>7>9>11>13>0>0>- the check bit of position 1 of input
data
3>6>7>10>11>1>1>- the check bit of position 2 of input data
5>6>7>12>13>0>0>- the check bit of position 4 of input data
9>10>11>12>13>0>0>- the check bit of position 8 of input
224
data
3>5>7>9>11>13>0>0>- the check bit of position 1 of error
data
3>6>7>10>11>1>1>- the check bit of position 2 of error data
5>6>7>12>13>1>1>- the check bit of position 4 of error data
9>10>11>12>13>1>1>- the check bit of position 8 of error
data
4>8>12>- the check bit position whose value has been changed
and the final error position.
Interface Source Code
To view the interface source code, go to
NetSim Installation path / src / Programming/ HammingCode.c
To find NetSims Installation path right click NetSim icon and select
Sample Scenarios:
Objective - To detect and correct the single bit error occurs in the transmission of data.
How to proceed? - The objective can be executed in NetSim using the programming exercise
available, under programming user has to select Error Correcting Code Hamming Code
Sample Inputs - In the Input panel the following steps need to be done,
Error Position needs to be selected. Based on the input, its values ranges.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
Depending on the Parity selected, tables of Hamming String, Original Data and
Error Data will be obtained.
For the Error Data table to be obtained click on the Next button available in the
output panel. When the Error Data table is obtained Error Position value is
also obtained.
Once the sample experiment is done, then Refresh button can be clicked to
create New Samples.
226
9.5.17
Programming Guidelines
This section guides the user to Run his/her own code for Cyclic Redundancy Check to
NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note: The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Input File Format
Algorithm=CRC_12
Condition=No_Error
File_Path=C:\Users\P.Sathishkumar\Docum
ents\1 Th.txt>
227
Sample Scenarios:
Objective - To detect the error found in the file transferred between a Sender and Receiver
using CRC12.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming Menu selectError Detecting CodesCyclic
Redundancy Check.
Sample Input
228
3. Under Input, Enter the path of the file name to get its CRC.The file
should be in .txt format which should not exceed 5000bytes.
4. Click on Run button to execute. Refresh button can be used if new Inputs
have to be given.
Sample Output
For No Error Case: The CalculatedCRC should be Zero when the .txt file is
received by the Node2. The message Data Frame is Flowing from Node1 to
Node2 with No Error.
For Error Case: The CalculatedCRC should be Non-Zero when the .txt file
is received by the Node2. The message Data Frame is Flowing from Node1 to
Node2 with Error.
229
Algorithm=CRC_16
Condition=No_Error
File_Path=C:\Users\P.Sathishkumar\Doc
uments\1 Th.txt>
Sample Scenarios:
Objective - To detect the error found in the file transferred between a Sender and Receiver
using CRC16.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming menu selectError Detecting CodesCyclic
Redundancy Check.
Sample Input
231
Sample Output
For No Error Case: The CalculatedCRC should be Zero when the .txtfile
is received by the Node2. The message DataFrame is Flowing from Node1
to Node2 with NoError.
232
Algorithm=CRC_32
Condition=No_Error
To find NetSims Installation path right click NetSim icon and select
Sample Scenarios:
Objective - To detect the error found in the file transferred between a Sender and Receiver
using CRC32.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming menu selectError Detecting CodesCyclic
Redundancy Check.
Sample Input
Sample Output
235
Algorithm=CRC_CCITT
Condition=No_Error
File_Path=C:\Users\P.Sathishkumar\Document
s\1 Th.txt>
Sample Scenarios:
Objective - To detect the error found in the file transferred between a Sender and Receiver
using CRC CCITT.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming menu selectError Detecting CodesCyclic
Redundancy Check.
Sample Input
Sample Output
For No Error Case: The CalculatedCRC should be Zero when the .txtfile is
received by the Node2. The message DataFrame is Flowing from Node1 to
Node2 with NoError.
For Error Case: The CalculatedCRC should be Non-Zero when the .txt file
is received by the Node2. The message DataFrame is Flowing from Node1 to
Node2 with Error.
238
Input.txt file has the original data bits, the type of parity
(odd or even) and the error data bits.
Parity=Odd (or Even)
Data=Tetcos
239
Sample Scenarios:
Objective - To study the working of Longitudinal Redundancy Check (LRC)
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select Error Detecting Codes in that
Longitudinal redundancy Check,
Sample Input - In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
9.5.22
Programming Guidelines
This section guides the user to link his/her own code for Bit Stuffing to NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt which is in Temporary Directory. The user program after executing the concept should
write the required output to a file named Output with extension txt in Temporary
Directory.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Input File
Output File
Destination Address=Value
Message=Value>
Source Address=Value
H=Value>e=Value>l=Value>l=Value>o=Value>
Data=Message
CRC Polynomial=Value
Error Status=0 or 1
Seed Value=Value
<Stuffing>
Destination Address= Value >
Example:
Destination Address=00011111
Source Address=00111111
<DeStuffing>
Data=Hello
241
CRC Polynomial=10010
Error Status=0
Seed Value=45
242
Sample Scenarios:
Objective - To study the working of Bit Stuffing technique.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select Framing Sequence Bit Stuffing.
Sample Inputs - In the Input panel,
Then Run button needs to be clicked. Refresh button can be used if new
Inputs have to be given.
Data will be converted into ASCII Values. ASCII Values will be converted
into Binary Values.
HDLC frame will be formed in Sender side and Bit Stuffing process is
animated (Adding 0 for every consecutive five 1s).
Finally the ASCII values will be converted into Data which the user
entered.
244
9.5.23
Programming Guidelines
This section guides the user to link his/her own code for Character Stuffing to NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt which is in Temporary Directory
The user program after executing the concept should write the required output to a file
named Output with extension txt in Temporary Directory.
Note: The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Input File
Output File
Starting Delimiter=Value
Stuffing>
Destination Address=Value
Destination Address=Value>
Source Address=Value
Data=Value
Data= Value>
Checksum=Value
Checksum= Value>
Ending Delimiter=Value
DeStuffing>
Example:
Starting Delimiter=a
Destination Address=eraerwbr
Data= Value>
Source Address=asdasdas
Checksum= Value>
Data=sdfgf
Example:
245
Checksum=shfsdfsd
Stuffing>
Ending Delimiter=h
Destination Address=eraaerwbr>
Source Address=aasdaasdaas>
Data=sdfgf>
Checksum=shhfsdfsd>
DeStuffing>
Destination Address=eraerwbr>
Source Address=asdasdas>
Data=sdfgf>
Checksum=shfsdfsd>
Sample Scenarios:
Objective - To study the working of Character Stuffing technique.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select Framing Sequence Character
Stuffing.
Sample Input - In the Input panel the following steps need to be done,
246
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
247
9.5.24
Programming Guidelines
This section guides the user to link his/her own code for Virtual Scheduling Algorithm to
NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file
named Output with extension txt.
The path of the input file and the output file can be viewed on clicking the Button Path in
NetSim.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
Input File Format
Input File Content
PCR=1
CDVT=0.200
Actual_Arriva_Time=0.100
Previous_Theoratical_Time=0.000
248
Sample Scenarios:
Objective - To study the working of Virtual Scheduling Algorithm.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select Virtual Scheduling Algorithm,
Sample Input - In the Input panel the following steps need to be done,
Select the Peak Cell Rate (PCR). Its value ranges from 1 to 10.
Select the Cell Delay Variation Tolerance (CDVT). Its value ranges from 0.1
to 0.9.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
249
250
9.5.25
Address Mask
Programming Guidelines
This section guides the user to link his/her own code for Address mask to NetSim.
Pre - Conditions
The user program should read the input from text file named Input with extension txt.
The user program after executing the concept should write the required output to a file
named Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File
Output File
This gives us the contents of the Input. Txt The Output File format
from which the user has to get the values
Binary value of IP Address>
for his program
Prefix value>Suffix value>
The Input File format
Binary value of Address mask>
IP Address>
Decimal value of Address mask>.
Sample Input text Format
Sample Output text Format
Let us consider how a given input (Data
11000000 10101001 00000000 10010110 >
file and error index) is stored in the text
and read.
1>31>
IP_Address=192.169.0.150
Prefix_Value=1
Sample Scenarios:
Objective - To understand the concept of finding Address mask through programming.
Sample Inputs - In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
252
9.5.26
Binary Conversion
Programming Guidelines
This section guides the user to link his/her own code for Binary conversion to NetSim.
Pre - Conditions
The user program should read the input from text file named Input with extension txt.
The user program after executing the concept should write the required output to a file
named Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File Format
Previous remainder>64>Quotient of
Previous remainder/64>Remainder of
Previous remainder /64>
IP Address>
Sample Input text Format
IP_Address=192.168.0.100
Previous remainder>32>Quotient of
Previous remainder/32>Remainder of
Previous remainder /32>
Previous remainder>16>Quotient of
Previous remainder/16>Remainder of
Previous remainder /16>
Previous remainder>8>Quotient of Previous
remainder/8>Remainder of Previous
remainder /8>
Previous remainder>4>Quotient of Previous
remainder/4>Remainder of Previous
253
remainder /4>
Previous remainder>2>Quotient of Previous
remainder/2>Remainder of Previous
remainder /2>
Previous remainder>1>Quotient of Previous
remainder/1>Remainder of Previous
remainder /1>.
.same procedure for all bytes
Binary value>
Sample Output text Format
192>128>1>64>
64>64>1>0>
0>32>0>0>
0>16>0>0>
0>8>0>0>
0>4>0>0>
0>2>0>0>
0>1>0>0>
168>128>1>40>
40>64>0>40>
40>32>1>8>
8>16>0>8>
8>8>1>0>
0>4>0>0>
0>2>0>0>
0>1>0>0>
0>128>0>0>
0>64>0>0>
0>32>0>0>
0>16>0>0>
0>8>0>0>
0>4>0>0>
0>2>0>0>
0>1>0>0>
100>128>0>100>
100>64>1>36>
254
36>32>1>4>
4>16>0>4>
4>8>0>4>
4>4>1>0>
0>2>0>0>
0>1>0>0>
11000000 10101000 00000000 01100100 >
Sample Scenarios:
Objective - To understand the concept of Binary conversion through programming.
Sample Inputs - In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
255
Once the sample experiment is done, then Refresh button can be clicked to
create New Samples.
256
9.5.27
Programming Guidelines
This section guides the user to link his/her own code for Classless Inter Domain Routing to
NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file
named Output with extension txt.
The path of the input file and the output file can be viewed on clicking the Button Path in
NetSim.
Note:
The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File Format
No_of_Networks=3
No_of_Hosts_in_Network_1=512
No_of_Hosts_in_Network_2=1024
No_of_Hosts_in_Network_3=2048
257
Host_IP_Address=150.0.1.2
network.
Value: The value will be either 0 or 1.
0 - The next line has the network address to
which the given host belongs.
1 - Means that the host does not belong to any
network.
Network Address: If the Value is 1 then the
network to which the host belongs is given.
Note: Each data will have a separate line and
each line will end with ">"
A Sample Output File Format
150.0.0.0>
150.0.1.255>
255.255.254.0>
512>
150.0.4.0>
150.0.7.255>
255.255.252.0>
1024>
150.0.8.0>
150.0.15.255>
255.255.248.0>
2048>
0>
150.0.0.0>
For each network there will be first address, last
address, mask and number of hosts. Since the
input is 3 networks, there are 3 set of outputs.
The last two lines give the details about whether
the host is present in any of the network.
Sample Scenarios:
Objective - To Implement Classless InterDomain Routing (CIDR).
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select Classless InterDomain Routing,
Sample Input - By using the Input Panel that is available on the left hand side a Sample
Scenario is created. The Steps involved in creating are as follows,
Select the No. of Networks from the given range. Maximum of 6 networks
can be selected.
Click on Add button to add the No.ofHosts onto the Hosts Field. The use of
Add button depends on the No. of Networks selected. If a new No. of Hosts
has to be added then remove button can be used.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
Once the sample experiment is done, then Refresh button can be clicked to
create New Samples.
260
9.5.28
Network Address
Programming Guidelines
This section guides the user to link his/her own code for Network Addresses to NetSim.
Pre - Conditions
The user program should read the input from text file named Input with extension txt.
The user program after executing the concept should write the required output to a file
named Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File
Output File
IP_Address=192.168.0.140
Prefix_Value=1
261
Sample Scenarios:
Objective - To understand the concept of finding Network Address through programming.
Sample Inputs - In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
262
9.5.29
Special Addresses
Programming Guidelines
This section guides the user to link his/her own code for Special Addresses to NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file
named Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File
Output File
IP_Address=192.168.0.160
Prefix_Value=5
Sample Scenarios:
Objective - To understand the concept of Special Addresses through programming.
Sample Inputs - In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
264
9.5.30
Subnetting
Programming Guidelines
This section guides the user to link his/her own code for Sub-netting to NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
The path of the input file and the output file can be viewed on clicking the Button Path in
NetSim.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File Format
Class=B
Network_Address=128.0.0.0
No_of_Subnets=2
Host_IP_Address=128.0.0.89
Sample Scenarios:
Objective - To understand the concept of Subnetting through programming.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select Subnetting,
Sample Inputs - In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
267
9.5.31
Programming Guidelines
This section guides the user to link his/her own code for EUI 64 Interface Identifier to
NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File
Output File
IPV6_Network_Id=2000:FE21:5931:72
C3
MAC_Address=11-11-FF-FF-12-34
MAC Address>
IPV6 Address>
Sample Output text Format
11-11-FF-FF-12-34>
11-11-FF>FF-12-34>
11-11-FF-FF-FE-FF-12-34>
11>00010001>
0>1>
00010011>13>
13-11-FF-FF-FE-FF-1234>1311:FFFF:FEFF:1234>
2000:FE21:5931:72C3>
2000:FE21:5931:72C3:1311:FFFF:FEFF:1234>
Interface Source Code
Interface source code written in C is given using this the user can write only the fnEUI64 ()
function using the variables already declared. To view the interface source code, go to
NetSim Installation path / src / Programming/ IPV6EUI64.c
To find NetSims Installation path right click NetSim icon and select
Sample Scenarios:
Objective - To understand the concept of EUI 64 Interface Identifier through programming.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select IPV6 Addressing EUI 64
Interface Identifier,
Sample Inputs - In the Input panel the following steps need to be done,
269
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
270
9.5.32
Programming Guidelines
This section guides the user to link his/her own code for IPV6 Host Addresses to NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File Format
IPV6_Address=1111:2222:
3333:4444:AAAA:BBBB:
CCCC:DDDD
Prefix_Length=12
IPV6 Address>
Binary value of IPV6 Address>
Prefix part of IPV6 Address>Suffix part of IPV6 Address>
Prefix part of Starting Address>Suffix part of Starting
Address>
Starting Address in hexa decimal notation>
Prefix part of Ending Address>Suffix part of Ending
Address>
Ending Address in hexa decimal notation>
Sample Output text Format
1111:2222:3333:4444:AAAA:BBBB:CCCC:DDDD>
271
000100010001000100100010001000100011001100110011
010001000100010010101010101010101011101110111011
11001100110011001101110111011101>12>116>
000100010001>00010010001000100010001100110011001
101000100010001001010101010101010101110111011101
111001100110011001101110111011101>
000100010001>00000000000000000000000000000000000
000000000000000000000000000000000000000000000000
000000000000000000000000000000000>
1110:0000:0000:0000:0000:0000:0000:0000>
000100010001>11111111111111111111111111111111111
111111111111111111111111111111111111111111111111
111111111111111111111111111111111>
111F:FFFF:FFFF:FFFF:FFFF:FFFF:FFFF:FFFF>
Interface Source Code
Interface source code written in C is given using this the user can write only the
fnHostAddresses () function using the variables already declared. To view the interface
source code, go to
NetSim Installation path / src / Programming/ IPV6HostAddress.c
To find NetSims Installation path right click NetSim icon and select
Sample Scenarios:
Objective - To understand the concept of IPV6 Host Addresses through programming.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select IPV6 Addressing IPV6 Host
Addresses,
Sample Inputs - In the Input panel the following steps need to be done,
272
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
273
9.5.33
IPV6 Subnetting
Programming Guidelines
This section guides the user to link his/her own code for IPV6 Subnetting to NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File Format
Sample Scenarios:
Objective - To understand the concept of IPV6 Subnetting through programming.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select IPV6 Addressing IPV6
Subnetting,
Sample Inputs - In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
276
277
9.5.34
Programming Guidelines
This section guides the user to link his/her own code for Leaky Bucket Algorithm to NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
The path of the input file and the output file can be viewed on clicking the Button Path in
NetSim.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
File Format
Input File
Output_Capacity=100
Buffer_Size=100
Input_Capacity=100,100,500,1
00,100,100,100,100,100,100,
Output File
Output.txt file contains three lines of data. The
data format in the output file should be as follows:
Output rate at 1st second >Output rate at 2nd
second>..>
Discard rate at 1st second >Discard rate at 2nd
second>..>
Total number of seconds taken >
The data should be stored in the file with a delimiter
> in between.
Sample File data
278
100>100>100>100>100>100>100>100>100>100>1
00>
0>0>300>0>0>0>0>0>0>0>0>
11>
Sample Scenarios:
Objective - To understand the concept of Leaky Bucket Algorithm(LBA) through
programming.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming menu user has to select Leaky Bucket Algorithm.
Sample Inputs - In the Input panel the following steps need to be done,
Select the Output Capacity from the given list of values. The value ranges
from 100 to 1000.
Select the Size of Buffer from the given list of values. The value ranges from
100 to 1000.
Enter in the Input Capacity in the fields provided. The range that can be
entered is from 100 to 1000. These values will be plotted in the graph on the
right hand side panel.
279
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
280
9.5.35
Programming Guidelines
This section guides the user to link his/her own code for Multi-Level Multi Access Protocol
to NetSim.
Pre - Condition
User written program should read the value from the Input.txt in the temporary directory
which is having input from the GUI at runtime
The output should be stored in Output.txt in the temporary directory for display.
User written program should return an integer value.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, The results of the program should be written into the
output file Output.txt.
Note:The naming of the input and the output file must be same as the text displayed in the
Methodology screen
File Format
Input File
Output File
Number_of_Nodes=2
Node1_Address=250
Node2_Address=500
Decade No>Decade
Type>Decade>aderess1>adress2>
Sample Output:
0>0>0000100100>
1>1>0000000001>
2>2>0000000001>500>
3>1>0000100000>
4>2>0000000001>250>
281
Sample Scenarios:
Objective - To study the working of Multi Level Multi Access (MLMA).
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select Multi-Level Multi -Access Protocol.
Sample Inputs - In the Input panel the following steps need to be done,
Node Address has to be entered and added onto the Node Address field. The
Number of Nodes selected and the Number of Addresses added into the
Address field should match.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
282
9.5.36
Programming Guidelines
This section guides the user to link his/her own code for Code Division Multiple Access to
NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt which is in Temporary Directory.
The user program after executing the concept should write the required output to a file named
Output with extension txt in Temporary Directory.
Note:The Temporary Directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
File Format
Input File Format
NumberofTransmittingMobilestation MobileStation=Value>Data=Value>code=Value>En
s=Value>
code=Value>Signal=Value>
MobileStation=Value>Data=Value>
Code=Value>
MobileStation=Value>Data=Value>code=Value>En
code=Value>Signal=Value>
MobileStation=Value>Data=Value>
Code=Value>
MobileStation=Value>Data=Value>code=Value>En
ecode=Value>Signal=Value
MobileStation=Value>
Data=Value>Code=Value>
Interference Pattern=Value>
Example:
MobileStation=Value>code=Value>Decode=Value>
Data=Value>
NumberOfTransmittingMobileStatio
ns=2>
MobileStation=Value>code=Value>Decode=Value>
Data=Value>
283
MobileStation=1>Data=10101010>
Code=1 1 1 1 1 1 1 1>
MobileStation=Value>code=Value>Decode=Value>
Data=Value>
MobileStation=2>Data=11110000>
Code=1 -1 1 -1 1 -1 1 -1>
Example:
NumberofMobileStations=2>
MobileStation=1>Data=1 0 1 0 1 0 1 0 >Code=1 1 1
1 1 1 1 1 >Encode=1 -1 1 -1 1 -1 1 -1 >Signal=1 1 1
1 1 1 1 1 -1 -1 -1 -1 -1 -1 -1 -1 1 1 1 1 1 1 1 1 -1 -1 1 -1 -1 -1 -1 -1 1 1 1 1 1 1 1 1 -1 -1 -1 -1 -1 -1 -1 -1
1 1 1 1 1 1 1 1 -1 -1 -1 -1 -1 -1 -1 -1 >
MobileStation=2>Data=1 1 1 1 0 0 0 0 >Code=1 -1
1 -1 1 -1 1 -1 >Encode=1 1 1 1 -1 -1 -1 -1 >Signal=1
-1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1
1 -1 1 -1 1 -1 1 -1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1
1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 >
InterferencePattern=2 0 2 0 2 0 2 0 0 -2 0 -2 0 -2 0 2 2 0 2 0 2 0 2 0 0 -2 0 -2 0 -2 0 -2 0 2 0 2 0 2 0 2 -2
0 -2 0 -2 0 -2 0 0 2 0 2 0 2 0 2 -2 0 -2 0 -2 0 -2 0 >
MobileStation=1>Code=1 1 1 1 1 1 1 1 >Decode=8
-8 8 -8 8 -8 8 -8 >Data=1 0 1 0 1 0 1 0 >
MobileStation=2>Code=1 1 1 1 1 1 1 1 >Decode=8
8 8 8 -8 -8 -8 -8 >Data=1 1 1 1 0 0 0 0 >
Sample Scenarios:
Objective - To study the working of Code Division Multiple Access technique
284
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under programming select Multiple Access Technology Code Division
Multiple Access.
Sample Inputs - In the Input panel the following steps need to be done,
Mobile Station
Binary Data(1Byte)
Code
01110111
11111111
00110011
1 -1 1 -1 1 -1 1 -1
11011101
1 1 -1 -1 1 1 -1 -1
Then Run button needs to be clicked. Refresh button can be used, if new
inputs have to be given.
In Transmitter side, the values of each Mobile Stations Binary Data, Code,
Encode and Signal are shown, if the user clicks the Mobile Station.
The Interference Pattern will be formed in Base Station and if the user
clicks the Base Station, interference Pattern will be displayed.
285
Once the sample experiment is done Refresh button can be clicked to create
new samples.
Transmitter Side
Mobile
Binary
Station
Data(1Byte)
01110111
Code
Encode
Signal
11111111
-1, 1, 1, 1, -1, 1, 1,
-1 -1 -1 -1 -1 -1 -1 -1 1 1 1 1 1
00110011
-1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1
1 -1 1 1 -1 1 -1 1 -1 1 -1 1 -1
1 -1 1 -1 1 -1 -1 1 -1 1 -1 1 -1
1 -1 1 -1 1 -1 1 -1 1 1 -1 1 -1
1 -1 1 -1 1 -1 1 -1 1 -1 1 -1
11011101
1 1 -1 -1 1 1 -1 -
1, 1, -1, 1, 1, 1, -1,
1 1 -1 -1 1 1 -1 -1 1 1 -1 -1 1
1 -1 -1 -1 -1 1 1 -1 -1 1 1 1 1 1 -1 1 1 -1 -1 1 1 -1 -1 1 1 -1 1 1 1 -1 -1 1 1 -1 -1 -1 -1 1 1 1 -1 1 1 1 1 -1 -1 1 1 -1 -1
286
In Base Station
Mobile
Signal
Station
1
-1 -1 -1 -1 -1 -1 -1 -1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
-1 -1 -1 -1 -1 -1 -1 -1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1 1
-1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1
-1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1 1 -1
1 1 -1 -1 1 1 -1 -1 1 1 -1 -1 1 1 -1 -1 -1 -1 1 1 -1 -1 1 1 1 1 -1 -1 1 1 -1 -1
1 1 -1 -1 1 1 -1 -1 1 1 -1 -1 1 1 -1 -1 -1 -1 1 1 -1 -1 1 1 1 1 -1 -1 1 1 -1 -1
Interference
1 1 -3 -1 -1 1 -3 -1 1 3 -1 1 1 3 -1 1 1 -1 3 1 1 -1 3 1 3 1 1 -1 3
Pattern
1 1 -1 -1 1 -3 -1 -1 1 -3 -1 1 3 -1 1 1 3 -1 1 1 -1 3 1 1 -1 3
1 3 1
1 -1 3 1 1 -1
Receiver Side
Mobile
Station
1
Code
Decode
Interference Pattern
1 1 -3 -1 -1 1 -3 -1 1 3
Binary
Data(1Byte)
11111111
-1 1 1 3 -1 1 1 -1 3 1
8 8 8 8 -8 8 8
01110111
1 -1 3 1 3 1 1 -1 3 1 1
-1 -1 1 -3 -1 -1 1 -3 -1 1
3 -1 1 1 3 -1 1 1 -1 3
1 1 -1 3 1 3 1 1 -1 3 1 1
-1
2
1 1 -3 -1 -1 1 -3 -1 1 3
1 -1 1 -1 1 -1 1 -
-8 -8 8 8 -8 - 8 8
-1 1 1 3 -1 1 1 -1 3 1
1 -1 3 1 3 1 1 -1 3 1 1
-1 -1 1 -3 -1 -1 1 -3 -1 1
3 -1 1 1 3 -1 1 1 -1 3
1 1 -1 3 1 3 1 1 -1 3 1 1
287
00110011
-1
3
1 1 -3 -1 -1 1 -3 -1 1 3
1 1 -1 -1 1 1 -1 -
-1 1 1 3 -1 1 1 -1 3 1
1 -1 3 1 3 1 1 -1 3 1 1
-1 -1 1 -3 -1 -1 1 -3 -1 1
3 -1 1 1 3 -1 1 1 -1 3
1 1 -1 3 1 3 1 1 -1 3 1 1
-1
288
8 8 -8 8 8 8 8 8
11011101
9.5.37
Programming Guidelines
This section guides the user to link his/her own code for Time Division Multiple Access to
NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt which is in Temporary Directory.
The user program after executing the concept should write the required output to a file named
Output with extension txt in Temporary Directory.
Note:The Temporary Directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
File Format
Input File Format
Bandwidth=Value>No. of
time slots=Value>Time slot
Length=Value>Guard
Interval=Value>
Example:
channel no=Value>Bandwidth=Value>start
time=Value>End time=Value>user=Value>
Guard Interval =Value>Bandwidth=Value>start
time=Value >end time=Value>nouser=Value>
289
Sample Scenarios:
Objective - To study the working of Time Division Multiple Access technique.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available, under programming user has to select Multiple Access Technology
Time Division Multiple Access.
Sample Inputs - In the Input panel the following steps need to be done,
290
Note:
The Values entered should be within the range.
Bandwidth(kHz)
200
No. of TimeSlots
TimeSlotLength(s)
100
GuardInterval(s)
10
Then Run button need to be clicked. Refresh button can be used, if new
Inputs have to be given.
The first Mobile Station will access the medium in first channel time slot.
The Second Mobile Station will access the medium in second channel
time slot, and so on.
During the guard interval, No mobile station will access the medium. This
is used to avoid the collision or interference.
291
Channel number
Bandwidth(kHz)
Time(s)
Mobile Station
200
0.0 5.0
200
5.0 95.0
200
95.0 100.0
200
100.0 105.0
200
105.0 195.0
200
195.0 200.0
200
200.0 205.0
200
205.0 295.0
200
295.0 300.0
200
300.0 305.0
200
305.0 395.0
.
.
.
292
9.5.38
Programming Guidelines
This section guides the user to link his/her own code for Orthogonal Frequency Division
Multiple Access to NetSim.
Pre-conditions
The user program should read the input scenario from text file named Input with extension
txtwhich is in Temporary Directory.
The user program after executing the concept should write the required output to a file named
Output with extension txtin Temporary Directory.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, the results of the program should be written into the
output file Output.txt.
Input File Format
Value
User1 =Value
User 2
User2 =Value
Value
User3 =Value
User 3
User4 =Value
Value
User 4
User 1
Value
Example:
Number of users = 4
User1 =111111111111
User2 =010101010101
Bit Mapping
User 1
Value
User 2
293
User3 =101010101010
Value
User4 =000000000000
User 3
Value
User 4
Value
SubCarrier Mapping
User 1
Value
User 2
-Value
User 3
Value
User 4
Value
SubCarrier Addition
User 1
Value
User 2
Value
User 3
Value
User 4
Value
Example:
Parallel Data Conversion
User 1
1
User 2
User 3
294
User 4
Bit Mapping
User 1
1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
-1
User 2
User 3
User 4
SubCarrier Mapping
User 1
sin(2PIf0t)
sin(2PIf1t)
sin(2PIf2t)
sin(2PIf3t)
sin(2PIf0t)
sin(2PIf1t)
sin(2PIf2t)
sin(2PIf3t)
sin(2PIf0t)
sin(2PIf1t)
sin(2PIf2t)
sin(2PIf3t)
-sin(2PIf4t)
sin(2PIf5t)
-sin(2PIf6t)
sin(2PIf7t)
-sin(2PIf4t)
sin(2PIf5t)
-sin(2PIf6t)
sin(2PIf7t)
-sin(2PIf4t)
sin(2PIf5t)
-sin(2PIf6t)
sin(2PIf7t)
-sin(2PIf9t)
sin(2PIf10t)
-sin(2PIf11t)
User 2
User 3
sin(2PIf8t)
295
sin(2PIf8t)
-sin(2PIf9t)
sin(2PIf10t)
-sin(2PIf11t)
sin(2PIf8t)
-sin(2PIf9t)
sin(2PIf10t)
-sin(2PIf11t)
User 4
-sin(2PIf12t) -sin(2PIf13t) -sin(2PIf14t) -sin(2PIf15t)
-sin(2PIf12t) -sin(2PIf13t) -sin(2PIf14t) -sin(2PIf15t)
-sin(2PIf12t) -sin(2PIf13t) -sin(2PIf14t) -sin(2PIf15t)
SubCarrier Addition
User 1
sin 2PI(f0+f1+f2+f3)t
sin 2PI(f0+f1+f2+f3)t
sin 2PI(f0+f1+f2+f3)t
User 2
sin 2PI(-f4+f5-f6+f7)t
sin 2PI(-f4+f5-f6+f7)t
sin 2PI(-f4+f5-f6+f7)t
User 3
sin 2PI(f8-f9+f10-f11)t
sin 2PI(f8-f9+f10-f11)t
sin 2PI(f8-f9+f10-f11)t
User 4
sin 2PI(-f12-f13-f14-f15)t
sin 2PI(-f12-f13-f14-f15)t
sin 2PI(-f12-f13-f14-f15)t
Sample Scenarios:
Objective - To study the working of Orthogonal Frequency Division Multiple Access
technique
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under programming select Multiple Access Technology OFDMA
Sample Inputs - In the Input panel,
Then Run button needs to be clicked. Refresh button can be used if new Inputs have to
be given.
The values of each userBinary Data, Parallel Conversion, Bit Mapping, SubCarrier
Mapping&SubCarrier Addition and Transmission will be shown in the right hand side
of the screen by animation.
Once the sample experiment is done Refresh button can be clicked to create new
samples.
297
9.5.39
Programming Guidelines
This section guides the user to link his/her own code for PC to PC Communication Socket
programming to NetSim.
Pre Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Coding Pre Requisites:
The prerequisite for the creation of sockets in the Windows-based C complier is they must
have winsock.h header file in its standard header file folder. In order to use the commands of
the winsock.h, there must be wsock32.lib library file present in the C complier. To link
wsock32.lib, different steps have to be followed for different compilers as shown:
For Visual Studio complier 2010 (10.0 versions), the library file linkage must be
made in the following way:
298
If you have an eclipse complier, the library linkage must be in the following way
299
300
If using Dev C++ IDE, go to Tools->compiler options and add -lws2_32 as follows
before executing:
The data format in the input file is as follows, Write the received message
Server Input
Protocol=TCP
connection
Operation=Server
Client
Protocol=TCP
Operation=Client
Destination IP=192.168.0.132
<Client IP:-Message>
Ex: 192.168.0.2:- Requesting for the
connection
301
302
9.5.40
Programming Guidelines
This section guides the user to link his/her own code for PC to PC Communication Socket
programming to NetSim.
Pre Conditions`
The user program should read the input from text file named Input with extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Coding Pre Requisites:
The prerequisite for the creation of sockets in the Windows-based C complier is they must
have winsock.h header file in its standard header file folder. In order to use the commands of
the winsock.h, there must be wsock32.lib library file present in the C complier. To link
wsock32.lib, different steps have to be followed for different compilers as shown:
For Visual Studio complier 2010 (10.0 versions), the library file linkage must be
made in the following way:
303
If you have an eclipse complier, the library linkage must be in the following way
304
305
If using Dev C++ IDE, go to Tools->compiler options and add -lws2_32 as follows
before executing:
Server Input
Ex:192.168.0.2:-
Protocol= UDP
connection
Operation=Server
Client
Protocol=UDP
Operation=Client
Destination IP=192.168.0.132
<Client IP:-Message>
Ex: 192.168.0.2:- Requesting for the connection
306
Requesting
for
the
Sample Scenarios:
Objective - Send and Receive the data using PC to PCCommunication - SocketProgramming
How to Proceed? -Two Systems are required to perform this experiment. When one System
is in the ServerMode other should be in the Client Mode. The objective can be executed in
NetSim using the programming exercise available. In the Programming menu selectPC to
PC Communication Socket Programming.
Sample Inputs - By using the InputPanel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
307
Sample Output:
On the Right hand side panel there is an InputField ReceivedData, where Data
would get displayed. Hello is the Data that is received from the ClientSystem.
TCP
First the Server should click on the Run button after which the Client should
click on the Run button to Create the socket
Client should click on the Connect button to establish the connection with
server.
The Client should click on the Send button to transmit the data to the Server.
The Client should click on the Close button to terminate the Connection with
Server.
UDP
First the Server should click on the Run button after which the Client should
click on the Run button to Create the socket
The Client should click on the Send button to transmit the data to the Server.
The Client should click on the Close button to terminate the Connection with
Server.
308
9.5.41
Programming Guidelines
This section guides the user to link his/her own code for PC to PC Communication Socket
programming to NetSim.
Pre Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Coding Pre Requisites:
The prerequisite for the creation of sockets in the Windows-based C complier is they must
have winsock.h header file in its standard header file folder. In order to use the commands of
the winsock.h, there must be wsock32.lib library file present in the C complier. To link
wsock32.lib, different steps have to be followed for different compilers as shown:
For Visual Studio complier 2010 (10.0 versions), the library file linkage must be
made in the following way:
309
If you have an eclipse complier, the library linkage must be in the following way
310
311
If using Dev C++ IDE, go to Tools->compiler options and add -lws2_32 as follows
before executing:
312
313
9.5.42
Programming Guidelines
This section guides the user to link his/her own code for PC to PC Communication Socket
programming to NetSim.
Pre Conditions`
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Coding Pre Requisites:
The prerequisite for the creation of sockets in the Windows-based C complier is they must
have winsock.h header file in its standard header file folder. In order to use the commands of
the winsock.h, there must be wsock32.lib library file present in the C complier. To link
wsock32.lib, different steps have to be followed for different compilers as shown:
For Visual Studio complier 2010 (10.0 versions), the library file linkage must be made in the
following way:
314
If you have an eclipse complier, the library linkage must be in the following way
315
316
If using Dev C++ IDE, go to Tools->compiler options and add -lws2_32 as follows
before executing:
317
Sample Scenarios:
Objective - Send and Receive the data using PC to PCCommunication Chat Application
How to Proceed? -Two to Ten Systems are required to perform this experiment.
The objective can be executed in NetSim using the programming exercise available. In the
Programming menu selectPC to PC Communication Chat Application.
Sample Inputs - By using the InputPanel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
On the Right hand side panel there is an InputField Send Data, where Data
needs to be typed in. This Data is later sent to the ReceiverSystem. Here Type
Hello.
On the Right hand side panel there is Receive Data, where data is received
from user. Ex. Hello
Sample Output:
On the Right hand side panel there is an InputField ReceivedData, where Data
would get displayed. Hello is the Data that is received from the users.
TCP
Click Run button to create the socket and start Receive Data from the users.
Click Run button to create the socket and start Receive Data from the users.
UDP
319
9.5.43
Programming Guidelines
This section guides the user to link his/her own code for Scheduling - FIFO to NetSim.
Pre - Conditions
The program should read the data from Input.txt file that is available in the temporary
directory.
The program should write the output data to Output.txt file that is available in the
temporary directory.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, the results of the program should be written into the
output file Output.txt.
Note:The naming of the input and the output file must be same as the text displayed in the
Methodology screen
File Format
Input File Format
Output_Link_Capacity=100
Nodes_Priority=8,7,6,5,4,3,2,1,
Nodes_Capacity=0,0,500,0,0,0,0,0,
320
Sample Scenarios:
Objective - The objective is to allocate the output capacity among the various input
capacities using First In First Out (FIFO) Scheduling algorithm.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming menu selectScheduling.
Sample Input - By using the InputPanel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
321
Node
Priority
Number
Given
1
2
3
4
5
6
7
8
7
6
8
3
2
1
5
4
Output
Note: The Transmission of the data takes place in the following sequence. The Bits /
Node are represented in different colors. These colors indicate the order in which the
transmission takes place.
The Transmission Sequence
Seconds
Node1
100
Node2
100
Node3
100
Node4
100
Node5
100
Node6
100
Node7
100
Node8
100
322
8.
9.5.44
Programming Guidelines
This section guides the user to link his/her own code for Scheduling - MMF to NetSim.
Pre - Conditions
The program should read the data from Input.txt file that is available in the application
path.
The program should write the output data to Output.txt file that is available in the
application path.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, the results of the program should be written into the
output file Output.txt.
Note:The naming of the input and the output file must be same as the text displayed in the
Methodology screen
File Format
Input File Format
323
Sample Scenarios:
Objective - The objective is to allocate the output capacity among the various input
capacities using Max-Min Fare(MMF) Scheduling algorithm.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming menu selectScheduling.
Sample Input - By using the InputPanel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
Output
The Transmission of the data takes place in the following sequence. The Bits / Node
are represented in different colors. These colors indicate the order in which the
transmission takes place.
324
2
4
4
5
5
6
7
7
8.
8
Node1
12.50
12.50
12.50
12.50
12.50
12.50
12.50
12.50
Node2
12.50
12.50
12.50
12.50
12.50
12.50
12.50
12.50
Node3
12.50
12.50
12.50
12.50
12.50
12.50
12.50
12.50
Node4
12.50
12.50
12.50
12.50
12.50
12.50
12.50
12.50
Node5
12.50
12.50
12.50
12.50
12.50
12.50
12.50
12.50
Node6
12.50
12.50
12.50
12.50
12.50
12.50
12.50
12.50
Node7
12.50
12.50
12.50
12.50
12.50
12.50
12.50
12.50
Node8
12.50
12.50
12.50
12.50
12.50
12.50
12.50
12.50
325
9.5.45
Programming Guidelines
This section guides the user to link his/her own code for shortest path Floyds to NetSim.
Pre - Conditions
The program should read the data from Input.txt file that is available in the temporary
directory.
The program should write the output data to Output.txt file that is available in the temporary
directory.
Note: The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, the results of the program should be written into the
output file Output.txt.
File Format
Input file format
Algorithm=Floyds
No_of_Router=3
Distance>0>1>2>1>2>1>
Distance:
Path>0>1>2>1>4>1>
999>5>1>
5>999>10>
1>10>999>
Source_Router=1
Destination_Router=3
Note:
> is the delimiter symbol, which is used
to separate each input.
326
Sample Output:
1>2>3>
1>2>
1>3>
1>
>>>
path_FS>
0>0>0>
0>0>1>
0>1>0>
distance_FS>
0>5>1>
5>0>6>
1>6>0>
Note:
The string Distance and Path in the file is
compulsory. The output must be stored in
the same format
327
Sample Scenarios:
Objective - The objective is to find the Shortest Path between the two Routers using the
Floyds algorithm.
How to Proceed? - The objective can be executed in NetSim using the Programming
exercise available. Under Programming Menu select Shortest Path.
Sample Input - By using
available on the left hand
follows,
Click on 2 Routers to give the distance between those 2 Routers. A blue arrow
would be pointing from the Source Node to the Destination Node. The Distances
between the Routers that needs to be given are as follows,
1. Router 4 and Router 1 67 Km,
2. Router 4 and Router 3 46 Km,
3. Router 3 and Router 1 18 Km,
4. Router 3 and Router 2 56 Km, and
5. Router 1 and Router 2 70 Km.
The Output is obtained in a Routing Table. All possible Routes and the
corresponding Distance are obtained. Below is a Routing Table for the above
Inputs,
328
Route
Distance[KM]
4>1>
67
4>3>1>
64
4>3>2>
102
4>3>
46
4>
Click on Refresh Button to Refresh the screen and create fresh Scenarios.
329
9.5.46
Programming Guidelines
This section guides the user to link his/her own code for shortest path - Link State Routing to
NetSim.
Pre - Conditions
The program should read the data from Input.txt file that is available in the temporary
directory.
The program should write the output data to Output.txt file that is available in the
temporary directory.
Note: The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, the results of the program should be written into the
output file Output.txt.
Input file format
Algorithm=Link_State
No_of_Router=3
Distance:
999>6>5>
6>999>7>
5>7>999>
Source_Router=1
Destination_Router=2
Distance>0>1>2>1>2>1>
Path>0>1>2>1>4>1>
The first line has the all the distance values
from the source node to all the other
connected nodes.
The second line has the path values from
the source node to all the other nodes.
The first line contains the values stored in
the distance array (single dimensional array)
used in the algorithm.
The second line contains the values stored
in the path array (single dimensional array)
used in the algorithm.
Sample Output:
Note:
330
1>2>
1>3>2>
1>3>
1>
>>>
Distance>0>6>5>
Path>1000>1>1>
Note:
The string Distance and Path in the file is
compulsory. The output must be stored in
the same format.
Sample Scenarios:
Objective - The objective is to find the Shortest Path between the two routers using the
Link State algorithm.
How to Proceed? - Under ProgrammingMenu select ShortestPath.
Sample Input - By using the InputPanel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
Click on 2 Routers to give the distance between those 2 Routers. A blue Line
would be pointing from the SourceNode to the DestinationNode. The Distances
between the Routers that needs to be given are as follows,
1. Router 1 and Router 2 35,
2. Router 2 and Router 3 30,
3. Router 3 and Router 4 60,
4. Router 4 and Router 1 20,
5. Router 4 and Router 5 67, and
6. Router 5 and Router 2 58.
Routing Table
Route
Distance[KM]
5>2>1>4>3>
173
5>2>1>4>
113
5>2>1>
93
5>2>3>
88
5>2>
58
5>4>1>2>3>
152
5>4>1>2>
122
5>4>1>
87
5>4>3>
127
5>4>
67
5>
0
332
9.5.47
Programming Guidelines
This section guides the user to link his/her own code for Go Back N to NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Window Size:
The Window Size for Go Back N is 7
Input File Format
Algorithm=Go_Back_N
Value1>Value2>Value3>Value4>
Data_File=C:\Users\P.Sathishkumar\D
ocuments\1 Th.txt>
Types:
Bit_Error_Rate=6
Sequence_Number=3
Window_Size=7
333
Value 4 - "TRANSMIT"
Type2:
Value1 - "DT",
Value 2 -Frame number,
Value 3 - Frames Source address,
Value 4 - Frames Destination address.
Type3:
Value 1 - "EV",
Value 2 - Output of the intro_error function,
Value 3 - Frame Source address,
Value 4 - Frames Destination address.
Type4:
Value 1 - "ACK",
Value 2 - "POS",
Value 3 - Acknowledgement frames Source
Address,
Value 4 - Acknowledgement frames
Destination Address.
Type5:
Value 1 - "DEL"
Value 2 - count of frames being deleted
Value 3 - "FRAME"
Value 4 - "DELETED"
Note: The above convention to write into the
Output.Txt ismandatory.
Values in Quotes"" to be written into file
Output.Txt as it is including Case.
DT>Frame No>node1>node2> (DT denotes
Data from node 1 to node 2)
EV>Error Flag>node1>node2> (EV denotes
Error Value - i.e If the above frame has error
then set the error flag as 1 else set the flag as
0)
ACK>POS>node2>node1>
(Acknowledgement for that above frame
received is sent to node 2 to node 1)
Ex:
CNT>1>FRAMES>TRANSMIT>
334
DT>1>node1>node2>
EV>0>node1>node2>
ACK>POS>node1>node2>
Sample Scenarios:
Objective - Send and receive the data using Sliding Window Protocol - Go BackN.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under ProgrammingMenu select Sliding WindowProtocolGo Back
N.
Sample Input - By using the InputPanel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
SelectGoBackN as Algorithm.
Select the path of the above created Datafile (.txt) which could be Maximum
of 100000bytes.
SelectBit Error Rate (BER) as 10^-5 from the drop down menu.
Count
Data
30
Acknowledgement
5
Total = 35
Note - The Total data frames to be transmitted and Total count in the Output
table depends on size of the .txt file.
3. The details of the DataFrames flowing from Node1 to Node 2 are obtained on the
right hand side panel. Below are the details that is obtained in the tool,
o Data Frame 1 is flowing from Node1 to Node2 with no error.
o Data Frame 2 is flowing from Node1 to Node2 with no error.
o Data Frame 3 is flowing from Node1 to Node2 with no error.
o Data Frame 4 is flowing from Node1 to Node2 with error.
o Data Frame 5 is flowing from Node1 to Node2 with no error.
o Data Frame 6 is flowing from Node1 to Node2 with no error.
o Data Frame 7 is flowing from Node1 to Node2 with error.
o Acknowledgement from Node2 to Node1.
o Data Frame 4 is flowing from Node1 to Node2 with no error.
o Data Frame 5 is flowing from Node1 to Node2 with no error.
o Data Frame 6 is flowing from Node1 to Node2 with no error.
o Data Frame 7 is flowing from Node1 to Node2 with no error.
o Data Frame 8 is flowing from Node1 to Node2 with no error.
o Data Frame 9 is flowing from Node1 to Node2 with no error.
o Data Frame 10 is flowing from Node1 to Node2 with no error.
o Acknowledgement from Node2 to Node1.
o Data Frame 11 is flowing from Node1 to Node2 with no error.
336
Once the sample experiment is done, then Refresh button can be clicked to create
new samples.
337
9.5.48
Programming Guidelines
This section guides the user to link his/her own code for Selective Repeat to NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Window Size:
The Window Size for Selective Repeat is 7
Input File Format
Algorithm=Selective_Repeat
Value1>Value2>Value3>Value4>
Data_File=C:\Users\P.Sathishkumar
\Documents\1 Th.txt>
Types:
Bit_Error_Rate=5
Sequence_Number=3
Window_Size=4
Value 4 - "TRANSMIT"
Type2:
Value1 - "DT",
Value 2 - Frame number,
Value 3 - Frames Source address,
Value 4 - Frames Destination address.
Type3:
Value 1 - "EV",
Value 2 - Output of the intro_error function,
Value 3 - Frame Source address,
Value 4 - Frames Destination address.
Type4:
Value 1 - "ACK",
Value 2 - "POS",
Value 3 - Acknowledgement frames
Source Address,
Value 4 - Acknowledgement frames
Destination Address.
Type5:
Value 1 - "DEL"
Value 2 - count of frames being deleted
Value 3 - "FRAME"
Value 4 - "DELETED"
Note: The above convention to write into
the Output.Txt ismandatory.
Values in Quotes"" to be written into file
Output.Txt as it is including Case.
DT>Frame No>node1>node2> (DT denotes
Data from node 1 to node 2)
EV>Error Flag>node1>node2> (EV denotes
Error Value - i.e If the above frame has
error then set the error flag as 1 else set the
flag as 0)
ACK>POS>node2>node1>
(Acknowledgement for that above frame
received is sent to node 2 to node 1)
Ex:
339
CNT>1>FRAMES>TRANSMIT>
DT>1>node1>node2>
EV>0>node1>node2>
ACK>POS>node1>node2>
Sample Scenarios:
Objective - Send and receive the data using Sliding Window Protocol - Selective Repeat.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under Programming Menu select Sliding WindowProtocolSelective
Repeat.
Sample Input - By using the Input Panel that is available on the left hand side a Sample
Scenario is created. The Steps involved in creating are as follows,
Select the path of the above created Data file (.txt) which could be Maximum
of 100000 bytes.
Select Bit Error Rate (BER) as 10^-5 from the drop down menu.
Output
Total data frames to be transmitted - 24
Transmitted frame
Count
Data
26
Acknowledgement
7
Total = 33
Note - The Total data frames to be transmitted and Total count in the
Output table depends on size of the .txt file.
3. The details of the Data Frames flowing from Node 1 to Node 2 are obtained on the
right hand side panel. Below are the details that is obtained in the tool,
o Data Frame 1 is flowing from Node1 to Node2 with no error
o Data Frame 2 is flowing from Node1 to Node2 with no error
o Data Frame 3 is flowing from Node1 to Node2 with no error
o Data Frame 4 is flowing from Node1 to Node2 with error
o Acknowledgement from Node2 to Node1
o Data Frame 4 is flowing from Node1 to Node2 with no error
o Data Frame 5 is flowing from Node1 to Node2 with no error
o Data Frame 6 is flowing from Node1 to Node2 with error
o Data Frame 7 is flowing from Node1 to Node2 with no error
o Acknowledgement from Node2 to Node1
o Data Frame 6 is flowing from Node1 to Node2 with no error
o Data Frame 8 is flowing from Node1 to Node2 with no error
o Data Frame 9 is flowing from Node1 to Node2 with no error
o Data Frame 10 is flowing from Node1 to Node2 with no error
o Acknowledgement from Node2 to Node1
o Data Frame 11 is flowing from Node1 to Node2 with no error
341
Once the sample experiment is done, then Refresh button can be clicked to create
new samples.
342
9.5.49
Programming Guidelines
This section guides the user to link his/her own code for Sorting Algorithm to NetSim.
Pre - Condition
User written program should read the value from the Input.txt in the temporary directory
which is having input from the GUI at runtime
The output should be stored in Output.txt in the temporary directory for display.
User written program should return an integer value.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, The results of the program should be written into the
output file Output.txt.
Note:The naming of the input and the output file must be same as the text displayed in the
Methodology screen
File Format
Input File Format
Ascending Order
Sorting_Type=Bubble
Sorting_Order=Ascending
Total_Number=3
Number_to_Sort=5,4,3
Descending Order
Sorting_Type=Bubble
Sorting_Order=Descending
Total_Number=3
Number_to_Sort=4,5,6
344
Sample Scenarios:
Objective - To study the working of Sorting Techniques.
How to Proceed? The objective can be executed in NetSim using the programming exercise available, under
programming user has to select Sorting Techniques.
Sample Inputs - In the Input panel the following steps need to be done,
Select the total number that has to be sorted. The values available are from 3
to 25.
Enter the Number Value in the field provided. The value entered should be
within the range of 1 to 9999.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
345
9.5.50
Programming Guidelines
This section guides the user to link his/her own code for Sorting Algorithm to NetSim.
Pre - Condition
User written program should read the value from the Input.txt in the temporary directory
which is having input from the GUI at runtime
The output should be stored in Output.txt in the temporary directory for display.
User written program should return an integer value.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, The results of the program should be written into the
output file Output.txt.
Note:The naming of the input and the output file must be same as the text displayed in the
Methodology screen
File Format
Input File Format
Ascending Order
Sorting_Type=Insertion
Sorting_Order=Ascending
Total_Number=3
Number_to_Sort=9,8,7
Descending Order
Sorting_Type=Insertion
Sorting_Order=Descending
Total_Number=3
Number_to_Sort=1,9,3
Sample Project:
Objective - To study the working of Sorting Techniques.
347
How to Proceed? The objective can be executed in NetSim using the programming exercise available, under
programming user has to select Sorting Techniques.
Sample Inputs - In the Input panel the following steps need to be done,
Select the total number that has to be sorted. The values available are from 3
to 25.
Enter the Number Value in the field provided. The value entered should be
within the range of 1 to 9999.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
348
9.5.51
Programming Guidelines
This section guides the user to link his/her own code for Sorting Algorithm to NetSim.
Pre - Condition
User written program should read the value from the Input.txt in the temporary directory
which is having input from the GUI at runtime
The output should be stored in Output.txt in the temporary directory for display.
User written program should return an integer value.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and, The results of the program should be written into the
output file Output.txt.
Note:The naming of the input and the output file must be same as the text displayed in the
Methodology screen
File Format
Input File Format
Ascending Order
Sorting_Type=Quick
Sorting_Order=Ascending
Total_Number=3
Number_to_Sort=33,22,66
Descending Order
Sorting_Type=Quick
Sorting_Order=Descending
Total_Number=3
349
Number_to_Sort=22,33,44
Sample Scenarios:
Objective - To study the working of Sorting Techniques.
How to Proceed? The objective can be executed in NetSim using the programming exercise available, under
programming user has to select Sorting Techniques.
Sample Inputs - In the Input panel the following steps need to be done,
Select the total number that has to be sorted. The values available are from 3
to 25.
Enter the Number Value in the field provided. The value entered should be
within the range of 1 to 9999.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
351
9.5.52
Programming Guidelines
This section guides the user to link his/her own code for Sorting Algorithm to NetSim.
Pre - Condition
User written program should read the value from the Input.txt in the temporary directory
which is having input from the GUI at runtime
The output should be stored in Output.txt in the temporary directory for display.
User written program should return an integer value.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and the results of the program should be written into the
output file Output.txt.
Note:The naming of the input and the output file must be same as the text displayed in the
Methodology screen
File Format
Input File Format
Ascending Order
Sorting_Type=Selection
Sorting_Order=Ascending
Total_Number=3
Number_to_Sort=88,77,66
Descending Order
Sorting_Type=Selection
Sorting_Order=Descending
Total_Number=3
Number_to_Sort=55,11,22
353
Sample Scenarios:
Objective - To study the working of Sorting Techniques.
How to Proceed? The objective can be executed in NetSim using the programming exercise available, under
programming user has to select Sorting Techniques.
Sample Inputs - In the Input panel the following steps need to be done,
Select the total number that has to be sorted. The values available are from 3
to 25.
Enter the Number Value in the field provided. The value entered should be
within the range of 1 to 9999.
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
354
9.5.53
Programming Guidelines
This section guides the user to link his/her own code for Spanning Tree using Borovska
algorithm to NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Input File Format
Algorithm=Borovska
No_of_Switches=3
No_of_Edges=3
Node1>Node2>Cost>
Source_Switch=3,Destination_Switch=1,
Distance=11,
Source_Switch=1,Destination_Switch=2,
Distance=22,
Example:
1>2>22>
1>3>11>
Source_Switch=3,Destination_Switch=2,
Distance=33,
Interface Source Code
Interface source code written in C is given .Using this the user can write only the Borovska
algorithm inside the function fnBorovska() using the variables already declared. To view the
interface source code, go to
355
Sample Scenarios:
Objective - To find a SpanningTree for a network using Borovskas algorithm.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming Menu selectSpanning Tree.
Sample Input
Click on 2 Switches to give the distance between them. Similarly connect all the
Switches that are available in the network. The Distances between the Routers
that needs to be given are as follows,
o Switch 1 and Switch 2 67 Km
o Switch 1 and Switch 4 46 Km
o Switch 1 and Switch 3 89 Km
o Switch 2 and Switch 3 78 Km
o Switch 2 and Switch 4 99 Km
o Switch 3 and Switch 4 56 Km
Click on Run button to execute. Refresh button can be used if new Inputs have
to be given.
Sample Output
The SpanningTreeTable with the Path (Source Switch and Destination Switch)
and Distance is obtained. Below is the Table that is obtained for the above inputs,
356
Distance[KM]
67
56
46
The Length of the SpanningTree (KM) would be given below in the output
panel. The SpanningTreePath consists of green lines, whereas the NonSpanningTree consists of red lines. Here in this Sample, Length of the
Spanning Tree (KM) 169.
Once the sample experiment is done, then Refresh button can be clicked to create
new samples.
357
9.5.54
Programming Guidelines
This section guides the user to link his/her own code for Spanning Tree using Kruskal
algorithm to NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Input File Format
Algorithm=Kruskal's
No_of_Switches=3
No_of_Edges=3
Node1>Node2>Cost>
Source_Switch=3,Destination_Switch=1,Distance=23,
Source_Switch=1,Destination_Switch=2,Distance=34,
Source_Switch=3,Destination_Switch=2,Distance=45,
Example:
3>1>23>
1>2>34>
358
To find NetSims Installation path right click NetSim icon and select
Sample Scenarios:
Objective - To find the SpanningTree for a network by using Kruskal algorithm.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming Menu selectSpanning Tree.
Sample Input
Click on 2 Switches to give the distance between them. Similarly connect all the
Switches that are available in the network. The Distances between the Routers
that needs to be given are as follows,
o Switch 1 and Switch 2 67 Km
o Switch 1 and Switch 4 46 Km
o Switch 1 and Switch 3 89 Km
o Switch 2 and Switch 3 78 Km
o Switch 2 and Switch 4 99 Km
o Switch 3 and Switch 4 56 Km
Click on Run button to execute. Refresh button can be used if new Inputs have
to be given.
Sample Output
The SpanningTreeTable with the Path (Source Switch and Destination Switch)
and Distance is obtained. Below is the Table that is obtained for the above inputs,
359
Distance[KM]
46
56
67
The Length of the SpanningTree (KM) would be given below in the output
panel. The SpanningTree Path consists of green lines, whereas the NonSpanningTree consists of red lines. Here in this Sample, Length of the
SpanningTree (KM) 169
Once the sample experiment is done, then Refresh button can be clicked to create
new samples.
360
9.5.55
Programming Guidelines
This section guides the user to link his/her own code for Spanning Tree using Prims
algorithm to NetSim.
Pre - Conditions
The user program should read the input scenario from text file named Input with extension
txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and
The results of the program should be written into the output file Output.txt.
Input File Format
Algorithm=Prim's
No_of_Switches=3
No_of_Edges=3
Node1>Node2>Cost>
Source_Switch=1
Example:
Source_Switch=3,Destination_Switch=1,Distance=44,
Source_Switch=1,Destination_Switch=2,Distance=55,
1>3>44>
1>2>55>
Source_Switch=2,Destination_Switch=3,Distance=66,
Sample Scenarios:
Objective - To find a SpanningTree for a network using Prims algorithm.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. In the Programming Menu selectSpanning Tree.
Sample Input
Click on 2 Switches to give the distance between them. Similarly connect all the
Switches that are available in the network. The Distances between the Routers
that needs to be given are as follows,
o Switch 1 and Switch 2 67 Km
o Switch 1 and Switch 4 46 Km
o Switch 1 and Switch 3 89 Km
o Switch 2 and Switch 3 78 Km
o Switch 2 and Switch 4 99 Km
o Switch 3 and Switch 4 56 Km
Click on Run button to execute. Refresh button can be used if new Inputs have
to be given.
362
Sample Output
Distance[KM]
56
46
67
The Length of the SpanningTree (KM) would be given below in the output
panel. The SpanningTree Path consists of green lines, whereas the NonSpanningTree consists of red lines. Here in this Sample, Length of the
Spanning Tree (KM) 169.
Once the sample experiment is done, then Refresh button can be clicked to create
New Samples.
363
9.5.56
Programming Guidelines
This section guides the user to link his/her own code for Go Back N to NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
Window Size:
The Window Size for Go Back N is 7
Input File Format
Algorithm=Go_Back_N
Value1>Value2>Value3>Value4>
Data_File=C:\Users\P.Sathishkumar\
Documents\1 Th.txt>
Types:
BER=0
364
Value 4 - "TRANSMIT"
Type2:
Value1 - "DT",
Value 2 - Frame number,
Value 3 - Frames Source address,
Value 4 - Frames Destination address.
Type3:
Value 1 - "EV",
Value 2 - Output of the intro_error function,
Value 3 - Frame Source address,
Value 4 - Frames Destination address.
Type4:
Value 1 - "ACK",
Value 2 - "POS",
Value 3 - Acknowledgement frames Source
Address,
Value 4 - Acknowledgement frames
Destination Address.
Type5:
Value 1 - "DEL"
Value 2 - count of frames being deleted
Value 3 - "FRAME"
Value 4 - "DELETED"
Note: The above convention to write into the
Output.Txt is mandatory.
Values in Quotes"" to be written into file
Output.Txt as it is including Case.
DT>Frame No>node1>node2> (DT denotes
Data from node 1 to node 2)
EV>Error Flag>node1>node2> (EV denotes
Error Value - i.e If the above frame has error
then set the error flag as 1 else set the flag as
0)
ACK>POS>node2>node1>
(Acknowledgement for that above frame
received is sent to node 2 to node 1)
Ex:
CNT>1>FRAMES>TRANSMIT>
DT>1>node1>node2>
365
EV>0>node1>node2>
ACK>POS>node2>node1>
DEL>1>FRAME>DELETED>
Sample Scenarios:
Objective - Send and receive the data using Transmission Flow Control - Go BackN.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under ProgrammingMenu select Transmission Flow ControlGo
Back N.
Sample Input - By using the InputPanel that is available on the left hand side a
SampleScenario is created. The Steps involved in creating are as follows,
SelectGoBackN as Algorithm.
Select the path of the above created Datafile (.txt) which could be Maximum
of 100000bytes.
SelectBit Error Rate (BER) as 10^-5 from the drop down menu.
Output
Total data frames to be transmitted - 24
Transmitted frame
Count
Data
30
Acknowledgement
5
Total = 35
Note - The Total data frames to be transmitted and Total count in the Output
table depends on size of the .txt file.
Once the sample experiment is done, then Refresh button can be clicked to create
new samples.
367
9.5.57
Programming Guidelines
This section guides the user to link his/her own code for Selective Repeat to NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
Window Size:
The Window Size for Selective Repeat is 7
Input File Format
Algorithm=Selective_Repeat
Value1>Value2>Value3>Value4>
Data_File=C:\Users\P.Sathishkumar\
Documents\1 Th.txt>
Types:
BER=0
368
Value 4 - "TRANSMIT"
Type2:
Value1 - "DT",
Value 2 - Frame number,
Value 3 - Frames Source address,
Value 4 - Frames Destination address.
Type3:
Value 1 - "EV",
Value 2 - Output of the intro_error function,
Value 3 - Frame Source address,
Value 4 - Frames Destination address.
Type4:
Value 1 - "ACK",
Value 2 - "POS",
Value 3 - Acknowledgement frames Source
Address,
Value 4 - Acknowledgement frames
Destination Address.
Type5:
Value 1 - "DEL"
Value 2 - count of frames being deleted
Value 3 - "FRAME"
Value 4 - "DELETED"
Note: The above convention to write into the
Output.Txt is mandatory.
Values in Quotes"" to be written into file
Output.Txt as it is including Case.
DT>Frame No>node1>node2> (DT denotes
Data from node 1 to node 2)
EV>Error Flag>node1>node2> (EV denotes
Error Value - i.e If the above frame has error
then set the error flag as 1 else set the flag as 0)
ACK>POS>node2>node1> (Acknowledgement
for that above frame received is sent to node 2
to node 1)
Ex:
CNT>1>FRAMES>TRANSMIT>
369
DT>1>node1>node2>
EV>0>node1>node2>
ACK>POS>node2>node1>
DEL>1>FRAME>DELETED>
Interface Source Code
Interface source code written in C is given using this the user can write only the Transmission
Flow Control -Selective Repeat inside the function SelectiveRepeat () using the variables
already declared. To view the interface source code, go to
NetSim Installation path / src / Programming/ SelectiveRepeat_TFC.c
To find NetSims Installation path right click NetSim icon and select
Sample Scenarios:
Objective - Send and receive the data using Transmission Flow Control - Selective Repeat.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under Programming Menu select Transmission Flow
ControlSelective Repeat.
Sample Input - By using the Input Panel that is available on the left hand side a Sample
Scenario is created. The Steps involved in creating are as follows,
Select the path of the above created Data file (.txt) which could be Maximum
of 100000 bytes.
Select Bit Error Rate (BER) as 10^-5 from the drop down menu.
370
2. An Output Table is obtained when Run button is clicked. In the Output Table,
Transmitted frame (Data and Acknowledgement) and their corresponding
Counts is obtained. The Total Count is also obtained. The table is given below,
Output
Total data frames to be transmitted Transmitted frame
Count
Data
Acknowledgement
Total =
Note - The Total data frames to be transmitted and Total count in the Output table
depends on size of the .txt file.
Once the sample experiment is done, then Refresh button can be clicked to create
new samples.
371
9.5.58
Programming Guidelines
This section guides the user to link his/her own code for Stop and Wait to NetSim.
Pre - Conditions
The user program should read the inputted scenario from text file named Input with
extension txt.
The user program after executing the concept should write the required output to a file named
Output with extension txt.
Note:The temporary directory is navigated through the following step.
Run Type "%temp%" NetSim "Input.txt" and "Output.txt"
General Program Flow
The program begins with the Reading of the Inputs from the input file Input.txt.
Executing the required concept and,
The results of the program should be written into the output file Output.txt.
Input File Format
Algorithm=Stop_and_Wait
Value1>Value2>Value3>Value4>
Data_File=C:\Users\P.Sathishkumar\
Documents\1 Th.txt>
Types:
BER=0
372
373
Sample Scenarios:
Objective - Send and receive the data using Transmission Flow Control Stop and wait.
How to Proceed? - The objective can be executed in NetSim using the programming
exercise available. Under Programming Menu select Transmission Flow Control Stop
and wait.
Sample Input - In the Input panel the following steps need to be done,
Then Run button need to be clicked. Refresh button can be used if new
Inputs have to be given.
374
Output
Total data frames to be transmitted
Transmitted frame
Count
Data
Acknowledgement
Total =
Once the sample experiment is done, then Refresh button can be clicked to
375
376
Sample:
Algorithm=Link_State
No_of_Router=3
Distance:
999>6>5>
6>999>7>
5>7>999>
Source_Router=1
Destination_Router=2
Save it in some other location. In this example, it is saved at D:\New.
377
After writing the code for the function void fnDijkstra(), create .exe file. The procedure to
create .exe file is explained in Section 9.2 of NetSim User Manual.
In this example, the exe file created is LinkState.exe
For Example:
In this example, the exe file LinkState.exe and Input.txt is present at D:\New. So in
command prompt go to the folder where exe file is saved.
378
For Receiver: <EXE Name> <blank> <Path where Input.txt is saved> receive
For Example: Here according to this example, the Output.txt file will be created at
D:\New folder. User can open the file and compare the content with NetSim user manual.
379
10 NetSim Emulator
10.1 Introduction
A network simulator mimics the behavior of networks but cannot connect to real networks.
NetSim Emulator enables users to connect NetSim simulator to real hardware and interact
with live applications.
10.1.1
A real PC (running NetSim Emulation Client) sends live traffic to the PC (running NetSim
Emulation Server). Whenever a packet arrives at the interface of server, this packet is
modulated into a simulation packet and sent from a source node (user selectable) in the
simulated network (user configurable) to a destination node (again user selectable). Upon
receipt of this packet at the destination, the packet is then de-modulated and sent back to a
real PC destination node (running NetSim Emulation Client). The real packet thus undergoes
network effects such as delay, loss, error etc. created virtually by NetSim Simulator.
380
10.2.1
User has to open any Stack based Network (Any network except Legacy Networks) in
NetSim with Emulation, whereby Emulation_Server.exe will automatically run and
will be displayed by a command window. This command window should not be
closed.
Create a network scenario of your choice (refer application examples provided) and
set the Application properties.
381
Assign real Source IP address and Destination IP address in the respective fields.
Then Click Accept.
Set the Simulation Time as how long you want to perform the Emulation in
Real
World.
Dont
run
the
simulation
before
running
the
10.2.1.2
10.2.1.2.1
In
the
Client
system,
copy
the
Emulation_Client
folder
containing
382
Emulation_Client window will open and it will ask to enter the Emulation Server IP
Address. Enter the Sever IP Address (Ex-192.168.0.59) i.e NetSim Emulation Server
IP address (not NetSim License Server IP Address) and click OK.
Now a new page displaying Scenario Details and Application Metrics will come. If
any network scenario with traffic is modelled in NetSim Emulation Server, it will be
reflected in the Emulation_Client window.
a. Scenario Details pane displays properties of Network scenario created in
NetSim in Server system like Device type, Device ID, Simulation IP, Real IP
address.
b. Application Metrics pane displays the Application type i.e Emulation,
Source ID, Destination ID, Real IP address of both Source and Destination.
Now it is confirmed that both Server and Clients are connected to each other.
383
10.2.1.2.2
User has to follow the steps in Running Emulation via CLI provided later.
User has to configure the router settings of the real-world network so as to allow the
packets to be transmitted to the Emulation Server
For Example, if we consider a sample real world network scenario where the
Emulation clients and server are located in different subnets
Routing table of router C needs to be configured such that any packet having Source
Address as IP Address of Node 6(Client Source) and Destination Address as IP
Address of Node 8(Client Destination) must be routed to Emulation Server. NetSim
configuration will the ensure that the packet is re-injected with destination set to the
appropriate IP Address (set in the application properties)
10.2.2
Type command
route delete <Network Address>
, then press Enter key. You will get OK. For example if your IP address is
192.168.0.4 and the subnet mask is 255.255.255.0 then the network address is
384
192.168.0.0 (Got by performing a bitwise AND of the IP Address and the subnet
mask)
Type command
route add <Network Address>mask
NetSim Emulation serve is running>
255.255.255.0
metric
, here the subnet mask is taken as 255.255.255.0). After execution, you will get OK.
Type command
netstat r
Note that in the above screenshot, for the network 192.168.0.0, the gateway address assigned
is 192.168.0.87(Address of the system where NetSim Emulation Server is running).
10.2.2.2 Setting configuration for NetSim Emulation Server
I.
HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\Tcpip\Parameters
II.
III.
Set IPEnableRouter as 1
Restart System.
385
10.3.1.1
I.
Run NetSim in Administrative Mode and create a basic network Scenario in any stack
based protocol (Any network except Legacy Networks) in NetSim. Screenshot of a
sample scenario in Internetworks is shown below
II.
Go to Properties of Link1 and Link2 and set Uplink and Downlink Delay to 5000.
Click and drop the Application. Right click Application select Properties.
III.
IV.
Select Source and Destination ID according to the network scenario and change the
Source and Destination IP address according to the IP address of the real system.
386
V.
Provide the Simulation Time as how long you want the Emulation to be performed.
Make sure that Run_Emulation_Client.exe is running in client system(s) and then
click Run Simulation.
10.3.1.2
1. Before running simulation, start pinging the Destination from Source using command
ping <Destination_IP> t and note down the time duration.
(NOTE: In case if no ping messages can be sent from source to destination, disable
windows firewall and try again.)
4. The impact of the link propagation delay in NetSim Emulator is seen on a real packet.
387
10.3.2
10.3.2.1
I.
Run NetSim in Administrative Mode and create a basic network Scenario in any stack
based protocol (Any network except Legacy Networks) in NetSim. Screenshot of a
sample scenario in Internetworks is shown below
II.
Click and drop the Application. Right click Application select Properties.
III.
IV.
Select Source and Destination ID according to the network scenario and change the
Source and Destination IP address according to the IP Address of the real system and
click accept.
388
V.
Provide the Simulation Time as how long you want the Emulation to be performed.
Make sure that Run_Emulation_Client.exe is running in client system(s) and then
click Run Simulation.
During Simulation you will notice a change in the quality of the video being played in the
destination PC. This is because the network created in NetSim has errors / delays etc in the
links. The impact of this loss / jitter / delay etc in NetSim Emulator is seen on a real video
stream.
10.3.2.2
1. Follow steps as provided before in Running Emulation via GUISetting up the NetSim
Client. Then open VLC Media player Click Media menu Select Stream Option.
2. Click add button then select the video which you want to play
389
5. Click on Add Button. Then enter the Destination IP address in the Address field and enter
a stream name (user defined) and click next button.
6. Select Video MPEG-2 + MPGA (TS) option from the drop down list as shown in the
below screen shot. Then click next button
390
7. Perform all the steps at Emulation Server and then click on Stream button. Also Wireshark
(if installed) will automatically start capturing the packets as soon as Emulation Server starts
simulation.
10.3.2.3
1.
NetSim Client. After performing all the steps at Source PC and NetSim Emulation Server,
open VLC Media Player Click on Toggle Playlist icon as shown in the below screenshot.
391
3. In the streamed video, you will notice a change in the quality of the video being played in
the destination PC. Also Wireshark (if installed) will automatically start capturing the packets
as soon as Emulation Server starts simulation.
392
10.3.3
Example Application 3 File Transfer using IP Messenger
(One way Communication)
10.3.3.1
1. Run NetSim in Administrative Mode and create a basic network Scenario in any stack
based protocol (Any network except Legacy Networks) in NetSim. Screenshot of a
sample scenario in Internetworks is shown below
2. Click and drop the Application. Right click Application select Properties.
3. In the Application Type select Emulation.
4. Select Source and Destination ID according to the network scenario and change the
Source and Destination IP address according to the IP Address of the real system and
click accept.
393
5. Provide the Simulation Time as how long you want the Emulation to be performed.
Make sure that Run_Emulation_Client.exe is running in client system(s) and then
click Run Simulation.
10.3.3.2
1. Follow steps as provided before in Running Emulation via GUISetting up the NetSim
Client. Run IP Messenger software. Drag and drop the file inside the software that you want
to send and select Destination address. Here, destination IP is 192.168.0.145 and the file is
VTU Experiment Manual 8.3.10.pdf.
2. Do not click Send until all the steps at NetSim Emulation Server are done. File must be
send only after NetSim Emulation Server is running simulation. Also Wireshark (if installed)
will automatically start capturing the packets as soon as Emulation Server starts simulation .
10.3.3.3
1. Follow steps as provided before in Running Emulation via GUISetting up the NetSim
Client. When Source PC will click on Send, the Destination PC will receive the file in IP
Messenger software. Also Wireshark (if installed) will automatically start capturing the
packets as soon as Emulation Server starts simulation .
2. Save the file by clicking on the filename and selecting the location.
394
10.3.4
10.3.4.1
1. Run NetSim in Administrative Mode and create a basic network Scenario in any stack
based protocol (Any network except Legacy Networks) in NetSim. Screenshot of a
sample scenario in Internetworks is shown below.
2. Click and drop Application button. Right click Application select Properties. As it
is two way communication, add and create two applications.
3. In both the Application Type select Emulation.
4. In one Application, select Source ID and Destination ID according to the network
scenario and change the Source and Destination IP address according to the IP
Address of the real system. In the second application, set the opposite of first
application, i.e Source ID and IP address will be exchanged with Destination ID and
IP address. (Refer the IP settings in the screen-shot to get a clear picture)
395
5. Provide the Simulation Time as how long you want the Emulation to be performed.
Make sure that Run_Emulation_Client.exe is running in client system(s) and then
click Run Simulation.
10.3.4.2
1. Follow steps as provided before in Running Emulation via GUISetting up the NetSim
Client.
2. Run Skype and make a call to the destination system (Make sure that Skype is running in
Destination PC).
3. Wireshark (if installed) will automatically start capturing the packets as soon as Emulation
Server starts simulation .
10.3.4.3
1.
NetSim Client. After performing all the steps at Source PC and NetSim Emulation Server,
open Skype.
2. Wireshark (if installed) will automatically start capturing the packets as soon as Emulation
Server starts simulation.
396
10.3.5
Example Application 5 JPerf Network performance
measurement graphical tool (One way Communication)
10.3.5.1
1. Run NetSim in Administrative Mode and create a basic network Scenario in any stack
based protocol (Any network except Legacy Networks) in NetSim. Screenshot of a
sample scenario in Internetworks is shown below
2. Click and drop the Application. Right click Application select Properties.
3. In the Application Type select Emulation.
4. Select Source and Destination ID according to the network scenario and change the
Source and Destination IP address according to the IP Address of the real system and
click accept.
397
5. Provide the Simulation Time as how long you want the Emulation to be performed.
Make sure that Run_Emulation_Client.exe is running in client system(s) and then
click Run Simulation.
10.3.5.2
1. Follow steps as provided before in Running Emulation via GUISetting up the NetSim
Client. Run JPerf and select Client and set Server Address as 192.168.0.145. User can edit
the Application Layer options, Transport Layer options and IP Layer options depending on
the type of data they want to transmit in the network .
2. Do not click Run IPerf until all the steps at NetSim Emulation Server are done. Also
Wireshark (if installed) will automatically start capturing the packets as soon as Emulation
Server starts simulation .
398
10.3.5.3
1. Follow steps as provided before in Running Emulation via GUISetting up the NetSim
Client. Run JPerf and select Server.
399
11 Troubleshooting in NetSim
11.1 CLI mode
While running NetSim via CLI for the scenarios described in the Configuration file, you may
bump into few problems.
Note: While running NetSim via CLI, try to ensure that there are no errors in the
Configuration.xml file. The file, ConfigLog.txt, written to the windows temp path would
11.1.1
Reason: While typing the CLI command if you enter wrong I/O Path, or if there is no
Configuration.xml file then the following error is thrown
400
11.1.2
11.1.3
Solution: If the folder name contains white space, then mention the folder path within double
quotes while specifying the folder name in the command prompt. For example, if app path
contains white space, then the app path must be mentioned within double quotes in the
command prompt.
401
11.1.4
Simulation does not commence. No license for product (-1) is displayed in the command
prompt.
Example:
402
Solution:
NetSim is based on the client-server architecture. When NetSim runs in the client machine, it
will check for the license in the same machine, first. If license is not available in the same
machine, then No license for product (-1) will be displayed in the command prompt and the
server machine will be checked for the availability of license. If no license is available in the
server machine also, then again No license for product (-1) will be displayed in the
command prompt.
So, if No license for product(-1) is displayed in the command prompt two times, then check
in the NetSim license server to know about the availability of license and adjust the number
of current users of NetSim, in order to get the license.
11.1.5
Reason: If the command/iopath provided by the user is first written in MS Word and then
copy pasted to Command prompt, some special characters(not visible in command prompt)
gets inserted and on execution, license config dll is not found.
Solution: Type the command manually or copy paste the command/iopath from notepad.
403
11.2 Configuration.xml
11.2.1
Specific attributes in the Configuration file are highlighted with zigzag lines
Reason: If invalid input is given in the Configuration file, then the corresponding attribute is
highlighted in zigzag lines as shown in the figure given below.
Solution:
To resolve this issue mouse over the corresponding attribute, in order to get the tool tip that
furnishes the details about the valid input for that attribute.
Note: If the schema file and the configuration file are not present in the same folder, the
zigzag lines wont appear. So place the Configuration file and Schema File in the same
location or change the path of schema file in the configuration file.
11.2.2
Simulation does not commence and error is displayed at the command prompt. Also, Zigzag
lines appearing at the tag specifying the Layer in the Configuration file
Reason: This issue arises mainly when the closing tag is not specified correctly for a
particular layer in the Configuration file.
Example: If the closing tag is not specified for the Data link Layer, then the zigzag lines
appear at the starting tags of Data link Layer and the Network Layer.
404
When NetSim is made to run through CLI, then the following error gets displayed in the
command prompt.
Solution: The bug can be fixed by setting the closing tag correctly in the Configuration file
11.2.3
Configuration file:
Zigzag lines appearing at configuration.xsd in the Configuration file
Reason: This issue arises when the schema and the configuration file are not in the same
folder.
405
Solution: The bug can be fixed by placing the Configuration file and schema in the same
folder.
11.2.4
Simulation terminates and NetSim Backend has stopped
working displayed:
Simulation terminates and exhibits unpredictable behavior. An error message stating, An
exe to run NetSim backend has stopped working is thrown
Example:
This problem arises if there is any flaw in the Configuration.xml or in the dll.
Solution: Check whether the desired scenario has been configured properly in the
Configuration.xml.
406
11.3 GUI
11.3.1
The text doesnt fit into the available space. This can be a problem of readability like in the
following case where MTU looks like MIU
Reason:
The system display setting has been change from Normal size (96DPI) to large size (120DPI)
Solution:
The display setting should change to normal size (96DPI) in DPI setting
In Windows XP, Right click in the desktop properties Settings (Tab) Advanced
(Button) DPI Setting (Combo box) Select normal size (96DPI).
Click OK button then must restart the system.
In case if the problem still persists,
In Windows XP, Right click in the desktop properties Appearance (Tab) Font size
(Combo box) Select Normal and Click OK button
11.3.2
While starting NetSim, error shows the monitor screen resolution is less than 1024 X 768.
Reason: This error will come if monitor resolution is less than 1024 and 768. For example,
1260 X 720 will also show this error
Solution: Change your monitor resolution to 1024 X 768 or above.
407
11.4 Licensing
11.4.1
NetSim dongle is running in the server system. When running the NetSim in the Client
system showing No License for product (-1) error.
Possible Reasons
1. Firewall in the client system is blocking the Network traffic.
2. No network connection between Client and Server.
3. License Server is not running in the Server system.
Solution
1. The installed firewall may block traffic at 5053 port used for licensing. So either the
user can stop the firewall, or may configure it to allow port 5053.
2. Contact the Network-in-charge and check if the Server system can be pinged from
client.
3. Check whether License Server is running in the Server system or not.
408
11.5 Emulator
11.5.1
409
11.5.2
Reason: This issue has been noticed rarely when emulation is running above one hour.
Solution:
1. Close and re-run Run_Emulation_Client.exe in NetSim client.
2. In the Emulation Server, close the error message(if any) and click Edit and re-run
the network scenario.
11.5.3
Emulation closed, yet clients are sending network packets
to NetSim Emulation Server IP Address.
If you send any data packet within your Network, it will get routed via Emulation Server.
As shown here, data transmitted to
192.168.0.147 is being routed via
192.168.0.145 which is nothing but
a former Emulation Server.
Reason: After closing the NetSim Emulation client, a new window will appear as shown
below and user closes it manually.
Solution: DO NOT CLOSE this window manually. It will automatically close after
sometime. In case the user manually closes the window, they need to disable the active
network adapter (located at Control Panel Network and Sharing Center Change adapter
settings) and enable it to revert back to the original network settings.
410
12 NetSim Videos
In order to have a better understanding of NetSim, users can access YouTube channel of
Tetcos at www.youtube.com/tetcos and check out the various videos available
411