Contents
ns3-rmcat is an ns3 module (Currently ns-3.26 is supported) used for IETF RMCAT candidate algorithm testing.
It can be used in one of these ways:
- As complementary tests for the unit test and integration test in emulator environment.
- Algorithm tuning. It's easier to support different topologies using ns3, as ns3 provides sophisticated LTE and WiFi models, which make it easier to peek the internals than a real world system and emulator testbed.
- Algorithm comparison. Simulation testbed is more reproducible than real world test and emulator testbed. The different candidate algorithms can be easily switched, thus making side-by-side comparison of different algorithms an easy and fair task.
The model for real-time media congestion is documented at "Framework for Real-time Media Congestion Avoidance Techniques", and ns3-rmcat is a simplified implementation focussing on evaluation of real-time media congestion control algorithms in a simulation environment.
ns3-rmcat defines ns3 applications (see model/apps) running on different network topologies. These ns3 applications send fake video codec data (model/syncodecs, more on syncodecs), according to the congestion control algorithm under test.
The sender application, RmcatSender, sends fake video codec data in media packets to the receiver application, RmcatReceiver. RmcatReceiver gets the sequence of packets and takes reception timestamp information, and sends it back to RmcatSender in feedback packets. The (sender-based) congestion control algorithm running on RmcatSender processes the feedback information (see model/congestion-control), to get bandwidth estimation. The sender application then uses this bandwidth estimation to control the fake video encoder by adjusting its target video bitrate.
Different topologies (see model/topo) are currently supported, currently only point-to-point wired topology and WIFI topologies are used. We will add LTE support later.
The test cases are in test/rmcat-wired-test-suite and test/rmcat-wifi-test-suite; and currently organized in three test suites:
- rmcat-wifi
- rmcat-wired
- rmcat-wired-vparam, which is based on some of the wired test cases, but varying other parameters such as bottleneck bandwidth, propagation delay, etc.
LTE test case are not implemented yet.
examples is provided as an application template for experimenting new test cases and algorithm changes.
You can create your own congestion control algorithm by inheriting from SenderBasedController, DummyController is an example which just prints the packet loss, queuing delay and receive rate without doing any congestion control: the bandwidth estimation is hard-coded.
To reuse the plotting tool, the following logs are expected to be written (see NadaController, process_test_logs.py):
# rmcat flow 0, this is the flow id, SenderBasedController::m_id # ts, current timestamp when receving the rmcat feedback in millionseconds # loglen, packet history size, SenderBasedController::m_packetHistory.size() # qdel, queuing delay, SenderBasedController::getCurrentQdelay() # rtt, round trip time, SenderBasedController::getCurrentRTT() # ploss, packet loss count in last 500 ms, SenderBasedController::getPktLossInfo() # plr, packet loss ratio, SenderBasedController::getPktLossInfo() # xcurr, aggregated congestion signal that accounts for queuing delay, ECN # rrate, current receive rate in bps, SenderBasedController::getCurrentRecvRate() # srate, current estimated available bandwidth in bps # avgint, average inter-loss interval in packets, SenderBasedController::getLossIntervalInfo() # curint, most recent (currently growing) inter-loss interval in packets, SenderBasedController::getLossIntervalInfo() rmcat_0 ts: 158114 loglen: 60 qdel: 286 rtt: 386 ploss: 0 plr: 0.00 xcurr: 4.72 rrate: 863655.56 srate: 916165.81 avgint: 437.10 curint: 997
- Download ns3 (ns-3.26 is currently supported, other version may also work but are untested).
- Git clone ns3-rmcat into ns-3.xx/src. Initialize syncodecs submodule (git submodule update --init --recursive)
- configure the workspace, CXXFLAGS="-std=c++11 -Wall -Werror -Wno-potentially-evaluated-expression -Wno-unused-local-typedefs" ./waf configure --enable-examples --enable-tests.
- build, ./waf build
- run tests, ./test.py -s rmcat-wired -w rmcat.html -r, wherermcat.htmlis the test report.
- [optional] run examples, ./waf --run "rmcat-example --log",--logwill turn on RmcatSender/RmcatReceiver logs for debugging.
- draw the plots (need to install the python module matplotlib), python src/ns3-rmcat/tools/process_test_logs.py testpy-output/2017-08-11-18-52-15-CUT; python src/ns3-rmcat/tools/plot_tests.py testpy-output/2017-08-11-18-52-15-CUT
You can also use test.csh to run the testcases and the plot scripts in one shot. If you do so, logs with testcase names will be located in the "testpy-output/[CURRENT UTC TIME]" directory, if none specified.
# run from ns3 root directory: ns-3.xx/ # # Example: # ./src/ns3-rmcat/tools/test.csh wired 2017-07-21-rmcat-wired # ./src/ns3-rmcat/tools/test.csh vparam 2017-07-21-rmcat-wired-vparam # ./src/ns3-rmcat/tools/test.csh wifi 2017-07-21-rmcat-wifi # # The second parameter, output directory, is optional. If not specified, # the script will use a folder with a name based on current GMT time
Note that in ns-3.26, the testing script (test.py) only works with python2. So one may want to point the python alias to python to ensure that the test.csh script runs out of box:
- ::
- alias python=python2.7.3
Alternatively, you can use test_v2.csh to explicitly invoke python2 for running the testing script and python3 for running the processing and plotting scripts. The latter works with both python2 and python3.
To build ns-3.26 on newer compilers: see tips here. To disable warnings from breaking your build, do the following:
CXXFLAGS="-Wall" ./waf configure ./waf -vv
To debug "rmcat-wired" test suite:
./waf --command-template="gdb %s" --run "test-runner" r --assert-on-failure --suite=rmcat-wired
To debug rmcat example, enter ns3 source directory:
./waf --command-template="gdb %s" --run src/ns3-rmcat/examples/rmcat-example
Adding LTE topology and test cases
Add support for ECN marking
Encapsulate Sender's rate shaping buffer in a C++ interface or class
Wired test cases: implement time-varying bottleneck capacity by changing the physical link properties