NR-Scope is a 5G wireless network telemetry tool for 5G Standalone network measurement and performance optimization. NR-Scope decodes DCI, SIB and RACH information from a 5G Standalone (New Radio) base station. It is distinct from NG-Scope, our prior 4G cellular network telemetry tool.
NR-Scope is published in ACM CoNEXT 2024: if you use this tool, we ask that you cite our paper and reach out to the developers at the email address ng-scope-dev
at lists.cs.princeton.edu
@inproceedings{10.1145/3680121.3697808,
author = {Wan, Haoran and Cao, Xuyang and Marder, Alexander and Jamieson, Kyle},
title = {NR-Scope: A Practical 5G Standalone Telemetry Tool},
year = {2024},
isbn = {9798400711084},
publisher = {Association for Computing Machinery},
address = {New York, NY, USA},
url = {https://doi.org/10.1145/3680121.3697808},
doi = {10.1145/3680121.3697808},
booktitle = {Proceedings of the 20th International Conference on Emerging Networking EXperiments and Technologies},
pages = {73–80},
numpages = {8},
keywords = {5G network, network measurement, telemetry, wireless network},
location = {Los Angeles, CA, USA},
series = {CoNEXT '24}
}
We welcome contributions. If you use NR-Scope and would like to contribute improvements, modifications, bug fixes, and the like, please initiate a pull request on this repository and one of our team will review your contribution.
NR-Scope and NG-Scope are open source products of NSF Award CNS-2223556 (IMR: MT). Any opinions, findings, and conclusions or recommendations expressed in this material are those of the author(s) and do not necessarily reflect the views of the National Science Foundation.
The main features are as follows:
- Supports 5G SA cells with 15kHz and 30kHz SCS, tested with 10MHz, 15 MHz, 20MHz and 40MHz cell bandwidth (wider bandwidth is working in progress 🏗 ).
- 5G SA cell search and MIB decoding.
- SIB 1 and all other SIBs decoding.
- RRCSetup (MSG 4) decoding for continuously UE attatch detection.
- Threaded DCI decoding for detected UEs.
- SIB, RRCSetup and DCI decoding are threaded for performance and independent processing.
- Can concurrently decode up to 64 UEs (max number we can create for now) in the same base station.
- Accurate DCIs, PRB and bit rate estimation for each UEs (please stay tuned for our paper).
- Local logging functions in
.csv
file and remote google BigQuery uploading function in BigQuery table. - Support using multiple USRPs to decode multiple base stations independently, each has its own log.
- Cell search for all possible frequencies in a separate file and the results are stored in
.csv
log file. - Non-initial (BWP id > 0) and plaintext (configured in SIB 1 or MSG 4) BWPs decoding in separate DCI decoder threads.
- Threaded resampling function for better-fidelity TwinRX USRP X310 daughterboard (better signal quality but doesn't support 5G sampling rate without resampling).
- Worker pool function is implemented. Each worker works on the slot data asynchronously. Now the processing doesn't need to keep up with the short slot time, and the throughput is increase through more workers.
- Stay tuned... 😄
Please refer to the wiki page for more feature description and documentation.
We tested this system on Ubuntu 22.04 system and it may support other version of Ubuntu. To build this project and make it run properly, the following libraries are needed.
sudo add-apt-repository ppa:ettusresearch/uhd
sudo apt-get update
sudo apt-get install libuhd-dev uhd-host
sudo apt-get install build-essential cmake libfftw3-dev libmbedtls-dev libboost-program-options-dev libconfig++-dev libsctp-dev
# In a different directory
git clone https://github.com/jbeder/yaml-cpp.git
cd yaml-cpp
mkdir build
cd build
cmake ..
make
sudo make install
We need liquid-dsp for resampling if better-fidelity TwinRX USRP X310 daughterboard is used:
# In a different directory
sudo apt-get install automake autoconf
# download source codes
git clone https://github.com/jgaeddert/liquid-dsp.git
cd liquid-dsp
# Building and installing the main library
./bootstrap.sh
./configure
make
sudo make install
sudo ldconfig
# to double check, libs should appear at /usr/local/lib and header liquid.h should appear at /usr/local/include/liquid/
For different USRP daughterboard, different config.yaml
should be used. Please refer to the sample config.yaml
in ./nrscope/config/config.yaml
and the explanatory comment in it.
CBX:
......
rf_args: "clock=external,type=x300,sampling_rate=23040000" #"type=x300" #"clock=external"
rx_gain: 30 # for x310, max rx gain is 31.5, for b210, it's around 80
srate_hz: 23040000 #11520000 #11520000 #23040000
srsran_srate_hz: 23040000
......
TwinRX (note TwinRX has a significantly higher rx gain limit):
......
rf_args: "clock=external,type=x300,master_clock_rate=200000000,sampling_rate=25000000" #"type=x300" #"clock=external"
rx_gain: 90 # for x310, max rx gain is 31.5, for b210, it's around 80
srate_hz: 25000000 #11520000 #11520000 #23040000
srsran_srate_hz: 23040000
......
Also, you should turn on the performance mode:
# This script is copied from srsRAN_Project
cd script
sudo ./srsran_performance
Push DCI logs to google storage BigQuery table (optional): Using google client c++ library requires c++ 14.0, where in ubuntu 22.04, the default c++ version is 11.0. We thought that nobody wants to mess with the system compiling environments, so we implement the function of pushing data to google cloud storage with python. Here is a step-by-step instruction of how to push the DCI log to our google cloud storage:
1. sudo pip install google-cloud-storage geocoder
2. sudo gcloud auth application-default login --impersonate-service-account [email protected]
3. # There will be a link from goole, open that link and login with any of your google account.
4. sudo gcloud init
5. # In the config file (./nrscope/config.yaml), set push_to_google: true.
6. # In the config file (./nrscope/config.yaml), set google_service_account_credential: "/home/wanhr/Downloads/nsf-2223556-222187-b5d2ea50f5d1.json" with the google service account credential file (provided by us)'s location on your file system.
7. # In the config file (./nrscope/config.yaml), set google_dataset_id: "ngscope5g_dci_log" with the google cloud Bigquery dataset name, everyone has his/her own dataset. The code will create one if the dataset with this dataset id is not existed.
8. sudo gcloud auth application-default set-quota-project <Your Google Storage Project Name>
Entry: /nrscope/src/main.cc
Load config: /nrscope/src/libs/load_config.cc
Radio thread (cell search, mib decoding, coreset decoding, etc.): /nrscope/src/libs/radio_nr.cc
Config file: /nrscope/config/config.yaml
Cell scan entry (scan all GSCN/SSB points): /nrscope/src/scan_main.cc
mkdir build
cd build
cmake ../
make all -j ${nof_proc}
cd nrscope/src/
sudo ./nrscope | tee ./$(date +"%Y-%m-%d_%H:%M:%S").txt | grep Found # This command can save the trace and show if cell or DCIs are found.
# or to scan all 5G SA cells (in nrscope/src/)
sudo ./nrscan
Please refer to this wiki page for the description of log output and FAQ.