Этот пример демонстрирует передачу и прием многокодового слова в восходящей линии связи.
В этом примере показано, как реализовать многокодовую передачу и прием с использованием 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
В этом примере используется эта вспомогательная функция.
3GPP TS 36.104 «Радиопередача и прием базовой станции (BS)»