Given the importance of obtaining a capable and fully open-source platform for xApp operation testing, especially for the complex use-cases. Orange Innovation Egypt(OIE) team Successfully integrated FlexRIC from EURECOM with ns-O-RAN simulator that originally developed by the institute for the Wireless Internet of Things (WIoT) and Mavenir. The team updated the ns-O-RAN simulator to be a fully compliant with E2AP v1.01, KPM v3 and RC v1.03. This platform will pave the way to test the use-cases that need a rich LTE/5G simulator to be verified. What's more, we propose Graphical User Interface for ns3 which allows to run and observe simulations in user-friendly way. The original project of ns-O-RAN in OpenRAN-Gym.
The ns-O-RAN is composed by three main components, as shown in the figure below:
- The e2sim software, which was originally developed by the OSC community.
- The ns3-mmWave version, which was originally developed by the University of Padova and NYU.
- The ns-O-RAN module, developed by Northeastern University and Mavenir, which is basically an external module that can be plugged in ns-3 and uses the e2sim to create a SCTP connection with the RIC.
-
E2 Setup request
- Edit the RAN Function IDs for KPM and RC - Reformat the size of the message to match FlexRIC (62 byte) - Update the KPM ASN and model to KPM v3
-
E2 Subscription Response
- Add RAN Function NotAdmitted IE to the message - Update the message to match KPM v3.0 - Fill New RIC indication messages formats (Format 3 )
-
RIC Control Acknoweldege
-Implemented from scratch
-
RIC Control Request
- Update the message to match E2SM RC v1.01
-
RIC Subscription delete request/response
- Implemented from scratch
-
RIC Subscription modification response (In-Prograss)
- Implemented from scratch
-
RIC Subscription modification confirm (In-Prograss)
- Implemented from scratch
-
Update the KPM ASN and model to KPM v3.00
-
Update the RC ASN and model to RC v1.03 (In-Prograss)
-
'--E2andLogging=(bool)' allows to trace KPIs do file and E2 term in the same time, every "Indication period" KPIs are sent to E2 termination (RIC) and saved to files (CU-CP, CU-UP, DU)
-
New scenario "scenario-zero-with_parallel_loging.cc" as example of use '--E2andLogging=(bool)'
-
Cell deep-sleep implementation (In-Progress)
-
New run flags:
--KPM_E2functionID=(double)
--RC_E2functionID=(double)
--N_MmWaveEnbNodes=(uint8_t)
--N_Ues=(uint32_t)
--CenterFrequency=(double)
--Bandwidth=(double)
--IntersideDistanceUEs=(double)
--IntersideDistanceCells=(double)
-
Observe Cell/UEs KPIs
-
Run simulation from GUI with selection of simulation parameters
-
Stop simulation
-
Observe cell allocation and UEs positions
-
Grafana platform deployed to observe simulation results (in-progress - users need to declare InfluxDB queries themselves)
First start with the installation of the prerequisites. In Ubuntu 20.04 LTS, these can be installed with:
sudo apt-get update
# Requirements for e2sim
sudo apt-get install -y build-essential git cmake libsctp-dev autoconf automake libtool bison flex libboost-all-dev
# Requirements for ns-3
sudo apt-get install g++
sudo apt install python3.13 # (or ealier version, but 3.6+ required)
For GUI, Docker Compose is needed, to install it please follow docs.docker.com.
The prepation of enviroment for running testing examples can be done when 'near-RIC' is initialized, as sequence diagram is represented below:
The first release for ns-O-RAN-flexric proejct is working with a mature commit for flexric, you MUST follow installtion and deployment instructions, under commit number d3ff8791 before use the simulator.
First you need to clone the project
git clone --recurse-submodules https://github.com/Orange-OpenSource/ns-O-RAN-flexric
Note
If you made a clone before and there are new updates so you need to make recursive pull
git pull --recurse-submodules https://github.com/Orange-OpenSource/ns-O-RAN-flexric
To set up the environment for ORAN E2 simulator, navigate to the /e2sim-kpmv3/e2sim
directory. Create a new directory named build. Then execute the script build_e2sim.sh
with the argument 3
to enable LOG_LEVEL (DEBUG). This is useful to debug the exchange of the messages between the ns-3 and the RIC, but also there are a different debug levels that can be setup. These levels are summarized in the table below.
cd /e2sim-kpmv3/e2sim/
mkdir build
sudo ./build_e2sim.sh 3
Log Level e2Sim | Value | Description |
---|---|---|
LOG_LEVEL_UNCOND | 0 | Show only the uncoditional logs. |
LOG_LEVEL_ERROR | 1 | Show all the previous logs plus failures on the e2Sim side (such as errors on encoding) |
LOG_LEVEL_INFO | 2 (default) | Show all the previous logs plus the some info about the size of the messages |
LOG_LEVEL_DEBUG | 3 | Show all the possible logs including the xer_printing of the ASN1.C messages |
This last command shall configure the cmake project and install the e2sim on the system. Its main actions are also in the aforementioned Dockerfile that we report here to clarify the operations conducted by the script:
RUN mkdir /workspace/e2sim/e2sim/build
WORKDIR /workspace/e2sim/e2sim/build # Creation and cd on the build directory
RUN cmake .. -DDEV_PKG=1 -DLOG_LEVEL=${log_level_e2sim} # build of the project with the LOG_LEVEL desired
RUN make package # Creation of the package
RUN echo "Going to install e2sim-dev"
RUN dpkg --install ./e2sim-dev_1.0.0_amd64.deb # Installation of the generated package on the system
RUN ldconfig # library update to make the package linkable from ns-3 without rebooting the machine
Navigate to ns3-mmWave project:
cd ns-3-mmwave-oran
At this step the software in place to configure and build ns-3:
./waf configure
./waf build
cd ns-3-mmwave-oran/GUI
nano docker-compose.yml # you need to set 'NS3_HOST' IP which is address of machine where ns3 is deployed '- NS3_HOST=192.168.100.21'. This information is needed for control of ns3 from GUI.
docker-compose up --build -d # this will deploy environement which includes GUI and InfluxDB database with newest images
pip3 install influxdb
Finally, run an example ns-3 scenario called Scenario Zero
for testing purpose. This scenario features a Non-StandAlone (NSA) 5G setup in which, its have one LTE eNB positioned in the center of the scenario and four gNBs around it with an inter site distance of 1000 between the eNB and each gNB. You can run the scenario after done the following steps first:
- First you must be done the installation instructions for the flexric mentiond in the above section 'FlexRiC Installation Instructions'
- Second you must done the building steps for ns3-oran simulator section, to build an 'e2sim' and 'ns-3-mmwave-oran' waf.
- The last thing, after you done the building process, it's time to run the scenario-zero as a first test case.
- Navigate to '/path/to/flexric/build/examples/ric/' and then run './nearRT-RIC'.
- Navigate to '/path/to/ns-3-mmwave-oran' and then run './waf --run scratch/scenario-zero.cc'
- Navigate to '/path/to/flexric/build/examples/xApp/c/kpm_rc' and then run './xapp_kpm_rc'.
And if everything goes as intended we should be able to see in order the following messages as shown in the Wireshark snapshot below:
- E2 Setup Request (ns-O-RAN to E2 Term on RIC)
- E2 Setup Response (E2 Term on RIC to ns-O-RAN)
- E2 Subscription Request (xApp to ns-O-RAN through E2 Term on RIC)
- E2 Subscription Response (ns-O-RAN to xApp through E2 Term on RIC)
- RIC Indication (ns-O-RAN to xApp through E2 Term on RIC)
- RIC Control Request (xApp to RIC to ns-O-RAN)
- RIC Control Ack (ns-O-RAN to xApp through E2 Term on RIC)
- RIC Subscription Delete Request (xApp to RIC to ns-O-RAN)
- RIC Subscription Delete Response (ns-O-RAN to xApp through E2 Term on RIC)
- First you need to run script 'python3 gui_trigger.py' in 'ns-3-mmwave-oran' folder, which will be responsible to push ns3 KPIs to database
- In your browser, type 127.0.0.1:8000 or 'NS3_HOST':8000 (e.g 127.0.0.1:8000).
It take up to 5 minutes to deploy portal, depends on HW. - Click on webpage 'Show form', choose run flags values and click 'Start', you should see Cells and UEs on grid shortly.
GUI will run 'scenario-zero-with_parallel_loging.cc' with user defined run flags.
Runtime logs from ns-3 will be saved in 'ns-3-mmwave-oran/ns3_run.log' file. - To see current KPIs, click 'Source Data'.
If FlexRIC connection is enabled, GUI KPIs will refresh only when xApp is running and Indication messages are exchanged.
If FlexRIC is disabled in GUI, GUI KPIs will refresh every 1s. - To stop simulation, click 'Stop' on 'Show Form' window.
- To close GUI if not needed, please use command 'docker-compose down' in 'ns-3-mmwave-oran/GUI' folder.
- [Optional Step] If you would like to observe KPIs from Grafana, which allows to observe past simulations, check the next section.
- Grafana is being deployed together with GUI through Docker Compose.
- It can be accessed by typing 127.0.0.1:3000 or 'NS3_HOST':3000 in the browser.
- Dashboards will be shared soon, for test proposes, you can use example query.
- Click '+' button and choose 'Create Dashboard'.
- Click 'Add an empty panel'.
- Click pencil button at the right side of 'FROM' in query builider.
- Type: 'SELECT ("value") FROM "du-cell-2_drb.meanactiveuedl" WHERE $timeFilter'.
- Click 'Apply'.
- Remember to set correct 'Absolute time range' in right corner of Grafana to choose time period when desired simulation started.
- List of all available KPIs that can be get with query can be found in '/docs/Grafana KPIs'.
- Mina Yonan, Orange Innovation Egypt, mina.awadallah.ext@orange.com
- Mostafa Ashraf, Orange Innovation Egypt, mostafa.ashraf.ext@orange.com
- Kamil Kociszewski, Orange Innovation Poland, kamil.kociszewski@orange.com
- Adrian Oziębło, Orange Innovation Poland, adrian.ozieblo@orange.com