Main Content

Model RF Impairments in 5G NR Downlink Waveform

Since R2024b

This example shows how to model RF impairments introduced by a superheterodyne transmitter, such as phase noise, in-phase and quadrature (I/Q) imbalance, filter effects, and memoryless nonlinearity, on a 5G NR downlink waveform. It also shows how to measure the corresponding error vector magnitude (EVM).

Introduction

The example comprises these steps:

  1. Generate a 5G NR downlink waveform defined by the 3GPP NR standard.

  2. Model RF impairments as components of a superheterodyne transmitter.

  3. Calculate the EVM of the 5G NR downlink waveform that is applied to the superheterodyne transmitter.

This figure shows the processing chain implemented in this example. For a more detailed discussion of the EVM measurement workflow, see the EVM Measurement of 5G NR Downlink Waveforms with RF Impairments (5G Toolbox) example.

5G_NRDownlink_EVM_ProcessingChain_new.png

Simulation Parameters

Simulation Parameters for 5G NR Downlink Waveform Generation

For RF testing of base stations, the 3GPP 5G NR standard specifies a series of NR test model (NR-TM) waveforms. For testing user equipment (UE), the standard outlines a set of fixed reference channel (FRC) waveforms. The NR-TMs and FRCs for frequency range 1 (FR1) are detailed in TS 38.141-1, whereas those for frequency range 2 (FR2) are described in TS 38.141-2.

Each FRC or NR-TM waveform is defined by a combination of these parameters:

  • NR-TM/FRC name

  • Channel bandwidth

  • Subcarrier spacing

  • Duplexing mode

Define simulation parameters for an NR downlink waveform defined by the 3GPP 5G NR standard.

rc = "NR-FR1-TM3.2"; % Reference channel (NR-TM or FRC)
% Select the NR waveform parameters
bw = "10MHz"; % Channel bandwidth
scs = "30kHz"; % Subcarrier spacing
dm = "FDD"; % Duplexing mode

For TMs, the generated waveform can contain more than one physical downlink shared channel (PDSCH). The chosen PDSCH to be analyzed is determined by the radio network temporary identifier (RNTI). By default, this example considers these RNTIs for EVM calculation with respect to the following TMs:

  • NR-FR1-TM2: RNTI = 2 (64QAM EVM)

  • NR-FR1-TM2a: RNTI = 2 (256QAM EVM)

  • NR-FR1-TM2b: RNTI = 2 (1024QAM EVM)

  • NR-FR1-TM3.1: RNTI = 0 and 2 (64QAM EVM)

  • NR-FR1-TM3.1a: RNTI = 0 and 2 (256QAM EVM)

  • NR-FR1-TM3.1b: RNTI = 0 and 2 (1024QAM EVM)

  • NR-FR1-TM3.2: RNTI = 1 (16QAM EVM)

  • NR-FR1-TM3.3: RNTI = 1 (QPSK EVM)

  • NR-FR2-TM2: RNTI = 2 (64QAM EVM)

  • NR-FR2-TM2a: RNTI = 2 (256QAM EVM)

  • NR-FR2-TM3.1: RNTI = 0 and 2 (64QAM EVM)

  • NR-FR2-TM3.1a: RNTI = 0 and 2 (256QAM EVM)

As per the specifications (TS 38.141-1, TS 38.141-2), these TMs are not designed to perform EVM measurements for conformance tests: NR-FR1-TM1.1, NR-FR1-TM1.2, NR-FR2-TM1.1. However, TMs are easy to generate and parameterize, so you can use them outside the scope of the test for which they were designed for, using their EVM measurements as a general methodology for assessing signal quality. If you generate these TMs, the algorithm used in the example measures the EVM for the following RNTIs:

  • NR-FR1-TM1.1: RNTI = 0 (QPSK EVM)

  • NR-FR1-TM1.2: RNTI = 2 (QPSK EVM)

  • NR-FR2-TM1.1: RNTI = 0 (QPSK EVM)

For PDSCH FRCs and physical downlink control channel (PDCCH), by default, RNTI 0 is considered for EVM calculation.

Calculate the PDSCH EVM for the RNTIs. To override the default PDSCH RNTIs, specify the targetRNTIs vector.

targetRNTIs = [];

Simulation Parameters for EVM Measurement

To print EVM statistics, select displayEVM.

displayEVM = true;

To plot EVM statistics, clear plotEVM.

plotEVM = true;

To measure EVM as defined in TS 38.104, Annex B(FR1) / Annex C(FR2), select evm3GPP.

evm3GPP = true;

Simulation Parameters for RF Impairments Modeling

This example considers the most common impairments that distort the waveform when it passes through an RF transmitter or receiver: phase noise, I/Q imbalance, filter effects, and memoryless nonlinearity. To enable or disable impairments, toggle the phaseNoiseOn, IQImbalanceOn, and nonLinearityModelOn flags. Define the distortion parameter values.

%#ok<*UNRCH>
% Set phase noise
phaseNoiseOn = true;
minFrequencyOffset = 1e4;

% Set I/Q imbalance
IQImbalanceOn = true;
amplitudeImbalance = 0.2;
phaseImbalance = 0.5;

% Set filtering
filterOn = true;

% Set amplifier gain
gain = 25; % Always on

% Set nonlinearity
nonLinearityModelOn = true;
rappMagnitudeSmooth = 1.15;
rappPhaseSaturation = 0.88;
rappPhaseSmooth = 3.43;

Furthermore, specify the modeling of white noise.

nfOn = true;
nf = 7;

Generate 5G NR Downlink Waveform

Before generating the 5G NR downlink waveform, specify a higher waveform sample rate to model wideband filter effects. You can increase the sample rate by multiplying the nominal sample rate with the oversampling factor, OSR. To use the nominal sample rate, set OSR to 1.

OSR = 5; % oversampling factor

% Create waveform generator object 
tmwavegen = hNRReferenceWaveformGenerator(rc,bw,scs,dm);

% Waveform bandwidth
bandwidth = tmwavegen.Config.ChannelBandwidth*1e6;

if OSR > 1
    % The |Config| property in |tmwavegen| specifies the configuration of
    % the standard-defined reference waveform. It is a read-only property.
    % To customize the waveform, make the |Config| property writable.
    tmwavegen = makeConfigWritable(tmwavegen);

    % Increase the waveform sample rate by multiplying the nominal sample
    % rate with |OSR|
    nominalSampleRate = getNominalSampleRate(tmwavegen.Config);
    tmwavegen.Config.SampleRate = nominalSampleRate*OSR;
else
    filterOn = false;
end

Now, generate the waveform and get the waveform sample rate.

[txWaveform,tmwaveinfo,resourcesinfo] = generateWaveform(tmwavegen,tmwavegen.Config.NumSubframes);
sr = tmwaveinfo.Info.SamplingRate; % waveform sample rate

Normalize the waveform to fit the dynamic range of the nonlinearity.

gain = 25;
peakPower = 10^(-gain/20);
txWaveform = peakPower.*txWaveform/max(abs(txWaveform),[],'all');

The waveform consists of one frame for frequency division duplex (FDD) and two for time division duplex (TDD). Repeat the signal twice. Remove the first half of the resulting waveform to avoid the transient introduced by the phase noise model.

txWaveform = repmat(txWaveform,2,1);

Transmitter with RF Impairments

This section shows how to model RF impairments as components of a superheterodyne transmitter. Using RF Toolbox™ Idealized Baseband library elements, add phase noise, I/Q imbalance, filter effects, and memoryless nonlinearity to model the effects of upconverting the waveform to the carrier frequency. There are two ways to model RF impairments: components-based and isolated impairments modeling. This example models impairments using component-based impairments modeling as shown in this figure. For more information on how to model the impairments as isolated constituents, see the EVM Measurement of 5G NR Downlink Waveforms with RF Impairments (5G Toolbox) example.

RFComponentsModeling.png

Build the superheterodyne transmitter architecture by characterizing these RF components:

  • IQ modulator

  • Bandpass filter (BPF)

  • Power amplifier

% Define frequency values
switch tmwavegen.Config.FrequencyRange
    case "FR1" % carrier frequency for FR1
        fc = 4e9;
    case "FR2" % carrier frequency for FR2
        fc = 30e9;
end

% Build transmitter
RFmixer = rf.Mixer('Model','iqmod');
RFfilter = rf.Filter('ResponseType','Bandpass', ...
    'UseFilterOrder',false, ...
    'PassFreq_bp',fc+[-(sr/2-(sr/2*0.6)) sr/2-(sr/2*0.6)], ...
    'PassAtten',0.7,...
    'StopFreq_bp',fc+[-(sr/2-(sr/2*0.5)) sr/2-(sr/2*0.5)], ...
    'StopAtten',60, ...
    'SampleRate',sr, ...
    'RF',fc);
RFHPA = rf.Amplifier('Gain',gain);

Add phase noise distortion. The phase noise characteristic is generated with the multipole zero model described in TR 38.803 Section 6.1.10. The figure shows the phase noise characteristic.

if phaseNoiseOn
    [level,frequencyOffset] = getPhaseNoisePSD(fc,sr,minFrequencyOffset);

    RFmixer.IncludePhaseNoise = true;
    RFmixer.PhaseNoiseLevel = level;
    RFmixer.PhaseNoiseFrequencyOffset = frequencyOffset;
    RFMixer.NoiseSeedSource = 'user';
    RFMixer.NoiseSeed = 2137;

    visualizePhaseNoise(RFmixer)
end

Figure RFmixer contains an axes object. The axes object with title Phase Noise Magnitude Response, xlabel Frequency (Estimated Sample Rate=9.57792e+07 Hz with Resolution=1461.47 Hz), ylabel dBc/Hz contains 3 objects of type line. One or more of the lines displays its values using only markers These objects represent Filter Response, Design Specification, Phase Noise Specification.

Add I/Q imbalance by applying a 0.2 dB amplitude imbalance and a 0.5 degree phase imbalance to the mixer. You can also increase the amplitude and phase imbalances by setting GainImbalance and PhaseImbalance to higher values.

if IQImbalanceOn
    RFMixer.GainImbalance = amplitudeImbalance;
    RFMixer.PhaseImbalance = phaseImbalance;
end

Filter the waveform by using a BPF and plot its magnitude response.

If the current passband and stopband frequencies result in high EVM values for a different waveform bandwidth and OSR, use a wider filter by increasing the parameters PassFreq_bp and StopFreq_bp in the Idealized Baseband filter block. To use a narrower filter, reduce PassFreq_bp and StopFreq_bp. You can also modify the passband ripple and the stopband attenuation. This figure shows the magnitude response of the BPF.

if filterOn
    RFfilter.FrequencyPoints = linspace(fc-sr,fc+sr,2001);

    visualize(RFfilter)
end

Figure contains an axes object. The axes object with xlabel Frequency [Hz], ylabel S21 [Mag (dB)] contains an object of type line.

Introduce nonlinear distortion using the Rapp model in the power amplifier. Set the parameters for the Rapp model to match the characteristics of the memoryless model from TR 38.803 Annex A.1. These figures show the nonlinearity introduced by the Rapp model.

if nonLinearityModelOn
    RFHPA.Model = 'modified-rapp';

    RFHPA.MagnitudeGainDB = gain;
    RFHPA.Vsat = gain;
    RFHPA.MagnitudeSmooth = rappMagnitudeSmooth;

    RFHPA.PhaseSaturation = rappPhaseSaturation;
    RFHPA.PhaseSmooth = rappPhaseSmooth;

    visualize(RFHPA)
    plotNonLinearCharacteristic(RFHPA)
end

Figure RFHPA contains 2 axes objects. Axes object 1 with title Rapp AM/AM, xlabel P_i_n (dBm), ylabel P_o_u_t (dBm) contains an object of type line. Axes object 2 with title Rapp AM/PM, xlabel P_i_n (dBm), ylabel Phase (degs) contains an object of type line.

Figure contains an axes object. The axes object with title Nonlinearity Impairment, xlabel Input Power (dBW), ylabel Gainless Output Power (dBW) contains 2 objects of type line. One or more of the lines displays its values using only markers These objects represent Linear characteristic, Rapp nonlinearity.

Finally, introduce white noise in elements of the transmitter.

if nfOn
    % Speciy NF in IQ modulator
    RFmixer.IncludeNoise = true;
    RFmixer.NF = nf;

    % Specify NF in HPA
    RFHPA.IncludeNoise = true;
    RFHPA.NF = nf;
end

Simulate the impairments of the transmitter on the waveform.

out_iq = RFmixer(txWaveform);
release(RFmixer)

if filterOn
    out_filt = RFfilter(out_iq);
    release(RFfilter)
else
    out_filt = out_iq;
end

rxWaveform = RFHPA(out_filt);
release(RFHPA)

Plot the spectrum of the waveform before and after adding the RF impairments.

scope = spectrumAnalyzer('SampleRate',sr,...
    'ChannelNames',{'Before impairments','After impairments'},...
    'Title', 'Waveform before and after impairments');
scope([(1/peakPower).*txWaveform,rxWaveform]);
release(scope);

The signal was previously repeated twice. Remove the first half of this signal. This avoids any transient introduced by the impairment models.

nFrames = 1; % because dm = "FDD"
rxWaveform(1:nFrames*tmwaveinfo.Info.SamplesPerSubframe*10,:) = [];

Measure the EVM of the 5G NR Downlink Waveform

Calculate the EVM of the resulting signal. In this example, you plot the RMS and peak EVMs per orthogonal frequency division multiplexing (OFDM) symbol, slot, and subcarrierand calculate the overall EVM (RMS EVM averaged over the complete waveform). Annex B and Annex C of TS 38.104 define alternative methods for computing the EVM in FR1 and FR2, respectively. For detailed steps on the decoding and analysis of the waveform, see the description of the helper function hNRDownlinkEVM in the EVM Measurement of 5G NR Downlink Waveforms with RF Impairments (5G Toolbox) example.

cfg = struct();
cfg.Evm3GPP = evm3GPP;
cfg.TargetRNTIs = targetRNTIs;
cfg.PlotEVM = plotEVM;
cfg.DisplayEVM = displayEVM;
cfg.IQImbalance = IQImbalanceOn;

% Compute and display EVM measurements
[evmInfo,eqSym,refSym] = hNRDownlinkEVM(tmwavegen.Config,rxWaveform,cfg);
EVM stats for BWP idx : 1
Low edge PDSCH RMS EVM, Peak EVM, slot 0: 1.197 4.183%
Low edge DM-RS RMS EVM, Peak EVM, slot 0: 1.072 2.475%
High edge PDSCH RMS EVM, Peak EVM, slot 0: 1.189 4.260%
High edge DM-RS RMS EVM, Peak EVM, slot 0: 1.072 2.475%
Low edge PDSCH RMS EVM, Peak EVM, slot 1: 1.265 4.133%
Low edge DM-RS RMS EVM, Peak EVM, slot 1: 1.274 3.491%
High edge PDSCH RMS EVM, Peak EVM, slot 1: 1.263 4.098%
High edge DM-RS RMS EVM, Peak EVM, slot 1: 1.274 3.491%
Low edge PDSCH RMS EVM, Peak EVM, slot 2: 1.161 3.780%
Low edge DM-RS RMS EVM, Peak EVM, slot 2: 1.130 2.516%
High edge PDSCH RMS EVM, Peak EVM, slot 2: 1.163 4.014%
High edge DM-RS RMS EVM, Peak EVM, slot 2: 1.130 2.516%
Low edge PDSCH RMS EVM, Peak EVM, slot 3: 1.250 4.220%
Low edge DM-RS RMS EVM, Peak EVM, slot 3: 1.417 3.841%
High edge PDSCH RMS EVM, Peak EVM, slot 3: 1.248 4.198%
High edge DM-RS RMS EVM, Peak EVM, slot 3: 1.417 3.841%
Low edge PDSCH RMS EVM, Peak EVM, slot 4: 1.184 4.170%
Low edge DM-RS RMS EVM, Peak EVM, slot 4: 1.089 2.432%
High edge PDSCH RMS EVM, Peak EVM, slot 4: 1.182 4.217%
High edge DM-RS RMS EVM, Peak EVM, slot 4: 1.089 2.432%
Low edge PDSCH RMS EVM, Peak EVM, slot 5: 1.253 4.089%
Low edge DM-RS RMS EVM, Peak EVM, slot 5: 1.118 3.114%
High edge PDSCH RMS EVM, Peak EVM, slot 5: 1.261 4.358%
High edge DM-RS RMS EVM, Peak EVM, slot 5: 1.118 3.114%
Low edge PDSCH RMS EVM, Peak EVM, slot 6: 1.110 3.451%
Low edge DM-RS RMS EVM, Peak EVM, slot 6: 1.096 2.614%
High edge PDSCH RMS EVM, Peak EVM, slot 6: 1.106 3.578%
High edge DM-RS RMS EVM, Peak EVM, slot 6: 1.096 2.614%
Low edge PDSCH RMS EVM, Peak EVM, slot 7: 1.091 3.738%
Low edge DM-RS RMS EVM, Peak EVM, slot 7: 1.123 2.638%
High edge PDSCH RMS EVM, Peak EVM, slot 7: 1.091 3.805%
High edge DM-RS RMS EVM, Peak EVM, slot 7: 1.123 2.638%
Low edge PDSCH RMS EVM, Peak EVM, slot 8: 1.176 3.867%
Low edge DM-RS RMS EVM, Peak EVM, slot 8: 1.162 2.749%
High edge PDSCH RMS EVM, Peak EVM, slot 8: 1.173 3.869%
High edge DM-RS RMS EVM, Peak EVM, slot 8: 1.162 2.749%
Low edge PDSCH RMS EVM, Peak EVM, slot 9: 1.100 3.701%
Low edge DM-RS RMS EVM, Peak EVM, slot 9: 1.045 2.934%
High edge PDSCH RMS EVM, Peak EVM, slot 9: 1.100 3.680%
High edge DM-RS RMS EVM, Peak EVM, slot 9: 1.045 2.934%
Low edge PDSCH RMS EVM, Peak EVM, slot 10: 1.124 3.422%
Low edge DM-RS RMS EVM, Peak EVM, slot 10: 1.100 2.398%
High edge PDSCH RMS EVM, Peak EVM, slot 10: 1.126 3.425%
High edge DM-RS RMS EVM, Peak EVM, slot 10: 1.100 2.398%
Low edge PDSCH RMS EVM, Peak EVM, slot 11: 1.191 4.292%
Low edge DM-RS RMS EVM, Peak EVM, slot 11: 1.166 3.107%
High edge PDSCH RMS EVM, Peak EVM, slot 11: 1.193 4.023%
High edge DM-RS RMS EVM, Peak EVM, slot 11: 1.166 3.107%
Low edge PDSCH RMS EVM, Peak EVM, slot 12: 1.172 3.829%
Low edge DM-RS RMS EVM, Peak EVM, slot 12: 1.133 2.644%
High edge PDSCH RMS EVM, Peak EVM, slot 12: 1.174 3.822%
High edge DM-RS RMS EVM, Peak EVM, slot 12: 1.133 2.644%
Low edge PDSCH RMS EVM, Peak EVM, slot 13: 1.297 4.278%
Low edge DM-RS RMS EVM, Peak EVM, slot 13: 1.271 2.706%
High edge PDSCH RMS EVM, Peak EVM, slot 13: 1.295 4.304%
High edge DM-RS RMS EVM, Peak EVM, slot 13: 1.271 2.706%
Low edge PDSCH RMS EVM, Peak EVM, slot 14: 1.208 4.109%
Low edge DM-RS RMS EVM, Peak EVM, slot 14: 1.067 2.699%
High edge PDSCH RMS EVM, Peak EVM, slot 14: 1.203 4.001%
High edge DM-RS RMS EVM, Peak EVM, slot 14: 1.067 2.699%
Low edge PDSCH RMS EVM, Peak EVM, slot 15: 1.220 5.090%
Low edge DM-RS RMS EVM, Peak EVM, slot 15: 1.064 2.133%
High edge PDSCH RMS EVM, Peak EVM, slot 15: 1.214 5.005%
High edge DM-RS RMS EVM, Peak EVM, slot 15: 1.064 2.133%
Low edge PDSCH RMS EVM, Peak EVM, slot 16: 1.110 3.759%
Low edge DM-RS RMS EVM, Peak EVM, slot 16: 1.161 3.121%
High edge PDSCH RMS EVM, Peak EVM, slot 16: 1.116 3.804%
High edge DM-RS RMS EVM, Peak EVM, slot 16: 1.161 3.121%
Low edge PDSCH RMS EVM, Peak EVM, slot 17: 1.349 4.329%
Low edge DM-RS RMS EVM, Peak EVM, slot 17: 1.363 3.074%
High edge PDSCH RMS EVM, Peak EVM, slot 17: 1.350 4.368%
High edge DM-RS RMS EVM, Peak EVM, slot 17: 1.363 3.074%
Low edge PDSCH RMS EVM, Peak EVM, slot 18: 1.330 4.501%
Low edge DM-RS RMS EVM, Peak EVM, slot 18: 1.447 3.380%
High edge PDSCH RMS EVM, Peak EVM, slot 18: 1.327 4.519%
High edge DM-RS RMS EVM, Peak EVM, slot 18: 1.447 3.380%
PDCCH RMS EVM, Peak EVM, slot 0: 0.506 1.116%
PDCCH DM-RS RMS EVM, Peak EVM, slot 0: 0.248 0.337%
PDCCH RMS EVM, Peak EVM, slot 1: 0.406 0.854%
PDCCH DM-RS RMS EVM, Peak EVM, slot 1: 0.214 0.326%
PDCCH RMS EVM, Peak EVM, slot 2: 0.501 0.965%
PDCCH DM-RS RMS EVM, Peak EVM, slot 2: 0.245 0.319%
PDCCH RMS EVM, Peak EVM, slot 3: 0.451 1.110%
PDCCH DM-RS RMS EVM, Peak EVM, slot 3: 0.238 0.387%
PDCCH RMS EVM, Peak EVM, slot 4: 0.506 1.071%
PDCCH DM-RS RMS EVM, Peak EVM, slot 4: 0.250 0.426%
PDCCH RMS EVM, Peak EVM, slot 5: 0.475 1.188%
PDCCH DM-RS RMS EVM, Peak EVM, slot 5: 0.156 0.297%
PDCCH RMS EVM, Peak EVM, slot 6: 0.533 1.123%
PDCCH DM-RS RMS EVM, Peak EVM, slot 6: 0.215 0.367%
PDCCH RMS EVM, Peak EVM, slot 7: 0.509 0.944%
PDCCH DM-RS RMS EVM, Peak EVM, slot 7: 0.271 0.442%
PDCCH RMS EVM, Peak EVM, slot 8: 0.484 1.140%
PDCCH DM-RS RMS EVM, Peak EVM, slot 8: 0.194 0.338%
PDCCH RMS EVM, Peak EVM, slot 9: 0.434 0.888%
PDCCH DM-RS RMS EVM, Peak EVM, slot 9: 0.286 0.533%
PDCCH RMS EVM, Peak EVM, slot 10: 0.419 0.879%
PDCCH DM-RS RMS EVM, Peak EVM, slot 10: 0.226 0.408%
PDCCH RMS EVM, Peak EVM, slot 11: 0.433 0.868%
PDCCH DM-RS RMS EVM, Peak EVM, slot 11: 0.204 0.309%
PDCCH RMS EVM, Peak EVM, slot 12: 0.435 0.826%
PDCCH DM-RS RMS EVM, Peak EVM, slot 12: 0.202 0.321%
PDCCH RMS EVM, Peak EVM, slot 13: 0.509 1.250%
PDCCH DM-RS RMS EVM, Peak EVM, slot 13: 0.303 0.463%
PDCCH RMS EVM, Peak EVM, slot 14: 0.396 0.827%
PDCCH DM-RS RMS EVM, Peak EVM, slot 14: 0.184 0.284%
PDCCH RMS EVM, Peak EVM, slot 15: 0.472 1.117%
PDCCH DM-RS RMS EVM, Peak EVM, slot 15: 0.173 0.348%
PDCCH RMS EVM, Peak EVM, slot 16: 0.524 1.045%
PDCCH DM-RS RMS EVM, Peak EVM, slot 16: 0.282 0.416%
PDCCH RMS EVM, Peak EVM, slot 17: 0.477 0.953%
PDCCH DM-RS RMS EVM, Peak EVM, slot 17: 0.198 0.340%
PDCCH RMS EVM, Peak EVM, slot 18: 0.539 1.130%
PDCCH DM-RS RMS EVM, Peak EVM, slot 18: 0.207 0.461%

Figure contains 3 axes objects. Axes object 1 with title PDSCH EVM vs Symbol BWP index :1, xlabel Symbol, ylabel EVM (%) contains 2 objects of type line. These objects represent rms EVM, peak EVM. Axes object 2 with title PDSCH EVM vs Slot BWP index :1, xlabel Slot, ylabel EVM (%) contains 2 objects of type line. These objects represent rms EVM, peak EVM. Axes object 3 with title PDSCH EVM vs Subcarrier BWP index :1, xlabel Subcarrier, ylabel EVM (%) contains 2 objects of type line. These objects represent rms EVM, peak EVM.

Figure EVM (%) contains an axes object. The axes object with title PDSCH EVM Resource Grid, BWP index : 1, xlabel OFDM symbols, ylabel Subcarriers contains an object of type surface.

Figure contains an axes object. The axes object with title PDSCH Equalized Symbols Constellation, BWP index : 1 contains 2 objects of type line. One or more of the lines displays its values using only markers

Figure contains 3 axes objects. Axes object 1 with title PDCCH EVM vs Symbol BWP index :1, xlabel Symbol, ylabel EVM (%) contains 2 objects of type line. These objects represent rms EVM, peak EVM. Axes object 2 with title PDCCH EVM vs Slot BWP index :1, xlabel Slot, ylabel EVM (%) contains 2 objects of type line. These objects represent rms EVM, peak EVM. Axes object 3 with title PDCCH EVM vs Subcarrier BWP index :1, xlabel Subcarrier, ylabel EVM (%) contains 2 objects of type line. These objects represent rms EVM, peak EVM.

Figure EVM (%) contains an axes object. The axes object with title PDCCH EVM Resource Grid, BWP index : 1, xlabel OFDM symbols, ylabel Subcarriers contains an object of type surface.

Figure contains an axes object. The axes object with title PDCCH Equalized Symbols Constellation, BWP index : 1 contains 2 objects of type line. One or more of the lines displays its values using only markers

Averaged overall PDSCH RMS EVM: 1.202%
Overall PDSCH Peak EVM = 5.0898%
Averaged overall PDCCH RMS EVM: 0.476%
Overall PDCCH Peak EVM = 1.2498%

As per TS 38.104, the minimum requirement for the RMS EVM for QPSK/BPSK, 16QAM, 64QAM and 256QAM modulation must not exceed the EVM level of 17.5%, 12.5%, 8%, and 3.5%, respectively. This example's default waveform NR-FR1-TM3.2 utilizes 16QAM, and the printed EVM measurements indicate that the minimum requirement is met due to the PDSCH RMS EVM remaining below 12.5%.

The EVM per OFDM symbol, per slot, per subcarrier, and resource grid plots help identify specific issues affecting the waveform's integrity:

  • The OFDM symbol plot can be analyzed to pinpoint precise moments when the signal integrity decreases to help identify adaptive modulation schemes that can apply real-time correction mechanisms.

  • The slot plot can give gain insight into broader fluctuations over time to address interference patterns or network conditions.

  • The subcarrier plot can be examined to identify frequency selective interference and fading to improve spectral efficiency.

  • The resource grid can be investigated to optimize scheduling algorithms and resource allocation strategies to minimize overall network errors.

In this example, the EVM across all plots must remain stable because the RF impairments modeled are temporally and spectrally independent.

The constellation diagram helps diagnose random versus systematic issues. A widely dispersed contellation indicates high levels of noise or uncorrelated interference, whereas consistent deviations point to high non-linearity and I/Q imbalance.

References

[1] TR 38.803 V14.3.0. "Study on new radio access technology: Radio Frequency (RF) and co-existence aspects." 3rd Generation Partnership Project; Technical Specification Group Radio Access Network.

[2] TS 38.141-1. "NR; Base Station (BS) conformance testing Part 1: Conducted conformance testing." 3rd Generation Partnership Project; Technical Specification Group Radio Access Network.

[3] TS 38.141-2. "NR; Base Station (BS) conformance testing Part 2: Conducted conformance testing." 3rd Generation Partnership Project; Technical Specification Group Radio Access Network.

[4] TS 38.104. "NR; Base Station (BS) radio transmission and reception." 3rd Generation Partnership Project; Technical Specification Group Radio Access Network.

Local Functions

function [sampleRate] = getNominalSampleRate(cfgObj)
    % Obtain nominal sample rate for the input parameter CFGOBJ. CFGOBJ is
    % an object of type 'nrDLCarrierConfig'
    sampleRate = nr5g.internal.wavegen.maxSampleRate(cfgObj);
end

function [PN_dBcPerHz,fVec] = getPhaseNoisePSD(fc,sr,minFrequencyOffset)
    % Compute phase noise PSD for specified frequency offset fVec (in Hz) as
    % defined in TR 38.803
    
    fVec = logspace(log10(minFrequencyOffset),log10(sr/2)-0.001,20);
    [~,idx] = min(abs(fc - [29.55, 45, 70]*1e9));
    validMdl = {'29.55','45','70'};
    mdl = validMdl{idx};
    switch mdl
        case '29.55'
            % Parameter set from TR 38.803 for 29.55 GHz Fc
            fcBase = 29.55e9;
            fz = [3e3 550e3 280e6];
            fp = [1 1.6e6 30e6];
            alphaz = [2.37 2.7 2.53];
            alphap = [3.3 3.3 1];
            PSD0 = 32;
        case '45'
            % Parameter set from TR 38.803 for 45 GHz Fc
            fcBase = 45e9;
            fz = [3e3 451e3 458e6];
            fp = [1 1.54e6 30e6];
            alphaz = [2.37 2.7 2.53];
            alphap = [3.3 3.3 1];
            PSD0 = 35.65;
        otherwise
            % Parameter set from TR 38.803 for 70 GHz Fc
            fcBase = 70e9;
            fz = [3e3 396e3 754e6];
            fp = [1 1.55e6 30e6];
            alphaz = [2.37 2.7 2.53];
            alphap = [3.3 3.3 1];
            PSD0 = 39.49;
    end
    
    % Compute numerator
    num = ones(size(fVec));
    for ii = 1:numel(fz)
        num = num.*(1 + (fVec./fz(ii)).^alphaz(ii));
    end
    
    % Compute denominator
    den = ones(size(fVec));
    for ii = 1:numel(fp)
        den = den.*(1 + (fVec./fp(ii)).^alphap(ii));
    end
    
    % Compute phase noise and apply a shift for carrier frequencies
    % different from the base frequency
    PN_dBcPerHz = 10*log10(num./den) + PSD0 + 20*log10(fc/fcBase);
end

function plotNonLinearCharacteristic(RFHPA)
    % Plot the nonlinear characteristic of the power amplifier (PA) impairment.
    
    % Input samples
    x = complex((1/sqrt(2))*(-1+2*rand(1000,1)),(1/sqrt(2))*(-1+2*rand(1000,1)));

    % Nonlinearity
    yRapp = RFHPA(x);

    % Release object to feed it a different number of samples
    release(RFHPA);

    % Plot characteristic
    figure;
    plot(10*log10(abs(x).^2),10*log10(abs(x).^2));
    hold on;
    grid on
    plot(10*log10(abs(x).^2),10*log10(abs(yRapp).^2)-RFHPA.Gain,'.');
    xlabel('Input Power (dBW)');
    ylabel('Gainless Output Power (dBW)');
    title('Nonlinearity Impairment')
    legend('Linear characteristic', 'Rapp nonlinearity','Location','Northwest');
end

See Also

| | | |