This guide will explain the rudimentary steps how to install and use the visualizer
-
Install nodejs
apt-get -y install npm
-
Run the visualizer with (in the forwardsocketdata folder)
nodejs index.js
-
Install ns-3. See How to configure ns3 main script to use the visualizer?
-
Run the visualizer (if used)
-
Run the ns-3 script which uses 802.11ah module to start the simulation.
This visualization tool offers 3 GUIs:
Browse to http://localhost:8080 in your favorite webbrowser (Chrome seems to work best with large datasets) to see a near real-time visualization of the running simulation.
Sections marked by numbers in the Figure shown above represent the following:
- Topology map shows node positions in the network.
- Each node can be selected. Measurements in the table (3) and chart (4) are shown for the selected node.
- If no node is selected (if a node is selected, click on the blank canvas unselects it) average and standard deviations of measurements for all nodes are shown in the table (3) and chart (4).
- If a node is selected, use keyboard keys right arrow and left arrow to navigate to the successor node or the predecessor node in terms of Association ID (AID) respecively.
- Color code is related to the selected measurement in table (3). Color gradation of red to green is and corresponds to the scale of "bad" to "good" (i.e. if "Packet loss" is selected in table (3), nodes with small packet loss are "good" and thus green, whereas if "Throughput" is selected, nodes with small throughput are considered "bad", thus they are red).
- Configuration table shows static configuration parameters for the simulation, total channel traffic in near real-time and total packet loss in the network in near real-time.
- Click on Channel Traffic or Total Packet Loss shows the diagram (4) of Channel Traffic or Total Packet Loss in near real-time.
- Table of measurements shows measurements for the selected node or all nodes in near real-time.
- By default, list of these measurements is shrinked showng only relevant measurements. Expanding the list shows all measurements supported by the visualizer, but some of them are not measured for current simulation.
- The table has several dropdown headers (General, Performance, Transmission, Reception, TCP, AP Packet scheduling, Application, Drop Reasons at station and Drop Reasons at AP). Each of those headers hides non-relevant parameters for the run simulation. For example, TCP statistics are irrelevant for simulations with UDP traffic, so the TCP statistics are hidden in that case).
- Step by step guide to add more measurements.
- Chart shows the diagram of the selected measurement from table (3) over time.
- If a node is selected, this diagram shows the selected measurement from table (3) in near real-time (a curve).
- If no node is selected, this diagram shows the average value of selected measurement from table (3) for all nodes over time, and standard deviation from average value (light blue surface depicting std. dev. around the curve representing avg. value).
- Zoom in by selecting the area in the chart that you want to enlarge.
- RAW group/Slot usage bars illustrate near real-time slot statistics. RAW groups (rectangles separated by whitespace) with their corresponding slots (bars in RAW groups) and the traffic in them are shown.
- All RAW groups horizontally one next to eachother belong to the same RPS element (thus they are located in the same beacon interval). Therefore, each RPS element is illustrated as a set of RAW groups one next to eachoter horizontally.
- Color code: Blue bar (vertically) in a RAW slot represents the percentage of slot duration used for uplink traffic (generated by stations); Orange bar (vertically) on top of the blue bar represent the percentage of slot duration used for downlink traffic (generated by AP). Whitespace on top of the orange bar in the slot represents the percentage of remaining unused time.
- On hover over the RAW group, part of the RAW group configuration is shown, namely:
- Cross-slot: (1 or 0) is boolean value indicating if the cross-slot boundary is allowed or not.
- Slot count: RAW configuration parameter indicating RAW slot duration in us by the formula 500 + 120 * SlotCount
- AID start and AID end: start and end value for AID of the stations in the RAW group. Stations are assigned to slots in the RAW group according to the formula slotIndex = AID % nSlots where nSlots is total number of slots in the RAW group.
-
Pie charts
-
Menu with the following options: Print chart, Download PNG image, Download JPEG image, Download PDF document (downloads chart), Download SVG vector image, Download CSV, Download XLS and View data table.
To compare multiple simulations, specify them in the compare querystring with comma seperated names of the simulations ( /?compare=sim1,sim2,sim3 ). Browse to http://localhost:8080/?compare=sim1,sim2,sim3.
When ns-3 simulation starts, visualzer creates a file named simulationName and extension .nss. This file is automatically saved in the base folder of ns-3 from where ns-3 simulation is run. In order to be able to compare saved simulations, it is neccesary to move/copy those files to the folder forwardsocketdata/simulations. All the simulations saved in forwardsocketdata/simulations are available for comparison in the visualizer.
To easily analyze and plot the data retreived from hundreds of simulations browse to http://localhost:8080/analyzecsv.html. Steps on how to get a CSV out of large number of simulations and use this webpage are:
- create your own batch folder in simulations folder and copy analyzedata.sh from some existing batch folder (i.e. simulations/udpbatch/analyzedata.sh). Edit analyzedata.sh to suit your needs. Example of the content of simulations/udpbatch/analyzedata.sh:
../analyzebatch.pl \ ../udpsims/ \ config=name,DataMode,payloadsize,nsta,BeaconInterval,NumOfRpsElements \ stats=edcaqueuelength,totalnumberofdrops,numberofmactxmissedack,numberoftransmissions,NumberOfDroppedPackets,AveragePacketSentReceiveTime,PacketLoss,latency,GoodputKbit \
and extract the config parameters and the latest node statistics (avg, q1, median, q3, min, max)
analyzedata.sh calls the perl script analyzebatch.pl
(line 1) over the set of .nss files located in the folder udpsims
passed to it as an argument (line 2) and creates a CSV which contains specified configuration data (line 3) and specified measurements (avg, q1, median, q3, min, max) (line 4). Comma separated parameters provided to config
and stats
are some of the parameters sent to the visualizer during the simulation and exact variable names can be seen in ns-3 in SimulationEventManager::onStartHeader()
and SimulationEventManager::onStatisticsHeader()
respectively. Parameter names in lines 3 and 4 are not case-sensitive.
-
Run
./analyzedata.sh > mycsv.csv
to create mycsv.csv file. -
Browse to http://localhost:8080/analyzecsv.html and
- Load the mycsv.csv to analyze.
- Specify Chart options from the list of available parameters (Series, x values, y values)
- Optionally use the section Fixed values to fix some of the values.
- Generate chart
- Optionally zoom in by selecting the area in the chart that you want to enlarge.
A menu in upper right corner of the chart enables download of the shown chart, CSV or XLS.
To use the visualizer this version of ns-3 is needed because it has implementation of SimulationEventManager, Configuration, NodeEntry, NodeStatistics, Statistics and SimpleTCPClient in the scratch folder. See an example of main script working with the visualizer.
-
Initialize Configuration, Statistics and SimulationEventManager
-
Create and configure the network in ns3
-
For each node and AP create its corresponding
NodeEntry
instance and connect the trace sinks for desired metrics for all nodes/AP. Trace sinks are available inNodeEntry
.NodeEntry* n = new NodeEntry(i, &stats, wifiStaNode.Get(i), staDevice.Get(i));
-
Send data to the visualizer using
SimulationEventManager
methods. Make sure to send configuration data first, that is to useonStartHeader()
andonStart(...)
, for each RAW group to callonRawConfig(...)
, for each node to callonSTANodeCreated(...)
oronAPNodeCreated(...)
and upon association/deassociation callonNodeAssociated(...)
/onNodeDessociated(...)
. -
After all stations are associated, configure applications in ns-3 and connect trace sinks for applications from
NodeEntry
. Start the applications. -
Schedule sending statistics to the visualizer each second using methods
onStatisticsHeader()
,onUpdateStatistics(...)
andonUpdateSlotStatistics(...)
.
SimulationEventManager
uses SimpleTCPClient
to establish a TCP connection with the nodejs webserver for the ns-3 simulation.
NodeEntry
uses NodeStatistics
to store the measurements from trace sinks.