NR SSB Beam Sweeping
This example shows how to employ beam sweeping at both the transmitter (gNB) and receiver (UE) ends of a 5G NR system. Using synchronization signal blocks (SSB), this example illustrates some of the beam management procedures used during initial access. To accomplish beam sweeping, the example uses several components from Phased Array System Toolbox™.
Introduction
The support of millimeter wave (mmWave) frequencies requires directional links, which led to the specification of beam management procedures for initial access in NR. Beam management is a set of Layer 1 (physical) and Layer 2 (medium access control) procedures to acquire and maintain a set of beam pair links (a beam used at gNB paired with a beam used at UE). Beam management procedures are applied for both downlink and uplink transmission and reception [ 1 ], [ 2 ]. These procedures include:
Beam sweeping
Beam measurement
Beam determination
Beam reporting
Beam recovery
This example focuses on initial access procedures for idle users when a connection is established between the user equipment (UE) and access network node (gNB). At the physical layer, using synchronization signal blocks (SSB) transmitted as a burst in the downlink direction (gNB to UE), the example highlights both transmit/receive point (TRP) beam sweeping and UE beam sweeping to establish a beam pair link. Among the multiple beam management procedures, TR 38.802 defines this dual-end sweep as procedure P-1 [ 1 ].
Once connected, the same beam pair link can be used for subsequent transmissions. If necessary, the beams are further refined using CSI-RS (for downlink) and SRS (for uplink). In case of beam failure, these pair links can be reestablished. For an example of beam pair refinement, see NR Downlink Transmit-End Beam Refinement Using CSI-RS (5G Toolbox).
This example generates an NR synchronization signal burst, beamforms each of the SSBs within the burst to sweep over both azimuth and elevation directions, transmits this beamformed signal over a spatial scattering channel, and processes this received signal over the multiple receive-end beams. The example measures the reference signal received power (RSRP) for each of the transmit-receive beam pairs (in a dual loop) and determines the beam pair link with the maximum RSRP. This beam pair link thus signifies the best beam-pair at transmit and receive ends for the simulated spatial scenario. This figure shows the main processing steps with the beam management ones highlighted in color.
rng(211); % Set RNG state for repeatability
Simulation Parameters
Define system parameters for the example. Modify these parameters to explore their impact on the system.
prm.NCellID = 1; % Cell ID prm.FreqRange = 'FR1'; % Frequency range: 'FR1' or 'FR2' prm.CenterFreq = 3.5e9; % Hz prm.SSBlockPattern = 'Case B'; % Case A/B/C/D/E prm.SSBTransmitted = [ones(1,8) zeros(1,0)]; % 4/8 or 64 in length prm.TxArraySize = [8 8]; % Transmit array size, [rows cols] prm.TxAZlim = [-90 90]; % Transmit azimuthal sweep limits prm.TxELlim = [-90 0]; % Transmit elevation sweep limits prm.RxArraySize = [2 2]; % Receive array size, [rows cols] prm.RxAZlim = [-90 90]; % Receive azimuthal sweep limits prm.RxELlim = [-45 45]; % Receive elevation sweep limits prm.ElevationSweep = false; % Enable/disable elevation sweep prm.SNRdB = 30; % SNR, dB prm.RSRPMode = 'SSSwDMRS'; % {'SSSwDMRS', 'SSSonly'}
The example uses these parameters:
Cell ID for a single-cell scenario with a single BS and UE
Frequency range, as a string to designate FR1 or FR2 operation
Center frequency, in Hz, dependent on the frequency range
Synchronization signal block pattern as one of Case A/B/C for FR1 and Case D/E for FR2. This also selects the subcarrier spacing.
Transmitted SSBs in the pattern, as a binary vector of length 4 or 8 for FR1 and length 64 for FR2. The number of SSBs transmitted sets the number of beams at both transmit and receive ends.
Transmit array size, as a two-element row vector specifying the number of antenna elements in the rows and columns of the transmit array, respectively. A uniform rectangular array (URA) is used when both values are greater than one.
Transmit azimuthal sweep limits in degrees to specify the starting and ending azimuth angles for the sweep
Transmit elevation sweep limits in degrees to specify the starting and ending elevation angles for the sweep
Receive array size, as a two-element row vector specifying the number of antenna elements in the rows and columns of the receive array, respectively. A uniform rectangular array (URA) is used when both values are greater than one.
Receive azimuthal sweep limits in degrees to specify the starting and ending azimuth angles for the sweep
Receive elevation sweep limits in degrees to specify the starting and ending elevation angles for the sweep
Enable or disable elevation sweep for both transmit and receive ends. Enable elevation sweep for FR2 and/or URAs
Signal-to-noise ratio in dB
Measurement mode for SSB to specify the use of only secondary synchronization signals ('SSSonly') or use of PBCH DM-RS along with secondary synchronization signals ('SSSwDMRS')
prm = validateParams(prm);
Synchronization Signal Burst Configuration
Set up the synchronization signal burst parameters by using the specified system parameters. For initial access, set the SSB periodicity to 20 ms.
txBurst = nrWavegenSSBurstConfig; txBurst.BlockPattern = prm.SSBlockPattern; txBurst.TransmittedBlocks = prm.SSBTransmitted; txBurst.Period = 20; txBurst.SubcarrierSpacingCommon = prm.SubcarrierSpacingCommon; % Configure an nrDLCarrierConfig object to use the synchronization signal % burst parameters and to disable other channels. This object will be used % by nrWaveformGenerator to generate the SS burst waveform. cfgDL = configureWaveformGenerator(prm,txBurst);
Refer to the tutorial Synchronization Signal Blocks and Bursts (5G Toolbox) for more details on synchronization signal blocks and bursts.
Burst Generation
Create the SS burst waveform [ 3 ] by calling the nrWaveformGenerator
function. The generated waveform is not yet beamformed.
burstWaveform = nrWaveformGenerator(cfgDL); % Display spectrogram of SS burst waveform figure; ofdmInfo = nrOFDMInfo(cfgDL.SCSCarriers{1}.NSizeGrid,prm.SCS); nfft = ofdmInfo.Nfft; spectrogram(burstWaveform,ones(nfft,1),0,nfft,'centered',ofdmInfo.SampleRate,'yaxis','MinThreshold',-130); title('Spectrogram of SS burst waveform')
Channel Configuration
Configure a spatial scattering MIMO channel channel
. This channel model applies free space path loss and, optionally, other atmospheric attenuations to the input. Specify the locations for the BS and UE as [x,y,z]
coordinates in a Cartesian system. Depending on the array sizes specified, employ either uniform linear arrays (ULA) or uniform rectangular arrays (URA). Use isotropic antenna elements for the arrays.
c = physconst('LightSpeed'); % Propagation speed lambda = c/prm.CenterFreq; % Wavelength prm.posTx = [0;0;0]; % Transmit array position, [x;y;z], meters prm.posRx = [100;-20;0]; % Receive array position, [x;y;z], meters toRxRange = rangeangle(prm.posTx,prm.posRx); spLoss = fspl(toRxRange,lambda); % Free space path loss % Transmit array if prm.IsTxURA % Uniform rectangular array arrayTx = phased.URA(prm.TxArraySize,0.5*lambda, ... 'Element',phased.IsotropicAntennaElement('BackBaffled',true)); else % Uniform linear array arrayTx = phased.ULA(prm.NumTx, ... 'ElementSpacing',0.5*lambda, ... 'Element',phased.IsotropicAntennaElement('BackBaffled',true)); end % Receive array if prm.IsRxURA % Uniform rectangular array arrayRx = phased.URA(prm.RxArraySize,0.5*lambda, ... 'Element',phased.IsotropicAntennaElement); else % Uniform linear array arrayRx = phased.ULA(prm.NumRx, ... 'ElementSpacing',0.5*lambda, ... 'Element',phased.IsotropicAntennaElement); end % Scatterer locations prm.FixedScatMode = true; if prm.FixedScatMode % Fixed single scatterer location prm.ScatPos = [50; 50; 0]; else % Generate scatterers at random positions Nscat = 10; % Number of scatterers azRange = -180:180; elRange = -90:90; randAzOrder = randperm(length(azRange)); randElOrder = randperm(length(elRange)); azAngInSph = azRange(randAzOrder(1:Nscat)); elAngInSph = elRange(randElOrder(1:Nscat)); r = 20; % radius [x,y,z] = sph2cart(deg2rad(azAngInSph),deg2rad(elAngInSph),r); prm.ScatPos = [x;y;z] + (prm.posTx + prm.posRx)/2; end % Configure channel channel = phased.ScatteringMIMOChannel; channel.PropagationSpeed = c; channel.CarrierFrequency = prm.CenterFreq; channel.SampleRate = ofdmInfo.SampleRate; channel.SimulateDirectPath = false; channel.ChannelResponseOutputPort = true; channel.Polarization = 'None'; channel.TransmitArray = arrayTx; channel.TransmitArrayPosition = prm.posTx; channel.ReceiveArray = arrayRx; channel.ReceiveArrayPosition = prm.posRx; channel.ScattererSpecificationSource = 'Property'; channel.ScattererPosition = prm.ScatPos; channel.ScattererCoefficient = ones(1,size(prm.ScatPos,2)); % Get maximum channel delay [~,~,tau] = channel(complex(randn(ofdmInfo.SampleRate*1e-3,prm.NumTx), ... randn(ofdmInfo.SampleRate*1e-3,prm.NumTx))); maxChDelay = ceil(max(tau)*ofdmInfo.SampleRate);
Transmit-End Beam Sweeping
To achieve TRP beam sweeping, beamform each of the SS blocks in the generated burst using analog beamforming. Based on the number of SS blocks in the burst and the sweep ranges specified, determine both the azimuth and elevation directions for the different beams. Then beamform the individual blocks within the burst to each of these directions.
% Number of beams at both transmit and receive ends numBeams = sum(txBurst.TransmittedBlocks); % Transmit beam angles in azimuth and elevation, equi-spaced azBW = beamwidth(arrayTx,prm.CenterFreq,'Cut','Azimuth'); elBW = beamwidth(arrayTx,prm.CenterFreq,'Cut','Elevation'); txBeamAng = hGetBeamSweepAngles(numBeams,prm.TxAZlim,prm.TxELlim, ... azBW,elBW,prm.ElevationSweep); % For evaluating transmit-side steering weights SteerVecTx = phased.SteeringVector('SensorArray',arrayTx, ... 'PropagationSpeed',c); % Get the set of OFDM symbols occupied by each SSB numBlocks = length(txBurst.TransmittedBlocks); burstStartSymbols = ssBurstStartSymbols(txBurst.BlockPattern,numBlocks); burstStartSymbols = burstStartSymbols(txBurst.TransmittedBlocks==1); burstOccupiedSymbols = burstStartSymbols.' + (1:4); % Apply steering per OFDM symbol for each SSB gridSymLengths = repmat(ofdmInfo.SymbolLengths,1,cfgDL.NumSubframes); % repeat burst over numTx to prepare for steering strTxWaveform = repmat(burstWaveform,1,prm.NumTx)./sqrt(prm.NumTx); for ssb = 1:numBeams % Extract SSB waveform from burst blockSymbols = burstOccupiedSymbols(ssb,:); startSSBInd = sum(gridSymLengths(1:blockSymbols(1)-1))+1; endSSBInd = sum(gridSymLengths(1:blockSymbols(4))); ssbWaveform = strTxWaveform(startSSBInd:endSSBInd,1); % Generate weights for steered direction wT = SteerVecTx(prm.CenterFreq,txBeamAng(:,ssb)); % Apply weights per transmit element to SSB strTxWaveform(startSSBInd:endSSBInd,:) = ssbWaveform.*(wT'); end
The beamformed burst waveform is then transmitted over the spatially-aware scattering channel.
Receive-End Beam Sweeping and Measurement
For receive-end beam sweeping, the transmitted beamformed burst waveform is received successively over each receive beam. For N
transmit beams and M
receive beams in procedure P-1, each of the N
beams is transmitted M
times from gNB so that each transmit beam is received over the M
receive beams.
The example assumes both N
and M
to be equal to the number of SSBs in the burst. For simplicity, the example generates only one burst, but to mimic the burst reception over the air M
times, the receiver processes this single burst M
times.
This figure shows a beam-based diagram for the sweeps at both gNB and UE for N = M = 4
, in the azimuthal plane. The diagram shows the time taken for the dual sweep, where each interval at gNB corresponds to an SSB and each interval at the UE corresponds to the SS burst. For the depicted scenario, beams S3
and U2
are highlighted as the selected beam-pair link notionally. The example implements the dual-sweep over a time duration of N*M
time instants.
The receive processing of the transmitted burst includes
Application of the spatially-aware fading channel
Receive gain to compensate for the induced path loss and AWGN
Receive-end beamforming
Timing correction
OFDM demodulation
Extracting the known SSB grid
Measuring the RSRP based on the specified measurement mode
The processing repeats these steps for each of the receive beams, then selects the best beam-pair based on the complete set of measurements made.
To highlight beam sweeping, the example assumes known SSB information at the receiver. For more details on recovery processing see NR Cell Search and MIB and SIB1 Recovery (5G Toolbox).
For the idle mode SS-RSRP measurement, use either only the secondary synchronization signals (SSS) or the physical broadcast channel (PBCH) demodulation reference signals (DM-RS) in addition to the SSS (Section 5.1.1. of [ 4 ]). Specify this by the RSRPMode
parameter of the example.
% Receive beam angles in azimuth and elevation, equi-spaced azBW = beamwidth(arrayRx,prm.CenterFreq,'Cut','Azimuth'); elBW = beamwidth(arrayRx,prm.CenterFreq,'Cut','Elevation'); rxBeamAng = hGetBeamSweepAngles(numBeams,prm.RxAZlim,prm.RxELlim, ... azBW,elBW,prm.ElevationSweep); % For evaluating receive-side steering weights SteerVecRx = phased.SteeringVector('SensorArray',arrayRx, ... 'PropagationSpeed',c); % AWGN level SNR = 10^(prm.SNRdB/10); % Convert to linear gain N0 = 1/sqrt(prm.NumRx*double(ofdmInfo.Nfft)*SNR); % Noise Std. Dev. % Receive gain in linear terms, to compensate for the path loss rxGain = 10^(spLoss/20); % Generate a reference grid for timing correction % assumes an SSB in first slot carrier = nrCarrierConfig('NCellID',prm.NCellID); carrier.NSizeGrid = cfgDL.SCSCarriers{1}.NSizeGrid; carrier.SubcarrierSpacing = prm.SCS; pssRef = nrPSS(carrier.NCellID); pssInd = nrPSSIndices; ibar_SSB = 0; pbchdmrsRef = nrPBCHDMRS(carrier.NCellID,ibar_SSB); pbchDMRSInd = nrPBCHDMRSIndices(carrier.NCellID); pssGrid = zeros([240 4]); pssGrid(pssInd) = pssRef; pssGrid(pbchDMRSInd) = pbchdmrsRef; refGrid = zeros([12*carrier.NSizeGrid ofdmInfo.SymbolsPerSlot]); burstOccupiedSubcarriers = carrier.NSizeGrid*6 + (-119:120).'; refGrid(burstOccupiedSubcarriers, ... burstOccupiedSymbols(1,:)) = pssGrid; % Loop over all receive beams rsrp = zeros(numBeams,numBeams); for rIdx = 1:numBeams % Fading channel, with path loss txWave = [strTxWaveform; zeros(maxChDelay,size(strTxWaveform,2))]; fadWave = channel(txWave); % Receive gain, to compensate for the path loss fadWaveG = fadWave*rxGain; % Add WGN noise = N0*randn(size(fadWaveG),"like",1i); rxWaveform = fadWaveG + noise; % Generate weights for steered direction wR = SteerVecRx(prm.CenterFreq,rxBeamAng(:,rIdx)); % Apply weights per receive element strRxWaveform = rxWaveform*conj(wR); % Correct timing offset = nrTimingEstimate(carrier, ... strRxWaveform(1:ofdmInfo.SampleRate*1e-3,:),refGrid*wR(1)'); if offset > maxChDelay offset = 0; end strRxWaveformS = strRxWaveform(1+offset:end,:); % OFDM Demodulate rxGrid = nrOFDMDemodulate(carrier,strRxWaveformS); % Loop over all SSBs in rxGrid (transmit end) for tIdx = 1:numBeams % Get each SSB grid rxSSBGrid = rxGrid(burstOccupiedSubcarriers, ... burstOccupiedSymbols(tIdx,:),:); if strcmpi(prm.RSRPMode,'SSSwDMRS') meas = nrSSBMeasurements(rxSSBGrid,carrier.NCellID,mod(tIdx-1,8)); else meas = nrSSBMeasurements(rxSSBGrid,carrier.NCellID); end rsrp(rIdx,tIdx) = max(meas.RSRPPerAntenna); end end
Beam Determination
After the dual-end sweep and measurements are complete, determine the best beam-pair link based on the RSRP measurement.
[m,i] = max(rsrp,[],'all','linear'); % First occurrence is output % i is column-down first (for receive), then across columns (for transmit) [rxBeamID,txBeamID] = ind2sub([numBeams numBeams],i(1)); % Display the selected beam pair disp(['Selected Beam pair with RSRP: ' num2str(rsrp(rxBeamID, ... txBeamID)) ' dBm', 13 ' Transmit #' num2str(txBeamID) ... ' (Azimuth: ' num2str(txBeamAng(1,txBeamID)) ', Elevation: ' ... num2str(txBeamAng(2,txBeamID)) ')' 13 ' Receive #' num2str(rxBeamID) ... ' (Azimuth: ' num2str(rxBeamAng(1,rxBeamID)) ', Elevation: ' ... num2str(rxBeamAng(2,rxBeamID)) ')' ]); % Display final beam pair patterns h = figure('Position',figposition([32 55 32 40]),'MenuBar','none'); h.Name = 'Selected Transmit Array Response Pattern'; wT = SteerVecTx(prm.CenterFreq,txBeamAng(:,txBeamID)); pattern(arrayTx,prm.CenterFreq,'PropagationSpeed',c,'Weights',wT); h = figure('Position',figposition([32 55 32 40]),'MenuBar','none'); h.Name = 'Selected Receive Array Response Pattern'; wR = SteerVecRx(prm.CenterFreq,rxBeamAng(:,rxBeamID)); pattern(arrayRx,prm.CenterFreq,'PropagationSpeed',c,'Weights',wR); % Plot MIMO scenario with tx, rx, scatterers, and determined beams. Beam % patterns in this figure resemble the power patterns in linear scale. prmScene = struct(); prmScene.TxArray = arrayTx; prmScene.RxArray = arrayRx; prmScene.TxArrayPos = prm.posTx; prmScene.RxArrayPos = prm.posRx; prmScene.ScatterersPos = prm.ScatPos; prmScene.Lambda = lambda; prmScene.ArrayScaling = 1; % To enlarge antenna arrays in the plot prmScene.MaxTxBeamLength = 45; % Maximum length of transmit beams in the plot prmScene.MaxRxBeamLength = 25; % Maximum length of receive beam in the plot hPlotSpatialMIMOScene(prmScene,wT,wR); if ~prm.ElevationSweep view(2); end
Selected Beam pair with RSRP: 56.2133 dBm Transmit #6 (Azimuth: 45, Elevation: 0) Receive #2 (Azimuth: -45, Elevation: 0)
These plots highlight the transmit directivity pattern, receive directivity pattern, and the spatial scene, respectively. The results are dependent on the individual beam directions used for the sweeps. The spatial scene offers a combined view of the transmit and receive arrays and the respective determined beams, along with the scatterers.
Summary and Further Exploration
This example highlights the P-1 beam management procedure by using synchronization signal blocks for transmit-end and receive-end beam sweeping. By measuring the reference signal received power for SSBs, you can identify the best beam pair link for a selected spatial environment.
The example allows variation on frequency range, SSB block pattern, number of SSBs, transmit and receive array sizes, transmit and receive sweep ranges, and the measuring mode. To see the impact of parameters on the beam selection, experiment with different values. The receive processing is simplified to highlight the beamforming aspects for the example.
For an example of the P-2 procedures of transmit-end beam sweeping using CSI-RS signals for the downlink, see NR Downlink Transmit-End Beam Refinement Using CSI-RS (5G Toolbox). You can use these procedures for beam refinement and adjustment in the connected mode, once the initial beam pair links are established [ 5 ], [ 6 ].
References
3GPP TR 38.802. "Study on New Radio access technology physical layer aspects." 3rd Generation Partnership Project; Technical Specification Group Radio Access Network.
Giordani, M., M. Polese, A. Roy, D. Castor, and M. Zorzi. "A tutorial on beam management for 3GPP NR at mmWave frequencies." IEEE Comm. Surveys & Tutorials, vol. 21, No. 1, Q1 2019.
3GPP TS 38.211. "NR; Physical channels and modulation." 3rd Generation Partnership Project; Technical Specification Group Radio Access Network.
3GPP TS 38.215. "NR; Physical layer measurements." 3rd Generation Partnership Project; Technical Specification Group Radio Access Network.
Giordani, M., M. Polese, A. Roy, D. Castor, and M. Zorzi. "Standalone and non-standalone beam management for 3GPP NR at mmWaves." IEEE Comm. Mag., April 2019, pp. 123-129.
Onggosanusi, E., S. Md. Rahman, et al. "Modular and high-resolution channel state information and beam management for 5G NR." IEEE Comm. Mag., March 2018, pp. 48-55.
Local Functions
function prm = validateParams(prm) % Validate user specified parameters and return updated parameters % % Only cross-dependent checks are made for parameter consistency. if strcmpi(prm.FreqRange,'FR1') if prm.CenterFreq > 7.125e9 || prm.CenterFreq < 410e6 error(['Specified center frequency is outside the FR1 ', ... 'frequency range (410 MHz - 7.125 GHz).']); end if strcmpi(prm.SSBlockPattern,'Case D') || ... strcmpi(prm.SSBlockPattern,'Case E') error(['Invalid SSBlockPattern for selected FR1 frequency ' ... 'range. SSBlockPattern must be one of ''Case A'' or ' ... '''Case B'' or ''Case C'' for FR1.']); end if ~((length(prm.SSBTransmitted)==4) || ... (length(prm.SSBTransmitted)==8)) error(['SSBTransmitted must be a vector of length 4 or 8', ... 'for FR1 frequency range.']); end if (prm.CenterFreq <= 3e9) && (length(prm.SSBTransmitted)~=4) error(['SSBTransmitted must be a vector of length 4 for ' ... 'center frequency less than or equal to 3GHz.']); end if (prm.CenterFreq > 3e9) && (length(prm.SSBTransmitted)~=8) error(['SSBTransmitted must be a vector of length 8 for ', ... 'center frequency greater than 3GHz and less than ', ... 'or equal to 7.125GHz.']); end else % 'FR2' if prm.CenterFreq > 52.6e9 || prm.CenterFreq < 24.25e9 error(['Specified center frequency is outside the FR2 ', ... 'frequency range (24.25 GHz - 52.6 GHz).']); end if ~(strcmpi(prm.SSBlockPattern,'Case D') || ... strcmpi(prm.SSBlockPattern,'Case E')) error(['Invalid SSBlockPattern for selected FR2 frequency ' ... 'range. SSBlockPattern must be either ''Case D'' or ' ... '''Case E'' for FR2.']); end if length(prm.SSBTransmitted)~=64 error(['SSBTransmitted must be a vector of length 64 for ', ... 'FR2 frequency range.']); end end prm.NumTx = prod(prm.TxArraySize); prm.NumRx = prod(prm.RxArraySize); if prm.NumTx==1 || prm.NumRx==1 error(['Number of transmit or receive antenna elements must be', ... ' greater than 1.']); end prm.IsTxURA = (prm.TxArraySize(1)>1) && (prm.TxArraySize(2)>1); prm.IsRxURA = (prm.RxArraySize(1)>1) && (prm.RxArraySize(2)>1); if ~( strcmpi(prm.RSRPMode,'SSSonly') || ... strcmpi(prm.RSRPMode,'SSSwDMRS') ) error(['Invalid RSRP measuring mode. Specify either ', ... '''SSSonly'' or ''SSSwDMRS'' as the mode.']); end % Select SCS based on SSBlockPattern switch lower(prm.SSBlockPattern) case 'case a' scs = 15; cbw = 10; scsCommon = 15; case {'case b', 'case c'} scs = 30; cbw = 25; scsCommon = 30; case 'case d' scs = 120; cbw = 100; scsCommon = 120; case 'case e' scs = 240; cbw = 200; scsCommon = 120; end prm.SCS = scs; prm.ChannelBandwidth = cbw; prm.SubcarrierSpacingCommon = scsCommon; end function ssbStartSymbols = ssBurstStartSymbols(ssbBlockPattern,Lmax) % Starting OFDM symbols of SS burst. % 'alln' gives the overall set of SS block indices 'n' described in % TS 38.213 Section 4.1, from which a subset is used for each Case A-E alln = [0; 1; 2; 3; 5; 6; 7; 8; 10; 11; 12; 13; 15; 16; 17; 18]; cases = {'Case A' 'Case B' 'Case C' 'Case D' 'Case E'}; m = [14 28 14 28 56]; i = {[2 8] [4 8 16 20] [2 8] [4 8 16 20] [8 12 16 20 32 36 40 44]}; nn = [2 1 2 16 8]; caseIdx = find(strcmpi(ssbBlockPattern,cases)); if (any(caseIdx==[1 2 3])) if (Lmax==4) nn = nn(caseIdx); elseif (Lmax==8) nn = nn(caseIdx) * 2; end else nn = nn(caseIdx); end n = alln(1:nn); ssbStartSymbols = (i{caseIdx} + m(caseIdx)*n).'; ssbStartSymbols = ssbStartSymbols(:).'; end function cfgDL = configureWaveformGenerator(prm,txBurst) % Configure an nrDLCarrierConfig object to be used by nrWaveformGenerator % to generate the SS burst waveform. cfgDL = nrDLCarrierConfig; cfgDL.SCSCarriers{1}.SubcarrierSpacing = prm.SCS; if (prm.SCS==240) cfgDL.SCSCarriers = [cfgDL.SCSCarriers cfgDL.SCSCarriers]; cfgDL.SCSCarriers{2}.SubcarrierSpacing = prm.SubcarrierSpacingCommon; cfgDL.BandwidthParts{1}.SubcarrierSpacing = prm.SubcarrierSpacingCommon; else cfgDL.BandwidthParts{1}.SubcarrierSpacing = prm.SCS; end cfgDL.PDSCH{1}.Enable = false; cfgDL.PDCCH{1}.Enable = false; cfgDL.ChannelBandwidth = prm.ChannelBandwidth; cfgDL.FrequencyRange = prm.FreqRange; cfgDL.NCellID = prm.NCellID; cfgDL.NumSubframes = 5; cfgDL.WindowingPercent = 0; cfgDL.SSBurst = txBurst; end