В этом примере показано, как симулировать Энкодер NR LDPC и блоки Декодера Энкодера NR LDPC. В этом примере оптимизированные оборудованием результаты этих блоков по сравнению с соответствующими функциями в 5G Toolbox™.
Выберите серию входных значений для bgn и liftingSize. Эти значения должны поддерживаться 5G стандарт NR. Сгенерируйте соответствующие входные векторы bgn и liftingSize значений в зависимости от времени. Сгенерируйте случайные системы координат входных данных и преобразуйте их в булевы векторы и управляющие сигналы, которые указывают на контуры системы координат. Модель в качестве примера импортирует переменные encSampleIn
рабочей области,
encStartIn
, encEndIn
, encValidIn
, encbgnIn
, encliftingSizeIn
'SampleTime'
, и simTime
.
encFrameGap
размещает задержку блока NR LDPC Encoder для bgn и liftingSize значений. Используйте сигнал nextFrame определить, когда блок будет готов принять запуск следующего входного кадра.
bgn = [0; 1; 1; 0]; liftingSize = [4; 384; 144; 208]; numFrames = 4; encbgnIn = [];encliftingSizeIn = []; msg = {numFrames}; K =[];N = []; encSampleIn = [];encStartIn = [];encEndIn = [];encValidIn = []; encFrameGap = 2500; for ii = 1:numFrames if bgn(ii) == 0 K(ii) = 22; N(ii) = 66; else K(ii) = 10; N(ii) = 50; end frameLen = liftingSize(ii) * K(ii); msg{ii} = randi([0 1],1,frameLen); len = K(ii) * ceil(liftingSize(ii)/64); encIn = ldpc_dataFormation(msg{ii},liftingSize(ii),K(ii)); encSampleIn = logical([encSampleIn encIn zeros(64,encFrameGap)]); %#ok<*AGROW> encStartIn = logical([encStartIn 1 zeros(1,len-1) zeros(1,encFrameGap)]); encEndIn = logical([encEndIn zeros(1,len-1) 1 zeros(1,encFrameGap)]); encValidIn = logical([encValidIn ones(1,len) zeros(1,encFrameGap)]); encbgnIn = logical([encbgnIn repmat(bgn(ii),1,len) zeros(1,encFrameGap)]); encliftingSizeIn = uint16([encliftingSizeIn repmat(liftingSize(ii),1,len) zeros(1,encFrameGap)]); end encSampleIn = timeseries(logical(encSampleIn')); sampleTime = 1; simTime = length(encValidIn); %#ok<NASGU>
Подсистема Алгоритма HDL содержит блок NR LDPC Encoder. Выполнение модели импортирует переменные входного сигнала из рабочей области и возвращается, LDPC закодировал выходные векторы наряду с управляющими сигналами, которые указывают на контуры системы координат. Модель экспортирует sampleOut
и ctrlOut
к рабочему пространству MATLAB.
open_system('NRLDPCEncoderHDL'); encOut = sim('NRLDPCEncoderHDL');
Преобразуйте данные о потоковой передаче назад в системы координат для сравнения с результатами nrLDPCEncode
функция от 5G Toolbox™.
startIdx = find(encOut.ctrlOut.start.Data); endIdx = find(encOut.ctrlOut.end.Data); for ii = 1:numFrames encHDL{ii} = ldpc_dataExtraction(encOut.sampleOut.Data,liftingSize(ii),startIdx(ii),endIdx(ii),N(ii)); %#ok<*SAGROW> encRef = nrLDPCEncode(msg{ii}',bgn(ii)+1); error = sum(abs(encRef - encHDL{ii})); fprintf(['Encoded Frame %d: Behavioral and ' ... 'HDL simulation differ by %d bits\n'],ii,error); end
Encoded Frame 1: Behavioral and HDL simulation differ by 0 bits Encoded Frame 2: Behavioral and HDL simulation differ by 0 bits Encoded Frame 3: Behavioral and HDL simulation differ by 0 bits Encoded Frame 4: Behavioral and HDL simulation differ by 0 bits
Используйте закодированные данные, чтобы сгенерировать входные отношения логарифмической правдоподобности (LLR) для блока NR LDPC Decoder. Используйте канал, модулятор, и демодулятор возражает, чтобы добавить некоторый шум в сигнал.
Снова, создайте векторы bgn и liftingSize и преобразуйте системы координат данных к векторам входа LLR с управляющими сигналами. Модель в качестве примера импортирует переменные decSampleIn
рабочей области,
decStartIn
, decEndIn
, decValidIn
, decbgnIn
, decliftingSizeIn
, numIter
'SampleTime'
, и simTime
.
decFrameGap
размещает задержку блока NR LDPC Decoder для bgn, liftingSize, и количество итераций. Используйте сигнал nextFrame определить, когда блок будет готов принять запуск следующего входного кадра.
nVar = 2.5; chan = comm.AWGNChannel('NoiseMethod','Variance','Variance',nVar); bpskMod = comm.BPSKModulator; bpskDemod = comm.BPSKDemodulator('DecisionMethod', ... 'Approximate log-likelihood ratio','Variance',nVar); numIter = 8; decFrameGap = numIter *1200; decbgnIn = [];decliftingSizeIn = []; rxLLR = {numFrames}; decSampleIn = [];decStartIn = [];decEndIn = [];decValidIn = []; for ii=1:numFrames mod = bpskMod(double(encHDL{ii})); rSig = chan(mod); rxLLR{ii} = fi(bpskDemod(rSig),1,6,0); len = N(ii)* ceil(liftingSize(ii)/64); decIn = ldpc_dataFormation(rxLLR{ii}',liftingSize(ii),N(ii)); decSampleIn = [decSampleIn decIn zeros(64,decFrameGap)]; %#ok<*AGROW> decStartIn = logical([decStartIn 1 zeros(1,len-1) zeros(1,decFrameGap)]); decEndIn = logical([decEndIn zeros(1,len-1) 1 zeros(1,decFrameGap)]); decValidIn = logical([decValidIn ones(1,len) zeros(1,decFrameGap)]); decbgnIn = logical([decbgnIn repmat(bgn(ii),1,len) zeros(1,decFrameGap)]); decliftingSizeIn = uint16([decliftingSizeIn repmat(liftingSize(ii),1,len) zeros(1,decFrameGap)]); end decSampleIn = timeseries(fi(decSampleIn',1,6,0)); simTime = length(decValidIn);
Подсистема Алгоритма HDL содержит блок NR LDPC Decoder. Выполнение модели импортирует переменные входного сигнала из рабочей области и возвращает поток декодируемых выходных выборок наряду с управляющими сигналами, которые указывают на контуры системы координат. Модель экспортирует sampleOut
и ctrlOut
к рабочему пространству MATLAB.
open_system('NRLDPCDecoderHDL'); decOut = sim('NRLDPCDecoderHDL');
Преобразуйте данные о потоковой передаче, возвращенные в модель Simulink в системы координат для сравнения с результатами nrLDPCDecode
функция от 5G Toolbox™.
startIdx = find(decOut.ctrlOut.start.Data); endIdx = find(decOut.ctrlOut.end.Data); for ii = 1:numFrames decHDL{ii} = ldpc_dataExtraction(decOut.sampleOut.Data,liftingSize(ii),startIdx(ii),endIdx(ii),K(ii)); %#ok<*SAGROW> decRef = nrLDPCDecode(double(rxLLR{ii}),bgn(ii)+1,numIter, 'Algorithm','Normalized min-sum','ScalingFactor',1.0,... 'Termination','max'); error = sum(abs(double(decRef) - decHDL{ii})); fprintf(['Decoded Frame %d: Behavioral and ' ... 'HDL simulation differ by %d bits\n'],ii,error); end
Decoded Frame 1: Behavioral and HDL simulation differ by 0 bits Decoded Frame 2: Behavioral and HDL simulation differ by 0 bits Decoded Frame 3: Behavioral and HDL simulation differ by 0 bits Decoded Frame 4: Behavioral and HDL simulation differ by 0 bits