Слияние кода завершено, страница обновится автоматически
%% Clean up
clear all;
clc;
%% Init
if ~isdeployed
addpath('./codes');
end
% Constellation size
M = 4;
% LDPC config
blkSize = 256;
codeRate = '5/6';
% Get LDPC struct
LDPC = ldpcGet(blkSize, codeRate);
% Simulation parameters
ebno = 8;
numIter = 1e2;
numErr = 0;
% Convert E_b/N_0 to some SNR
snr = ebno + 10*log10(log2(M)) + 10*log10(str2num(codeRate));
%% Simulate
for i = 1:numIter
% Generate random data
data = randi([0 1], 1, LDPC.numInfBits);
% Encode
dataEnc = ldpcEncode(data, LDPC);
% QAM mapping
dataMod = qammod(dataEnc(:), M, 'InputType', 'bit', 'UnitAveragePower', true);
% AWGN
dataRx = awgn(dataMod, snr);
% LLR demapping
dataLlr = qamdemod(dataRx, M, 'OutputType', 'llr', 'UnitAveragePower', true);
% Decode
dataHat = ldpcDecode(dataLlr', LDPC);
% Count number of bit errors
numErr = numErr + sum(abs(dataHat - data));
end
%% BER
ber = numErr / (numIter * LDPC.numInfBits)
Вы можете оставить комментарий после Вход в систему
Неприемлемый контент может быть отображен здесь и не будет показан на странице. Вы можете проверить и изменить его с помощью соответствующей функции редактирования.
Если вы подтверждаете, что содержание не содержит непристойной лексики/перенаправления на рекламу/насилия/вульгарной порнографии/нарушений/пиратства/ложного/незначительного или незаконного контента, связанного с национальными законами и предписаниями, вы можете нажать «Отправить» для подачи апелляции, и мы обработаем ее как можно скорее.
Опубликовать ( 0 )