[[TOC]]
This document is complementary to the RFSIMULATOR Tutorial.
Channel models in the context of wireless communication refer to mathematical models that simulate the effects of transmission mediums on signal propagation. These models account for factors such as attenuation, interference, and fading, which can affect the quality of communication between transmitter and receiver.
Different channel models represent different real-world scenarios, such as urban environments, indoor spaces, or rural areas. By using these models, researchers and engineers can predict and evaluate the performance of wireless systems under various conditions.
OpenAirInterface RFSimulator incorporates a channel simulation feature. This feature allows any component to modify the time domain samples of a RF channel. It achieves this by applying predefined models, such as those defined in 3GPP TR 36.873 or TR 38.901.
The definition, configuration, and real-time modification of a channel model are implemented in a common code. This code is included in UE, gNB and eNB. It is utilized when operating with the RFSimulator or the L1 simulator. PHY simulators also employ channel simulation, but their configuration is accomplished via dedicated command-line options.
The RFSimulator is the exclusive option that provides access to all the configuration and real-time modification features of OAI's channel simulation. This makes it a comprehensive tool for managing and manipulating channel simulations in OAI.
OAI channel simulation is using the config module to get its parameters at init time. The telnet server includes a set of commands which can be used to dynamically modify some channel model parameters.
The relevant source files are:
All channel parameters are set depending on the model name via a call to:
channel_desc_t *new_channel_desc_scm(uint8_t nb_tx,
uint8_t nb_rx,
SCM_t channel_model,
double sampling_rate,
uint64_t center_freq,
double channel_bandwidth,
double DS_TDL,
double maxDoppler,
const corr_level_t corr_level,
double forgetting_factor,
int32_t channel_offset,
double path_loss_dB,
float noise_power_dB);
To define and use a channel model for uplink, the gNB configuration file needs to include a channel configuration file. To do this, add:
@include "channelmod_rfsimu.conf"
at the end of the gNB configuration file, and place the channel configuration file in the same directory. The same shall be done for downlink by including the channel model configuration file at the end of UE configuration file. E.g.
All channel simulation parameters are defined in the channelmod
section. Most parameters are specific to a channel model and are only used by the rfsimulator. An example of the configuration file can be found here:
e.g. a simple scenario to with an AWGN channel:
channelmod = {
max_chan = 10;
modellist = "modellist_rfsimu_1";
modellist_rfsimu_1 = (
{
model_name = "rfsimu_channel_enB0"
type = "AWGN";
ploss_dB = 20;
noise_power_dB = -4;
forgetfact = 0;
offset = 0;
ds_tdl = 0;
},
{
model_name = "rfsimu_channel_ue0"
type = "AWGN";
ploss_dB = 20;
noise_power_dB = -2;
forgetfact = 0;
offset = 0;
ds_tdl = 0;
}
);
};
where rfsimu_channel_ue0
will be activated on server side (i.e. eNB/gNB) for uplink and rfsimu_channel_enB0
will be activated on client side (i.e. UE) for downlink.
How simulate noise of a AWGN channel? Starting from the configuration file in the previous section, in the rfsimu_channel_enB0
model part, set the noise power to:
noise_power_dB = -10
In the rfsimu_channel_ue0
model part, set the noise power to:
noise_power_dB = -20;
and the rest of the channelmod_rfsimu.conf
remains unchanged.
In order to verify the effects of the changes introduced by the channel simulation, the nr-scope
constellation tool can be used to track and analyze the modulation constellation points. This tool allows users to visualize the modulation scheme being used and assess the quality of the received signals. By observing the constellation points, users can verify whether the changes made to the system configuration have resulted in.
Please refer to this documentation telnetusage.md.
When the chanmod
option is enabled, the RF channel simulator with a channel modeling function is called. Add the following options to the command line to enable the channel model:
--rfsimulator.options chanmod
Example run of OAI RFSIM on the same machine with activation of the channel model via command line: gNB:
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.fr1.106PRB.usrpb210.conf --gNBs.[0].min_rxtxtime 6 --rfsim --rfsimulator.options chanmod --telnetsrv
UE:
sudo ./nr-uesoftmodem -r 106 --numerology 1 --band 78 -C 3619200000 --rfsim --rfsimulator.serveraddr 127.0.0.1 --uicc0.imsi 001010000000001 -O ../../../ci-scripts/conf_files/nrue.uicc.conf --rfsimulator.options chanmod
where @include "channelmod_rfsimu.conf"
has been added at the end of ci-scripts/conf_files/channelmod_rfsimu.conf
which has been copied to targets/PROJECTS/GENERIC-LTE-EPC/CONF/
.
Channel simulation parameters can also be specified on the command line by using the --channelmod
option:
CL option | type | default | description |
---|---|---|---|
modellist |
char string | DefaultChannelList |
select and load the modellist from the config file. |
max_chan |
integer | 10 | set the maximum number of channel models that can be defined in the system. Must be greater than the number of model definitions in the model list loaded at init time. |
noise_power_dBFS |
integer | 0 | Noise power in dBFS. If set, noise per channel is not applied. To achieve positive SNR use values below the default gNB/nrUE amp backoff value (-36dBFS) |
Example usage:
--channelmod.modellist modellist_rfsimu_2
Several model lists can be defined in the OAI channel simulation configuration file. One, defined by the modellist
parameter is loaded at init time. In the configuration file each model list item describes a channel model using a group of parameters:
Parameter name | Type | Default | Description |
---|---|---|---|
model_name |
char string | mandatory | name of the model, as used in the code to retrieve a model definition. |
type |
char string | AWGN |
name of the channel modelization algorithm applied on RF signal. The list of available models is defined in [sim.h ](../sim.h] |
ploss_dB |
real (float) | 0 | total path loss of the channel including shadow fading, in dB |
noise_power_dB |
real (double) | -50 | Noise power in dB, used to compute the SNR. Its value is proportional to the noise added. |
forgetfact |
real (double) | 0 | Forgetting factor, allows for simple 1st order temporal variation. 0 means a new channel every call, 1 means keep channel constant all the time |
offset |
integer | 0 | channel offset for accessing the input signal, in samples |
ds_tdl |
real double | 0 | delay spread for TDL models |
ploss_dB
and noise_power_dB
are applied to each IQ sample in order to scale the received signal.
Example usage, set the offset for the selected model of the selected modellist
:
--channelmod.<modellist>.[<model ID>].offset
e.g. with the softmodem:
sudo ./nr-softmodem -O ../../../targets/PROJECTS/GENERIC-NR-5GC/CONF/gnb.sa.band78.fr1.106PRB.usrpb210.conf --gNBs.[0].min_rxtxtime 6 --rfsim --rfsimulator.options chanmod --telnetsrv --channelmod.modellist modellist_rfsimu_2 --channelmod.modellist_rfsimu_2.[1].offset 120
Add the --telnetsrv
option to the command line. Then in a new shell, connect to the telnet server, e.g.:
$ telnet 127.0.0.1 9090
Trying 127.0.0.1...
Connected to 127.0.0.1.
Escape character is '^]'
to enter the command and control of the simulator press any key: softmodem_enb
will be displayed for the eNB/gNB and softmodem_5Gue
will be displayed for the UE. Select a different port in order to use both servers on the same machine.
The telnet server includes two modules to change the RF channel simulation in real-time:
channelmod
to dynamically modify the channel model configuration parametersrfsimu
to set a different channel model
They both have their own help:
softmodem_enb> help
.....................................
module 4 = channelmod:
channelmod help
channelmod show <predef,current>
channelmod modify <channelid> <param> <value>
channelmod show params <channelid> <param> <value>
module 5 = rfsimu:
rfsimu setmodel <model name> <model type>
rfsimu setdistance <model name> <distance>
rfsimu getdistance <model name>
rfsimu vtime
softmodem_enb> channelmod help
channelmod commands can be used to display or modify channel models parameters
channelmod show predef: display predefined model algorithms available in oai
channelmod show current: display the currently used models in the running executable
channelmod modify <model index> <param name> <param value>: set the specified parameters in a current model to the given value
<model index> specifies the model, the show current model command can be used to list the current models indexes
<param name> can be one of "riceanf", "aoa", "randaoa", "ploss", "noise_power_dB", "offset", "forgetf"
softmodem_enb>
Example usage:
Command | Description |
---|---|
channelmod show current |
Monitor the current status |
channelmod show predef |
See the available channel modelss |
channelmod modify <channelid> <param> <value> |
Set parameters specific to the channel model, e.g. pathloss, Ricean factor |
Where <param>
in the channelmod modify
command can be:
Parameter | Type | Range | Description |
---|---|---|---|
riceanf |
double | 0 to 1 | Ricean factor, of first tap w.r.t. other taps (where 0 means AWGN and 1 means Rayleigh channel) |
aoa |
double | 0 to 2*Pi | Angle of arrival of wavefront (in radians). For Ricean channel only. This assumes that both RX and TX have linear antenna arrays with lambda/2 antenna spacing. Also it is assumed that the arrays are parallel to each other and that they are far enough apart so that we can safely assume plane wave propagation. |
randaoa |
bool | 0 or 1 | randomized angle of arrival according to a uniform random distribution |
ploss |
double | - | same as ploss_dB in Model lists |
noise_power_dB |
int | - | same as noise_power_dB in Model lists |
forgetf |
double | 0 to 1 | same as forgetfact in Model lists |
Example usage:
channelmod modify 0 ploss 12
channelmod modify 0 noise_power_dB 3
This module can be used to set a different channel model, e.g. rfsimu setmodel AWGN
.