Visualizing Submodule Information¶
In INET, network nodes are typically composed of multiple submodules, such as apps, protocols, and protocol parts. These submodules often contain important information for understanding the behavior of the network, but accessing it can be difficult, as it requires drilling down into the graphical inspector or object inspector.
To make this information more accessible, INET provides a feature for displaying submodule information on the top-level canvas, near the corresponding network node icons. This makes the information readily available at a glance.
This showcase features a simple WiFi network model and demonstrates how to display (1) the number of packets sent and received by an application, and (2) the IEEE 802.11 MAC state information, on the network level.
About the visualizer¶
The InfoVisualizer module (included in the network as part of IntegratedVisualizer) can visualize information provided by submodules one or more levels down in the module hierarchy. This information is visualized at the submodule of the containing network node, typically at the top level canvas. The following image illustrates this with the example of an application that communicates over UDP:
The image on the left shows the inside of a host. The text displayed above
app submodule indicates the number of packets sent/received by
that application, which can be quite a useful piece of information.
However, to see it, the user has to go into the host, which is especially
inconvenient if there are several such hosts to watch. The image on
the right shows how, with the help of InfoVisualizer, the same
information can be displayed over the host’s icon on the top level canvas.
The submodules whose states should be visualized can be selected with
modules parameter. This parameter takes full path
module names. Wildcards can be used to select a certain submodule in
multiple nodes. Additionally, one can specify multiple submodules for a
node. By default, the value of the
modules parameter is
information displayed.) Also, the visualization can be turned on and off
displayInfos parameter, which is
true by default.
The visualizer can display module information in various ways, selected
format parameter. This model takes a format string, which can
contain the following directives:
%n: module full name
%p: module full path
%t: display string text, i.e. the
ttag of the submodule’s display string
%s: the return value of the module’s
The default format string is
On the example image above, the display string text is visualized,
selected with the
In the example simulation, three wireless nodes will communicate via
wifi. The network contains three AdhocHost’s arranged in a chain.
The communication ranges of hosts are determined by their radio
transmitter power, which is configured so that hosts can only reach
adjacent hosts in the chain. Hosts’ routing tables are set up
accordingly, thus packets going between
are routed via
The network also contains an Ipv4NetworkConfigurator, an
Ieee80211ScalarRadioMedium, and an IntegratedVisualizer module.
Displaying Packet Counts¶
In this example, we use the visualizer to display the number of packets sent and
received by the UDP application. Thus, for the
we specify the
app submodules of the hosts. The
is set to display the submodule’s display string text.
*.visualizer.*.infoVisualizer.modules = "*.*.app" *.visualizer.*.infoVisualizer.format = "%t" *.visualizer.*.infoVisualizer.placementHint = "topCenter"
To run the simulation, choose the
from the ini file.
The counts are updated as the simulation progresses.
Displaying MAC State¶
In this example, we’ll visualize the state of the wifi MAC modules: reception state, transmission state, and contention state.
The IEEE 802.11 MAC is the
wlan.mac submodule inside each host.
It is a compound module itself. The transmission process is in its
tx submodule, reception is in its
rx submodule, and
the submodule responsible for contention in DCF mode is the
dcf.channelAccess.contention submodule. All three submodules
display their internal states via display string
so we can use the InfoVisualizer to display them over
the host icons.
The visualizer allows specifying multiple submodules in the
parameter so that we can list all of tx, rx, and contention:
*.visualizer.*.infoVisualizer.modules = "*.*.wlan.mac.tx OR *.*.wlan.mac.rx OR *.*.wlan.mac.dcf.channelAccess.contention " *.visualizer.*.infoVisualizer.format = "%n: %t"
The simulation can be run by choosing the
from the ini file. The following captured video shows the result:
In the video, you can follow how the MAC states of nodes change as frames are
transmitted and received. For example, when
source starts transmitting
a data frame, its tx state switches to
TRANSMIT, and when the beginning
of the frame reaches
relay’s rx state changes to