exponenta event banner

Образцы потокового турбо-кодирования

В этом примере показано, как использовать блок LTE Turbo Encoder для кодирования данных и как сравнивать аппаратную конструкцию с результатами LTE Toolbox™. Рабочий процесс выполняется следующим образом:

  1. Создание кадров случайных входных выборок в MATLAB ®.

  2. Кодирование данных с помощью функции LTE Toolbox lteTurboEncode.

  3. Преобразование входных данных с кадрами в поток образцов и импорт потока в Simulink ®.

  4. Для кодирования выборок с использованием аппаратной архитектуры запустите модель Simulink, которая содержит беспроводной HDL Toolbox™ блок LTE Turbo Encoder.

  5. Экспорт потока закодированных выборок в рабочую область MATLAB.

  6. Преобразуйте поток образцов обратно в данные с кадрами и сравните кадры с опорными данными.

Создание входных кадров данных. Создание эталонных кодированных данных с помощью lteTurboEncode.

rng(0);
turboframesize = 40;
numframes = 2;

txBits    = cell(1,numframes);
codedData = cell(1,numframes);

for ii = 1:numframes
    txBits{ii} = logical(randi([0 1],turboframesize,1));
    codedData{ii} = lteTurboEncode(txBits{ii});
end

Сериализация входных данных для модели Simulink. Оставьте достаточно времени между кадрами для полного кодирования каждого кадра до начала следующего. Блок турбокодера LTE принимает inframesize + 16 циклов для завершения кодирования кадра.

inframes = txBits;

inframesize = size(inframes{1},1);

idlecyclesbetweensamples = 0;
idlecyclesbetweenframes = inframesize+16;

[sampleIn,ctrlIn] = ...
    whdlFramesToSamples(inframes, ...
                          idlecyclesbetweensamples, ...
                          idlecyclesbetweenframes);

Запустите модель Simulink. Время моделирования равно количеству входных выборок. Из-за добавленных циклов простоя между кадрами потоковые входные данные включают в себя достаточное количество циклов для модели, чтобы завершить кодирование обоих кадров.

sampletime = 1;
samplesizeIn = 1;
simTime = size(ctrlIn,1);
modelname = 'ltehdlTurboEncoderModel';
open_system(modelname);
sim(modelname);

Экспорт модели Simulink sampleOut_ts и ctrlOut_ts обратно в рабочую область MATLAB. Десериализируйте выходные выборки и сравните кадрированные данные с кадрами, кодированными по ссылке.

Выходные выборки блока турбокодера LTE перемежаются с битами четности.

Аппаратный выход: S_1 P1_1 P2_1 S2 P1_2 P2_2 ... Sn P1_n P2_n

Выходные данные панели инструментов LTE: S_1 S_2 ... S_n P1_1 P1_2 ... P1_n P2_1 P2_2 ... P2_n

Переупорядочить выборки с помощью опции чередования whdlSamplesToFrames функция. Сравните переупорядоченные выходные кадры с кодированными опорными кадрами.

sampleOut = sampleOut';
interleaveSamples = true;
outframes = whdlSamplesToFrames(sampleOut(:),ctrlOut,[],interleaveSamples);

fprintf('\nLTE Turbo Encoder\n');
for ii = 1:numframes
    numBitsDiff = sum(outframes{ii} ~= codedData{ii});
    fprintf(['  Frame %d: Behavioral and ' ...
        'HDL simulation differ by %d bits\n'],ii,numBitsDiff);
end
Maximum frame size computed to be 132 samples.

LTE Turbo Encoder
  Frame 1: Behavioral and HDL simulation differ by 0 bits
  Frame 2: Behavioral and HDL simulation differ by 0 bits

См. также

Блоки

Функции

Связанные темы