NetAnim2: Difference between revisions
| Line 8: | Line 8: | ||
| == Prerequisites == | == Prerequisites == | ||
| # mercurial | # mercurial | ||
| # QT4 development packages | # QT4 development packages (tested version 4.7) | ||
| # xerces-c++ development packages | # xerces-c++ development packages (minimum version 3.1.1) | ||
| === Debian/Ubuntu Linux distribution:=== | === Debian/Ubuntu Linux distribution:=== | ||
| Line 26: | Line 26: | ||
| # mercurial | # mercurial | ||
| # Qt4 : Install Qt4 (including Qt Creator if possible) from http://qt.nokia.com/downloads/   | # Qt4 : Install Qt4 (including Qt Creator if possible) from http://qt.nokia.com/downloads/   | ||
| # Xerces-c++: http://xerces.apache.org/xerces-c/download.cgi | # Xerces-c++: http://xerces.apache.org/xerces-c/download.cgi  (minimum version 3.1.1) | ||
| == Feature-set in NetAnim 2.0 == | == Feature-set in NetAnim 2.0 == | ||
Revision as of 20:13, 17 September 2011
NetAnim is an animator based on the multi-platform Qt 4 toolkit NetAnim can animate a simulation using offline trace files (basic-mode) or it can animate while simulation is running (advanced-mode). NetAnim's advanced-mode also supports some basic statistics collection
Prerequisites
- mercurial
- QT4 development packages (tested version 4.7)
- xerces-c++ development packages (minimum version 3.1.1)
Debian/Ubuntu Linux distribution:
- apt-get install mercurial
- apt-get install qt4-dev-tools
- apt-get install libxerces-c-dev
Red Hat/Fedora based distribution:
- yum install mercurial
- yum install qt4
- yum install qt4-devel
- yum install xerces-c
- yum install xerces-c-devel
Mac/OSX
- mercurial
- Qt4 : Install Qt4 (including Qt Creator if possible) from http://qt.nokia.com/downloads/
- Xerces-c++: http://xerces.apache.org/xerces-c/download.cgi (minimum version 3.1.1)
Feature-set in NetAnim 2.0
- Basic
- Read offline XML trace file generated by ns-3's AnimationInterface
- Ability to track Wired & Wireless transmission (LTE not yet supported)
- Any node having a mobility model can be seen on the Animation.
- Track mobility of nodes
- Record button to take periodic snapshots of the Animation
- Display Node Id on the Animation canvas, with zoom-in, zoom-out etc
 
- Advanced (Requires integration with ns-3 libraries)
- Plotting the animation while the simulation is running
- Logging statistics to select Logging Components individually and display them while the simulation is running
- Routing statistics to print Routing Tables and other Ipv4 statistics such as Tx,Rx,Drop counters,Interface addresses while the simulation is running
- Application statistics for Tx,Rx counters
- NetDevice/Queue statistics for Tx,Rx,Drop counters
 
- Feature removed
- Socket based communication between the Animator and ns-3
 
Feature-set in NetAnim 1.0
- Animate only Wired topology
- Read non-XML trace file generated by ns-3
Downloading NetAnim
NetAnim 2.0:
hg clone http://code.nsnam.org/jabraham3/netanim
NetAnim 1.0:
click here. Untar it using:tar -xzvf NetAnim.tar.gz
Building NetAnim (Basic-Mode)
NetAnim uses a QT4 build tool called qmake. Only qmake version 4.7 is supported
For build instructions for advanced-mode go to #Building NetAnim (Advanced-mode)
In General
cd netanim make clean qmake NetAnim.pro make
Note: qmake could be "qmake-qt4" in some systems
This should create an executable named "NetAnim" in the same directory
On Mac OS X
The preferred Qt 4 version is Qt 4.7. Using "Qt Creator" to build NetAnim is usually fool-proof
cd netanim /usr/local/Trolltech/Qt-4.x.y/bin/qmake NetAnim.pro make
Note that above, the x.y is the specific version of Qt4 you are running.
Special note to Mac OS X Lion users as of July 30, 2011: In the latest build of Qt libraries, namely, http://get.qt.nokia.com/qt/source/qt-mac-opensource-4.7.3.dmg, qmake generates Xcode .pbproj file instead of Makefile by default. The Xcode file, however, is incompatible to the Xcode tools (version 4.1) for Lion. To get the Makefile output from qmake, one can try the following after installed qt-mac-opensource-4.7.3.dmg:
$ cd /usr/local/Qt4.7/mkspecs/ $ sudo rm default $ sudo ln -s macx-g++ default
Then, qmake will use the GCC template instead of Xcode template for building Qt projects. You can then build NetAnim as usual, namely,
$ cd netanim $ qmake $ make
On Fedora
cd netanim qmake-qt4 NetAnim.pro make
Using ns3::AnimationInterface to generate Animation trace files
The NetAnim application requires a custom trace file for animation. This trace file is created by AnimationInterface in ns-3.
- Model is at: src/netanim/model
- Examples are at src/netanim/examples
NetAnim 2.0 supports only reading XML trace files.
NetAnim 1.0 can read only Non-XML traces.
AnimationInterface as of ns-3.12 generates only non-XML trace files by default. To generate XML trace files, use void ns3::AnimationInterface::SetXMLOutput() prior to StartAnimation. See the examples under "src/netanim/examples"
Recommended set of steps
Here is the recommended set of steps for generating XML Animation traces.They must be applied before the "Simulation::Run" statement.
NOTE: A node must have an associated mobility model in-order to be displayed on the animation. This applies for both stationary and mobile nodes (See notes below)
 0. Ensure that your wscript includes the "netanim" module. Example as in: src/netanim/examples/wscript. Also include the header [#include "ns3/netanim-module.h"] in your test program
 1. AnimationInterface anim;
 2. anim.SetOutputFile ("animation.xml");
 3. anim.SetXMLOutput ();
 4. anim.SetMobilityPollInterval (Seconds (1));	
 5. anim.StartAnimation ();
where
 1. Create an AnimationInterface object
 2. Set the trace output file name
 3. Enable XML output (Only when using NetAnim 2.0). If this statement is not used, the AnimationInterface generates traces which are non-XML and can also be
     read by NetAnim 1.0
 4. This statement is optional. It records the position of the nodes every 1 second. NOTE: Setting a low value may result in large XML files.
    If your topology is expected to be stationary, it will be good to set it to a very large value (so that polling occurs rarely).
 5. Start recording traces. StartAnimation and other AnimationInterface methods should be called before "Simulator::Run()"
Running an Example File
The netanim example files are located under "src/netanim/examples"
./waf --run "dumbbell-animation --nLeftLeaf=5 --nRightLeaf=5 --animFile=dumbbell.xml" ./waf --run "grid-animation --xSize=5 --ySize=5 --animFile=grid.xml"
Setting the location of nodes
NetAnim requires a location to be assigned to each Node, in-order to be shown on the animation.
For stationary nodes:
- You should assign the ConstantPositionMobilityModel. Constant Position is a kind of mobility.
Here is an example:
 1. Ptr<Node> n = nodecontainer.Get (1);
 2. Ptr<ConstantPositionMobilityModel> Loc =  n->GetObject<ConstantPositionMobilityModel> ();
 3. if (Loc == 0)
       {
 4.     Loc = CreateObject<ConstantPositionMobilityModel> ();
 5.     n->AggregateObject (Loc);
       }
 6. Vector vec (10, 20, 0);
 7. Loc->SetPosition (vec);
where
1. Get a Ptr to Node from the node container 2. Get the aggregated ConstantPositionMobilityModel object from the node 3. If Loc ==0 , it indicates that this node is not aggregated with a mobility model.So we have to aggregate one. 4. Create a ConstantPositionMobilityModel object and assign it to Loc 5. Aggregate the mobility model "Loc" to the node 6. Create a position vector with 3-d co-ordinates x= 10, y= 20, z=0 7. Set the position vector to the mobility model
For mobile nodes
- You should assign any suitable Mobility model.
The examples for these are found in places such as src/mobility/examples or examples/routing/manet-routing-compare.cc etc
Understanding the XML trace file format
The ns3::AnimationInterface class is responsible for the creation of the xml trace files. Currently, in basic-mode, AnimationInterface records the position of the nodes at every periodic interval. This interval is 200 ms by default. This will become more efficient in future releases. This has the potential to cause a. Slowness in simulation b. Large XML trace files
Some ways to get around this is to identify if your topology has
- only stationary nodes and hence no mobility
- or slow-moving nodes
If the above is the case you should use AnimationInterface::SetMobilityPollInterval to set the poll interval to a high value.
Parts of the XML
The XML trace files has the following main sections
- Topology
- Nodes
- Links
 
- packets (packets over wired-links)
- wpackets (packets over wireless-links.LTE not supported)
XML tags
Nodes are identified by their unique Node id. The XML begins with the "information" element describing the rest of the elements
<anim> element
This is the XML root element. All other elements fall within this element
Attributes are: lp = Logical Processor Id (Used for distributed simulations only)
<topology> element
This elements contains the Node and Link elements.It describes, the co-ordinates of the canvas used for animation.
Attributes are: minX = minimum X coordinate of the animation canvas minY = minimum Y coordinate of the animation canvas maxX = maximum X coordinate of the animation canvas maxY = maximum Y coordinate of the animation canvas Example: <topology minX = "-6.42025" minY = "-6.48444" maxX = "186.187" maxY = "188.049">
<node> element
This element describes each Node's Id and X,Y co-ordinate (position)
Attributes are: lp = Logical Processor Id (Used for distributed simulations only) id = Node Id locX = X coordinate locY = Y coordinate
Example: <node lp = "0" id = "8" locX = "107.599" locY = "96.9366" />
<link> element
This element describes wired links between two nodes.
Attributes are: fromLp = From logical processor Id (Used for distributed simulations only) fromId = From Node Id (first node id) toLp = To logical processor Id toId = To Node Id (second node id) Example: <link fromLp="0" fromId="0" toLp="0" toId="1"/>
<packet> element
This element describes a packet over wired links being transmitted at some node and received at another The reception details is described in it associated rx element
Attributes are: fromLp = From logical processor Id (Used for distributed simulations only) fromId = Node Id transmitting the packet fbTx = First bit transmit time of the packet lbTx = Last bit transmit time of the packet
Example: <packet fromLp="0" fromId="1" fbTx="1" lbTx="1.000067199"><rx toLp="0" toId="0" fbRx="1.002" lbRx="1.002067199"/> Packet over wired-links from Node 1 was received at Node 0. The first bit of the packet was transmitted at the 1th second, the last bit was transmitted at the 1.000067199th second of the simulation Node 0 received the first bit of the packet at the 1.002th second and the last bit of the packet at the 1.002067199th second of the simulation
NOTE: A packet with fromId == toId is a dummy packet used internally by the AnimationInterface.Please ignore this packet
<rx> element
This element describes the reception of a packet at a node
Attributes are: toLp = To logical processor Id toId = Node Id receiving the packet fbRx = First bit Reception Time of the packet lbRx = Last bit Reception Time of the packet
<wpacket> element
This element describes a packet over wireless links being transmitted at some node and received at another The reception details is described in it associated rx element
Attributes are: fromLp = From logical processor Id (Used in distributed simulations only) fromId = Node Id transmitting the packet fbTx = First bit transmit time of the packet lbTx = Last bit transmit time of the packet range = Range of the transmission
Example: <wpacket fromLp = "0" fromId = "20" fbTx = "0.003" lbTx = "0.003254" range = "59.68176982"> <rx toLp="0" toId="32" fbRx="0.003000198" lbRx="0.003254198"/> Packet over wireless-links from Node 20 was received at Node 32. The first bit of the packet was transmitted at the 0.003th second, the last bit was transmitted at the 0.003254 second of the simulation Node 0 received the first bit of the packet at the 0.003000198 second and the last bit of the packet at the 0.003254198 second of the simulation
Using the XML trace with NetAnim
- Here is a youtube video demonstrating Animation for Wireless transmission click here
- Here is a youtube video demonstrating Animation for Wired transmission click here
Parts of the basic-mode Animator
The basic-mode Animator will have the following buttons shown here  
- Quit: Quits the NetAnim application
- Concentric circles: Shows Wireless transmission as concentric circles
- Reverse play button: Plays the animation in the reverse direction. Don't use this if "Track" button is enabled
- Forward play button: Plays the animation in the forward direction
- Track button:
Overrides the update interval slider logic to avoid skipping over animating packets that fall within the Update interval. This is helpful when you want to animate wireless transmissions (which have extremely low propagation delay) which often get skipped during animation because the update interval is usually higher than the propagation delay in wireless.It is recommended to disable the Track button when animating over wired links
- Pause button: Used to pause the animation
This slider controls the interval between updating animation. If it is low, more packets will be animated, but the simulation progress will be slow
If it is high, some packets may get skipped, although the simulation may progress faster.
Due to the skipping of packets, it is possible that Wireless transmissions may get skipped. Please enable the "Track" button when such a situation occurs.
- Record button: WIll take snapshots of the animation at periodic intervals and store them as a collection of images under the "recordings" folder
- Zoom-in button: Zoom into the animation
- Zoom-out button: Zoom out
- Reset Zoom
- Pkt ON: If suppressed will display packet transmission. Disable this button, when you are only interested in seeing the location of the nodes (or mobility)
- Show Node Id: If enabled shows the Node Id of each node on the canvas
- Node Id Font size: Controls the font size of the Node Id mentioned above
Using the XML trace file in NetAnim 2.0
- Open the XML file via "Options" menu --> "Load XML"
Using the non-XML trace file in NetAnim 1.0
- use the command-line
./NetAnim dumbbell-tr
Advanced-mode feature summary
Advanced-mode Animation
Press the "Offline" button to move to "Online" mode. Hit play as usual. Don't forget to remove "Track" for Wired animation. In this mode, the animation happens as the simulation proceeds. This usually gives a better animation. This provides some useful features such as pause and resume for your simulation
Advanced-mode Logging
Here you can log components separately. More than one component can be added using the "+" and "-" button
Advanced-mode L3/Routing stats
This tab records commonly used stats such as "Routing-table", Tx,Rx,Drop Counters, list of IP addresses of a node. It also has the logtofile button, which can be used to log the stats to the disk under the "logs" folder We have the option of polling the stats per Simulation Time or Real time. ( Make sure you click the "Stopped" button to begin polling for stats )
As shown below before simulation begins, NetAnim will provide a scrollable list of buttons for each node Id. Toggling each of these buttons monitors the l3 stats for a node selectively.
This tab also provides elementary packet filtering at layer 3 as shown by the video
Advanced-mode Application stats
This tab tracks stats such as the number of applications on a node,Rx,Tx counters available on an application
Advanced-mode NetDevice/Queue stats
This tab tracks stats such as the list of NetDevices on a node, Mac Address to IP address mappings, Tx,Rx,Drop counters. This tab also tracks Drop-tail queue statistics, and provides a simple-way to enable Pcaps at a NetDevice level
Building NetAnim (Advanced-mode)
To enable NetAnim's advanced-mode features, the ns-3 libraries need to be integrated with NetAnim. See this youtube-video for a glance at the new features
Summary of steps
- build ns-3 and install it
- ensure that PKG_CONFIG_PATH and LD_LIBRARY_PATH are properly set
- Edit NetAnim.pro to enable ns-3 features
- Add your test to ns3test.cpp
- Rebuild NetAnim
Detailed steps follow
Build ns-3 and install it
Use the following steps to build ns-3 modular libraries for Linux
hg clone http://code.nsnam.org/ns-3-dev cd ns-3-dev ./waf -d debug configure sudo ./waf install
This usually installs the ".pc" for ns-3 at "/usr/local/lib/pkgconfig" This also installs the "libns3-*.so" or "libns3-*.dylib" libraries at "/usr/local/lib"
For instance here is the "ls" output I get:
ns-3-dev john$ ls /usr/local/lib/pkgconfig/libns3* /usr/local/lib/pkgconfig/libns3-aodv.pc /usr/local/lib/pkgconfig/libns3-mesh.pc /usr/local/lib/pkgconfig/libns3-spectrum.pc /usr/local/lib/pkgconfig/libns3-applications.pc /usr/local/lib/pkgconfig/libns3-mobility.pc /usr/local/lib/pkgconfig/libns3-stats.pc /usr/local/lib/pkgconfig/libns3-bridge.pc /usr/local/lib/pkgconfig/libns3-mpi.pc /usr/local/lib/pkgconfig/libns3-template.pc /usr/local/lib/pkgconfig/libns3-config-store.pc /usr/local/lib/pkgconfig/libns3-netanim.pc /usr/local/lib/pkgconfig/libns3-test.pc /usr/local/lib/pkgconfig/libns3-core.pc /usr/local/lib/pkgconfig/libns3-network.pc /usr/local/lib/pkgconfig/libns3-tools.pc /usr/local/lib/pkgconfig/libns3-csma-layout.pc /usr/local/lib/pkgconfig/libns3-nix-vector-routing.pc /usr/local/lib/pkgconfig/libns3-topology-read.pc /usr/local/lib/pkgconfig/libns3-csma.pc /usr/local/lib/pkgconfig/libns3-ns3tcp.pc /usr/local/lib/pkgconfig/libns3-uan.pc /usr/local/lib/pkgconfig/libns3-dsdv.pc /usr/local/lib/pkgconfig/libns3-ns3wifi.pc /usr/local/lib/pkgconfig/libns3-virtual-net-device.pc /usr/local/lib/pkgconfig/libns3-energy.pc /usr/local/lib/pkgconfig/libns3-olsr.pc /usr/local/lib/pkgconfig/libns3-visualizer.pc /usr/local/lib/pkgconfig/libns3-flow-monitor.pc /usr/local/lib/pkgconfig/libns3-point-to-point-layout.pc /usr/local/lib/pkgconfig/libns3-wifi.pc /usr/local/lib/pkgconfig/libns3-internet.pc /usr/local/lib/pkgconfig/libns3-point-to-point.pc /usr/local/lib/pkgconfig/libns3-wimax.pc /usr/local/lib/pkgconfig/libns3-lte.pc /usr/local/lib/pkgconfig/libns3-propagation.pc
[root@localhost ns-3-dev]# ls /usr/local/lib libns3-aodv.so libns3-mobility.so libns3-template.so libns3-applications.so libns3-mpi.so libns3-test.so libns3-bridge.so libns3-netanim.so libns3-tools.so libns3-config-store.so libns3-network.so libns3-topology-read.so libns3-core.so libns3-nix-vector-routing.so libns3-uan.so libns3-csma-layout.so libns3-ns3tcp.so libns3-virtual-net-device.so libns3-csma.so libns3-ns3wifi.so libns3-visualizer.so libns3-dsdv.so libns3-olsr.so libns3-wifi.so libns3-emu.so libns3-point-to-point-layout.so libns3-wimax.so libns3-energy.so libns3-point-to-point.so perl5 libns3-flow-monitor.so libns3-propagation.so pkgconfig libns3-internet.so libns3-spectrum.so python2.7 libns3-lte.so libns3-stats.so libns3-mesh.so libns3-tap-bridge.so
Set PKG_CONFIG_PATH and LD_LIBRARY_PATH
Set the PKG_CONFIG_PATH variable to the location containing the "*.pc" files mentioned above like so
export PKG_CONFIG_PATH=$PKG_CONFIG_PATH:/usr/local/lib/pkgconfig
On some systems it may be required to set LD_LIBRARY_PATH to the location of the "libns3-*.so" files (libns3-*dylib for Mac OSX) like so
export LD_LIBRARY_PATH=$LD_LIBRARY_PATH:/usr/local/lib
Edit NetAnim.pro to enable Advanced-mode
######### NS-3 related # include(ns3.pro)
Uncomment the above line to look something like
######### NS-3 related include(ns3.pro)
Note: only the default modules of ns-3 are included in ns3.pro If you need to include optional modules such as click, openflow, emu etc, please edit ns3.pro suitably
A Test Run
Assuming all of the above steps were done correctly , go to the netanim folder and build NetAnim like so
make clean qmake NetAnim.pro (or qmake-qt4 NetAnim.pro in some systems) make ./NetAnim
If the above went well, the NetAnim advanced-mode should be presented like the below image , with "Logging" and "Routing" tabs etc
Adding your own tests
NetAnim comes with a default example in the "ns3test" folder in the file "ns3test.cpp". To run an ns-3 example within NetAnim the following must be considered
Special rules
- NetAnim uses the namespace "netanim".
- Your program must not include "Simulator::Run" and "Simulator::Destroy" (NetAnim will do that for you)
- Your program must not include any "ns3::AnimationInterface" objects (NetAnim will take care of setting up the Animation Interface)
- Your program must replace the "main" function with "Simulation::ConfigureSimulation" as shown in the example "ns3test.cpp"
- Your program must include the Simulator::Stop(Time_t) function to indicate when the Simulation should stop. Without this, the simulation may run indefinitely.
- Optionally: If your example has some statements that come after Simulator::Run, they must be moved to the function "Simulation::PostSimulation" as shown in ns3test.cpp
IMPORTANT: NetAnim has its own definition of  "Node" and "Packet" so if you use Node and Packet in your program make sure you have
the proper name resolution such as
netanim::Node n ns3::Node n netanim::Packet ns3::Packet
Passing command-line arguments to your program , can be done by passing the arguments to NetAnim itself like so
./NetAnim --animFile=a.xml --numNodes=5
Your example code must use the statement
using namespace netanim
as shown in the example in "ns3test.cpp"
F.A.Q
- I get
/usr/bin/ld: cannot find -lsqlite3 /usr/bin/ld: cannot find -lpng14 /usr/bin/ld: cannot find -lintl >>> Try removing the corresponding "-l" phrases from the LIBS variable in NetAnim.pro
- I get GLib-GIO:ERROR:gdbusconnection.c:2279:initable_init: assertion failed: (connection->initialization_error == NULL)Aborted (core dumped)
>>> Don't install or run NetAnim as a root-user
- I get
QImage: XPM pixels missing on image line 9 (possibly a C++ trigraph). QImage: XPM pixels missing on image line 10 (possibly a C++ trigraph). QImage: XPM pixels missing on image line 11 (possibly a C++ trigraph). QImage: XPM pixels missing on image line 12 (possibly a C++ trigraph). QImage: XPM pixels missing on image line 13 (possibly a C++ trigraph). QImage: XPM pixels missing on image line 14 (possibly a C++ trigraph)
>>> These can be ignored
- I am unable to see any packets animated
>>> If you are using Wireless links , try using the "Track" button >>> If you are using Wired links, try disabling the "Track" button
- The program hangs or crashes
>>> Double-check if the "Special-rules" section has been followed
- I get *.so not found. Try using -rpath
>>> ensure that you have set LD_LIBRARY_PATH correctly











