exponenta event banner

Версия 10 Моделирование передачи и приема нескольких кодовых слов PUSCH

Этот пример демонстрирует передачу и прием многокодового слова в восходящей линии связи.

Введение

В этом примере показано, как реализовать многокодовую передачу и прием с использованием LTE Toolbox™. Это выполняется с использованием фиксированного опорного канала (FRC) A3-2 как указано в TS36.104, Приложение A3 [1]. Затем конфигурация изменяется для передачи двух идентично сконфигурированных кодовых слов.

Установка

В этом разделе задается структура конфигурации пользовательского оборудования (UE), связанная с FRC A3-2, и изменяется для использования 2 кодовых слов. Конфигурация для двух кодовых слов идентична.

% Generate configuration for FRC A3-2
frc = lteRMCUL('A3-2');

% UE configuration
frc.TotSubframes = 1;   % Total number of subframes
frc.NTxAnts = 2;        % Number of transmit antennas

% Update Physical Uplink Shared Channel (PUSCH) configuration for 2
% identically configured codewords
frc.PUSCH.NLayers = 2;
frc.PUSCH.Modulation = repmat({frc.PUSCH.Modulation},1,2);
frc.PUSCH.RV = repmat(frc.PUSCH.RV,1,2);
frc.PUSCH.TrBlkSizes = repmat(frc.PUSCH.TrBlkSizes,2,1);

Кодировка

В этом разделе устанавливаются транспортные блоки и управляющая информация восходящей линии связи (UCI). Затем это кодируется для генерации общего канала восходящей линии связи (UL-SCH). На диаграмме ниже показаны операции, выполняемые внутри lteULSCH.

Модуляция PUSCH применяется к сгенерированным кодовым словам.

% Set up the transport block sizes and data for both codewords
TBSs = frc.PUSCH.TrBlkSizes(:,frc.NSubframe+1); % transport block sizes
trBlks = {(randi([0 1], TBSs(1), 1)) (randi([0 1], TBSs(2), 1))}; % data

% Set up UCI contents
CQI = [1 0 1 0 0 0 1 1 1 0 0 0 1 1].';
RI  = [0 1 1 0].';
ACK = [1 0].';

% UL-SCH coding including UCI coding
cws = lteULSCH(frc,frc.PUSCH,trBlks,CQI,RI,ACK);

% PUSCH modulation
puschSymbols = ltePUSCH(frc,frc.PUSCH,cws);

Расшифровка

Этот раздел демодулирует PUSCH и применяет канальное декодирование. Результирующий UCI затем декодируется для получения принятого индикатора качества канала (CQI), индикации ранга (RI) и подтверждения (ACK).

% PUSCH demodulation
ulschInfo = lteULSCHInfo(frc,frc.PUSCH,TBSs,length(CQI),length(RI),...
            length(ACK),'chsconcat');    % Get UL-SCH information
llrs = ltePUSCHDecode(frc,ulschInfo,puschSymbols); % Decode PUSCH

% UL-SCH decoding
softBuffer = [];
[rxtrblks,crc,softBuffer] = lteULSCHDecode(frc,ulschInfo,TBSs,llrs,...
                            softBuffer);

% UCI decoding
[llrsData,llrsCQI,llrsRI,llrsACK] = lteULSCHDeinterleave(frc,ulschInfo,...
                                    llrs);
rxCQI = lteCQIDecode(ulschInfo,llrsCQI);    % Decode CQI
rxRI = lteRIDecode(ulschInfo,llrsRI);       % Decode RI
rxACK = lteACKDecode(ulschInfo,llrsACK);    % Decode ACK

Результаты

Декодированный CRC для обоих кодовых слов отображается. Также показаны переданные и принятые биты CQI, RI и ACK.

hULMulticodewordTxRxDisplayResults(crc,CQI,RI,ACK,rxCQI,rxRI,rxACK);
CRCs:
Codeword 1: 0
Codeword 2: 0

CQI:
transmitted: 1  0  1  0  0  0  1  1  1  0  0  0  1  1
received   : 1  0  1  0  0  0  1  1  1  0  0  0  1  1

RI:
transmitted: 0  1  1  0
received   : 0  1  1  0

ACK:
transmitted: 1  0
received   : 1  0

Приложение

В этом примере используется эта вспомогательная функция.

Избранная библиография

  1. 3GPP TS 36.104 «Радиопередача и прием базовой станции (BS)»