Процедура восстановления для пакета 802.11ax

Этот пример показывает, как обнаружить пакет и декодировать биты полезной нагрузки в принятой форме волны 802.11ax™ IEEE ®. Приемник восстанавливает параметры формата пакета из полей преамбулы, чтобы декодировать поле данных и системы координат MAC.

Введение

В пакете 802.11ax параметры передачи передаются в приемник с помощью полей преамбулы L-SIG, HE-SIG-A и HE-SIG-B [1]:

  • Поле L-SIG содержит информацию, позволяющую приемнику определять время передачи пакета.

  • Поле HE-SIG-A содержит общие параметры передачи для пользователей HE-MU и все параметры передачи для пакетов HE-SU и HE-EXT-SU.

  • Комбинация информации о длине в поле L-SIG, типа модуляции и количества символов OFDM в поле HE-SIG-A определяет формат пакета HE.

  • Поле HE-SIG-B содержит информацию выделения ресурсного модуля (RU) и параметры передачи для пользователей в пакете HE-MU.

В этом примере мы обнаруживаем и декодируем пакет HE-MU в сгенерированной форме волны. Этот пример может также восстановить пакеты HE-SU и HE-EXT-SU. Все параметры передачи, кроме полосы пропускания канала, приняты неизвестными и поэтому извлекаются из декодированных полей преамбулы L-SIG, HE-SIG-A и HE-SIG-B. Восстановленные параметры передачи используются для декодирования поля HE-данных. Дополнительно проводят следующий анализ:

  • Форма волны обнаруженного пакета восстанавливается и отображается.

  • Спектр обнаруженного пакета восстанавливается и отображается.

  • Отображается созвездие уравненных символов данных для всех пространственных потоков.

  • Измеряется величина вектора ошибок (EVM) каждого поля.

  • Обнаруживают A-MPDU и определяют Систему координат проверки (FCS) для восстановленного MAC- системы координат.

  • Отображается EVM на символ данных и пространственный поток, усредненный по поднесущим.

  • Отображается EVM на поднесущую данных и пространственный поток, усредненный по символам.

Передача формы волны

В этом примере синтезируется сигнал HE-MU 802.11ax, но можно использовать захваченный сигнал. Вы можете использовать MATLAB ®, чтобы получить данные I/Q от широкой области значений инструментов с помощью Toolbox™ Instrument Control и программно определенных радиоплатформ.

Синтезированная форма волны нарушается внутренним каналом с замираниями 2x2 TGax, аддитивным белым Гауссовым шумом и смещением несущей частоты. Чтобы сгенерировать сигнал HE-MU, мы конфигурируем объект строения формата HE-MU wlanHEMUConfig. Обратите внимание, что объект строения wlanHEMUConfig используется только на стороне передатчика. Приемник сформулирует объект строения восстановления HE wlanHERecoveryConfig. Неизвестные свойства объекта строения восстановления HE устанавливаются после декодирования информационных бит в полях L-SIG, HE-SIG-A и HE-SIG-B. Функция helper heSigRecGenerateWaveform генерирует ослабленную форму волны. Выполняются следующие шаги обработки:

  • Случайная полезная нагрузка MSDU создается для MAC- системы координат, который кодируется в пакет HE-MU.

  • Форма волны передается через внутреннюю модель канала с замираниями TGax.

  • Смещение несущей частоты (CFO) и аддитивный белый Гауссов шум (AWGN) добавляются к форме волны.

% A mixed OFDMA and MU-MIMO configuration is defined for an HE-MU packet.
% The allocation index 17 defines two 52-tone RUs, with one user in each
% RU, and one 106-tone RU. The 106-tone RU has two users in a MU-MIMO
% configuration.
cfgMU = wlanHEMUConfig(17);
cfgMU.NumTransmitAntennas = 2;

% Configure RU 1 and user 1
cfgMU.RU{1}.SpatialMapping = 'Direct';
cfgMU.User{1}.STAID = 1;
cfgMU.User{1}.APEPLength = 1e3;
cfgMU.User{1}.MCS = 5;
cfgMU.User{1}.NumSpaceTimeStreams = 2;
cfgMU.User{1}.ChannelCoding = 'LDPC';

% Configure RU 2 and user 2
cfgMU.RU{2}.SpatialMapping = 'Fourier';
cfgMU.User{2}.STAID = 2;
cfgMU.User{2}.APEPLength = 500;
cfgMU.User{2}.MCS = 4;
cfgMU.User{2}.NumSpaceTimeStreams = 1;
cfgMU.User{2}.ChannelCoding = 'BCC';

% Configure RU 3 and user 1
cfgMU.RU{3}.SpatialMapping = 'Fourier';
cfgMU.User{3}.STAID = 3;
cfgMU.User{3}.APEPLength = 100;
cfgMU.User{3}.MCS = 2;
cfgMU.User{3}.NumSpaceTimeStreams = 1;
cfgMU.User{3}.ChannelCoding = 'BCC';

% Configure RU 3 and user 2
cfgMU.User{4}.STAID = 4;
cfgMU.User{4}.APEPLength = 500;
cfgMU.User{4}.MCS = 3;
cfgMU.User{4}.NumSpaceTimeStreams = 1;
cfgMU.User{4}.ChannelCoding = 'LDPC';

% Specify propagation channel
numRx = 2; % Number of receive antennas
delayProfile = 'Model-D'; % TGax channel delay profile

% Specify impairments
noisePower = -40; % Noise power to apply in dBW
cfo = 62e3; % Carrier frequency offset Hz

% Generate waveform
rx = heSigRecGenerateWaveform(cfgMU,numRx,delayProfile,noisePower,cfo);

Восстановление пакетов

Сигнал для обработки сохранен в переменной rx. Шаги обработки для восстановления пакета:

  • Создается объект строения восстановления HE, wlanHERecoveryConfig. Свойства объекта обновляются по мере декодирования полей преамбулы.

  • Пакет обнаруживается и синхронизируется.

  • L-LTF экстрагируют и демодулируют. Демодулированные символы L-LTF не включают вращение тонального сигнала для каждого сегмента 20 МГц, как описано в разделе 21.3.7.5 [2].

  • Демодулированные символы L-LTF используются для оценок канала и шума.

  • Сигнал временной области, содержащий выборки, эквивалентные четырем символам OFDM, непосредственно следующим за L-LTF, используются для определения формата пакета HE. Формат пакета обновляется в объекте wlanHERecoveryConfig.

  • L-LTF демодулируется. Демодулированные символы L-LTF включают вращение тонального сигнала для каждого сегмента 20 МГц, как описано в разделе 21.3.7.5 [2]. Оценки канала L-LTF (с вращением тонального сигнала) используются для декодирования pre-HE-LTF.

  • Поля L-SIG и RL-SIG извлекаются. Канал оценивается по дополнительным четырем поднесущим на подканал в полях L-SIG и RL-SIG. Оценки канала L-LTF обновляются, чтобы включать в себя оценки канала на дополнительных поднесущих.

  • Информационные биты в поле L-SIG восстанавливаются, чтобы определить длину пакета в микросекундах.

  • После декодирования HE-SIG-A объект строения восстановления обновляется общими параметрами передачи для пакета HE-MU и всеми параметрами передачи для пакетов HE-SU и HE-EXT-SU.

  • Для формата пакета HE-MU декодируется поле HE-SIG-B. Для несжатого сигнала SIGB общее поле HE-SIG-B декодируется сначала, далее следует пользовательское поле HE-SIG-B. Для сжатого сигнала SIGB декодируется только пользовательское поле HE-SIG-B.

  • Для формата HE-MU без сжатия SIGB параметры выделения RU и передачи пользователем восстанавливаются из поля HE-SIG-B. Для сжатого сигнала SIGB информация о выделении RU выводится из поля HE-SIG-A, и параметры пользовательской передачи определяются из бит пользовательского поля HE-SIG-B.

  • Объект wlanHERecoveryConfig создается с использованием восстановленных параметров передачи для каждого пользователя после декодирования HE-SIG-B.

  • Поле HE-LTF извлекается и демодулируется. Демодулированные символы используются для оценки канала поднесущих, выделенных пользователю, представляющему интерес. Оценки канала MIMO используются для декодирования поля HE-данных.

  • Поле HE-Data извлекается, и биты PSDU восстанавливаются с помощью объекта wlanHERecoveryConfig для каждого пользователя.

  • Обнаружение A-MPDU в восстановленном PSDU и проверка FCS на наличие восстановленного MAC- системы координат.

Setup параметров восстановления формы волны

В этом примере все параметры передачи, кроме полосы пропускания канала, приняты неизвестными и будут восстановлены. Объект строения восстановления wlanHERecoveryConfig создается для хранения восстановленной информации в полях преамбулы L-SIG, HE-SIG-A и HE-SIG-B. Свойства передачи в wlanHERecoveryConfig обновляются после последующего декодирования полей преамбулы. Следующий код конфигурирует объекты и переменные для обработки.

chanBW = cfgMU.ChannelBandwidth; % Assume channel bandwidth is known
sr = wlanSampleRate(cfgMU); % Sample rate

% Specify pilot tracking method for recovering the data field. This can be:
%  'Joint' - use joint common phase error and sample rate offset tracking
%  'CPE' - use only common phase error tracking
% When recovering 26-tone RUs only CPE tracking is used as the joint
% tracking algorithm is susceptible to noise.
pilotTracking = 'Joint';

% Create an HE recovery configuration object and set the channel bandwidth
cfgRx = wlanHERecoveryConfig;
cfgRx.ChannelBandwidth = chanBW;

% The recovery configuration object is used to get the start and end
% indices of the pre-HE-SIG-B field.
ind = wlanFieldIndices(cfgRx);

% Setup plots for the example
[spectrumAnalyzer,timeScope,ConstellationDiagram,EVMPerSubcarrier,EVMPerSymbol] = heSigRecSetupPlots(sr);

% Minimum packet length is 10 OFDM symbols
lstfLength = double(ind.LSTF(2));
minPktLen = lstfLength*5; % Number of samples in L-STF

rxWaveLen = size(rx,1);

Фронтэнд-обработка

Обработка на переднем конце состоит из обнаружения пакетов, грубой коррекции смещения частоты несущей, временной синхронизации и точной коррекции смещения частоты несущей. A while цикл используется для обнаружения и синхронизации пакета в пределах принятой формы волны. Смещение выборки searchOffset используется для индекса в rx для обнаружения пакета. Первый пакет в rx обнаруживается и обрабатывается. Если синхронизация не удаётся для обнаруженного пакета, смещение индекса выборки searchOffset увеличивается, чтобы выйти за пределы обработанного пакета в rx. Это повторяется до тех пор, пока пакет не будет успешно обнаружен и синхронизирован.

searchOffset = 0; % Offset from start of waveform in samples
while (searchOffset + minPktLen) <= rxWaveLen
    % Packet detection
    pktOffset = wlanPacketDetect(rx,chanBW,searchOffset);

    % Adjust packet offset
    pktOffset = searchOffset + pktOffset;
    if isempty(pktOffset) || (pktOffset + ind.LSIG(2) > rxWaveLen)
        error('** No packet detected **');
    end

    % Coarse frequency offset estimation and correction using L-STF
    rxLSTF = rx(pktOffset+(ind.LSTF(1):ind.LSTF(2)), :);
    coarseFreqOffset = wlanCoarseCFOEstimate(rxLSTF,chanBW);
    rx = helperFrequencyOffset(rx,sr,-coarseFreqOffset);

    % Symbol timing synchronization
    searchBufferLLTF = rx(pktOffset+(ind.LSTF(1):ind.LSIG(2)),:);
    pktOffset = pktOffset+wlanSymbolTimingEstimate(searchBufferLLTF,chanBW);

    % Fine frequency offset estimation and correction using L-STF
    rxLLTF = rx(pktOffset+(ind.LLTF(1):ind.LLTF(2)),:);
    fineFreqOffset = wlanFineCFOEstimate(rxLLTF,chanBW);
    rx = helperFrequencyOffset(rx,sr,-fineFreqOffset);

    % Timing synchronization complete: packet detected
    fprintf('Packet detected at index %d\n',pktOffset + 1);

    % Display estimated carrier frequency offset
    cfoCorrection = coarseFreqOffset + fineFreqOffset; % Total CFO
    fprintf('Estimated CFO: %5.1f Hz\n\n',cfoCorrection);

    break; % Front-end processing complete, stop searching for a packet
end

% Scale the waveform based on L-STF power (AGC)
gain = 1./(sqrt(mean(rxLSTF.*conj(rxLSTF))));
rx = rx.*gain;
Packet detected at index 404
Estimated CFO: 61942.9 Hz

Обнаружение формата пакета

Выборки во временной области, эквивалентные четырем символам OFDM, непосредственно следующим за L-LTF, используются для определения формата пакета HE [1 фигура. 27-63]. L-LTF экстрагируют и демодулируют. Для обнаружения формата демодулированные символы L-LTF не должны включать вращение тонального сигнала для каждого сегмента 20 МГц, как описано в разделе 21.3.7.5 [2]. Демодулированный L-LTF используется для оценки канала и шума. Канал L-LTF (без вращения тонального сигнала) и оценки степени шума используются для обнаружения формата пакета.

rxLLTF = rx(pktOffset+(ind.LLTF(1):ind.LLTF(2)),:);
lltfDemod = wlanLLTFDemodulate(rxLLTF,chanBW);
lltfChanEst = wlanLLTFChannelEstimate(lltfDemod,chanBW);
noiseVar = helperNoiseEstimate(lltfDemod);

disp('Detect packet format...');
rxSIGA = rx(pktOffset+(ind.LSIG(1):ind.HESIGA(2)),:);
pktFormat = wlanFormatDetect(rxSIGA,lltfChanEst,noiseVar,chanBW);
fprintf('  %s packet detected\n\n',pktFormat);

% Set the packet format in the recovery object and update the field indices
cfgRx.PacketFormat = pktFormat;
ind = wlanFieldIndices(cfgRx);
Detect packet format...
  HE-MU packet detected

Оценка канала L-LTF

Демодулируйте L-LTF и выполните оценку канала. Демодулированные символы L-LTF включают вращение тонального сигнала для каждого сегмента 20 МГц, как описано в разделе 21.3.7.5 [2]. Оценки канала L-LTF (с вращением тонального сигнала) используются для выравнивания и декодирования полей pre-HE-LTF.

lltfDemod = wlanHEDemodulate(rxLLTF,'L-LTF',chanBW);
lltfChanEst = wlanLLTFChannelEstimate(lltfDemod,chanBW);

Декодирование L-SIG и RL-SIG

Поле L-SIG используется для определения времени приема или RXTIME пакета. RXTIME вычисляется с использованием бит длины полезной нагрузки L-SIG. Поля L-SIG и RL-SIG восстанавливаются для выполнения оценки канала на дополнительных поднесущих в полях L-SIG и RL-SIG. The lltfChanEst оценки канала обновляются, чтобы включить оценки канала на дополнительных поднесущих в поля L-SIG и RL-SIG. Полезная нагрузка L-SIG декодируется с использованием оценки канала и степеней шума, полученных из поля L-LTF. Свойство length L-SIG в wlanHERecoveryConfig обновляется после декодирования L-SIG.

disp('Decoding L-SIG... ');
% Extract L-SIG and RL-SIG fields
rxLSIG = rx(pktOffset+(ind.LSIG(1):ind.RLSIG(2)),:);

% OFDM demodulate
helsigDemod = wlanHEDemodulate(rxLSIG,'L-SIG',chanBW);

% Estimate CPE and phase correct symbols
helsigDemod = preHECommonPhaseErrorTracking(helsigDemod,lltfChanEst,'L-SIG',chanBW);

% Estimate channel on extra 4 subcarriers per subchannel and create full
% channel estimate
preheInfo = wlanHEOFDMInfo('L-SIG',chanBW);
preHEChanEst = preHEChannelEstimate(helsigDemod,lltfChanEst,preheInfo.NumSubchannels);

% Average L-SIG and RL-SIG before equalization
helsigDemod = mean(helsigDemod,2);

% Equalize data carrying subcarriers, merging 20 MHz subchannels
[eqLSIGSym,csi] = preHESymbolEqualize(helsigDemod(preheInfo.DataIndices,:,:), ...
    preHEChanEst(preheInfo.DataIndices,:,:),noiseVar,preheInfo.NumSubchannels);

% Decode L-SIG field
[~,failCheck,lsigInfo] = wlanLSIGBitRecover(eqLSIGSym,noiseVar,csi);

if failCheck
    disp(' ** L-SIG check fail **');
else
    disp(' L-SIG check pass');
end
% Get the length information from the recovered L-SIG bits and update the
% L-SIG length property of the recovery configuration object
lsigLength = lsigInfo.Length;
cfgRx.LSIGLength = lsigLength;

% Measure EVM of L-SIG symbols
EVM = comm.EVM;
EVM.ReferenceSignalSource = 'Estimated from reference constellation';
EVM.Normalization = 'Average constellation power';
EVM.ReferenceConstellation = wlanReferenceSymbols('BPSK');
rmsEVM = EVM(eqLSIGSym);
fprintf(' L-SIG EVM: %2.2fdB\n\n',20*log10(rmsEVM/100));

% Calculate the receive time and corresponding number of samples in the
% packet
RXTime = ceil((lsigLength + 3)/3) * 4 + 20; % In microseconds
numRxSamples = round(RXTime * 1e-6 * sr);   % Number of samples in time

fprintf(' RXTIME: %dus\n',RXTime);
fprintf(' Number of samples in the packet: %d\n\n',numRxSamples);
Decoding L-SIG... 
 L-SIG check pass
 L-SIG EVM: -36.91dB

 RXTIME: 536us
 Number of samples in the packet: 10720

Форма волны и спектр обнаруженного пакета в rx отображается с учетом вычисленного RXTIME и соответствующего количества выборок.

sampleOffset = max((-lstfLength + pktOffset),1); % First index to plot
sampleSpan = numRxSamples + 2*lstfLength; % Number samples to plot
% Plot as much of the packet (and extra samples) as we can
plotIdx = sampleOffset:min(sampleOffset + sampleSpan,rxWaveLen);

% Configure timeScope to display the packet
timeScope.TimeSpan = sampleSpan/sr;
timeScope.TimeDisplayOffset = sampleOffset/sr;
timeScope.YLimits = [0 max(abs(rx(:)))];
timeScope(abs(rx(plotIdx,:)));
release(timeScope);

% Display the spectrum of the detected packet
spectrumAnalyzer(rx(pktOffset + (1:numRxSamples),:));
release(spectrumAnalyzer);

Декодирование HE-SIG-A

Поле HE-SIG-A содержит строение передачи пакета HE. Оценка канала и степени, полученной из L-LTF, требуется для декодирования поля HE-SIG-A.

disp('Decoding HE-SIG-A...')
rxSIGA = rx(pktOffset+(ind.HESIGA(1):ind.HESIGA(2)),:);
sigaDemod = wlanHEDemodulate(rxSIGA,'HE-SIG-A',chanBW);
hesigaDemod = preHECommonPhaseErrorTracking(sigaDemod,preHEChanEst,'HE-SIG-A',chanBW);

% Equalize data carrying subcarriers, merging 20 MHz subchannels
preheInfo = wlanHEOFDMInfo('HE-SIG-A',chanBW);
[eqSIGASym,csi] = preHESymbolEqualize(hesigaDemod(preheInfo.DataIndices,:,:), ...
                                      preHEChanEst(preheInfo.DataIndices,:,:), ...
                                      noiseVar,preheInfo.NumSubchannels);
% Recover HE-SIG-A bits
[sigaBits,failCRC] = wlanHESIGABitRecover(eqSIGASym,noiseVar,csi);

% Perform the CRC on HE-SIG-A bits
if failCRC
    disp(' ** HE-SIG-A CRC fail **');
else
    disp(' HE-SIG-A CRC pass');
end

% Measure EVM of HE-SIG-A symbols
release(EVM);
if strcmp(pktFormat,'HE-EXT-SU')
    % The second symbol of an HE-SIG-A field for an HE-EXT-SU packet is
    % QBPSK.
    EVM.ReferenceConstellation = wlanReferenceSymbols('BPSK',[0 pi/2 0 0]);
    % Account for scaling of L-LTF for an HE-EXT-SU packet
    rmsEVM = EVM(eqSIGASym*sqrt(2));
else
    EVM.ReferenceConstellation = wlanReferenceSymbols('BPSK');
    rmsEVM = EVM(eqSIGASym);
end
fprintf(' HE-SIG-A EVM: %2.2fdB\n\n',20*log10(mean(rmsEVM)/100));
Decoding HE-SIG-A...
 HE-SIG-A CRC pass
 HE-SIG-A EVM: -35.17dB

Интерпретируйте восстановленные биты HE-SIG-A

Объект wlanHERecoveryConfig обновляется после интерпретации восстановленных бит HE-SIG-A.

cfgRx = interpretHESIGABits(cfgRx,sigaBits);
ind = wlanFieldIndices(cfgRx); % Update field indices

Отображение общего строения передачи, полученной из поля HE-SIG-A для пакета HE-MU. Свойства, обозначенные как -1, неизвестны или неопределены. Неизвестные пользовательские свойства обновляются после успешного декодирования поля HE-SIG-B.

disp(cfgRx)
  wlanHERecoveryConfig with properties:

                    PacketFormat: 'HE-MU'
                ChannelBandwidth: 'CBW20'
                      LSIGLength: 383
                 SIGBCompression: 0
                         SIGBMCS: 0
                         SIGBDCM: 0
          NumSIGBSymbolsSignaled: 5
                            STBC: 0
                 LDPCExtraSymbol: 0
             PreFECPaddingFactor: 4
                  PEDisambiguity: 0
                   GuardInterval: 3.2000
                       HELTFType: 4
                 NumHELTFSymbols: 2
                UplinkIndication: 0
                        BSSColor: 0
                    SpatialReuse: 0
                    TXOPDuration: 127
                     HighDoppler: 0
                 AllocationIndex: -1
       NumUsersPerContentChannel: -1
         RUTotalSpaceTimeStreams: -1
                          RUSize: -1
                         RUIndex: -1
                           STAID: -1
                             MCS: -1
                             DCM: -1
                   ChannelCoding: 'Unknown'
                     Beamforming: -1
             NumSpaceTimeStreams: -1
    SpaceTimeStreamStartingIndex: -1

Декодирование HE-SIG-B

Для пакета HE-MU поле HE-SIG-B содержит:

  • Информация о выделении RU для несжатого сигнала SIGB выводится из общего поля HE-SIG-B [1 Таблица. 27-23]. Для сжатого сигнала SIGB информация выделения RU выводится из восстановленных бит HE-SIG-A.

  • Для несжатого сигнала SIGB количество символов HE-SIG-B обновляется в объекте wlanHERecoveryConfig. Символы обновляются только в том случае, если количество символов HE-SIG-B, указанных в поле HE-SIG-A, установлено на 15, и все каналы содержимого проходят CRC. Количество символов HE-SIG-B, указанных в поле HE-SIG-A, не обновляется, если какой-либо канал содержимого HE-SIG-B отказывает CRC.

  • Параметры пользовательской передачи как сжатого, так и несжатого сигнала SIGB выводятся из пользовательского поля HE-SIG-B [1 таблица. 27-25, 27-26].

Оценка канала и степени, полученной из L-LTF, требуется для декодирования поля HE-SIG-B.

if strcmp(pktFormat,'HE-MU')
    fprintf('Decoding HE-SIG-B...\n');
    if ~cfgRx.SIGBCompression
        fprintf(' Decoding HE-SIG-B common field...\n');
        s = getSIGBLength(cfgRx);
        % Get common field symbols. The start of HE-SIG-B field is known
        rxSym = rx(pktOffset+(ind.HESIGA(2)+(1:s.NumSIGBCommonFieldSamples)),:);
        % Decode HE-SIG-B common field
        [status,cfgRx] = heSIGBCommonFieldDecode(rxSym,preHEChanEst,noiseVar,cfgRx);

        % CRC on HE-SIG-B content channels
        if strcmp(status,'Success')
            fprintf('  HE-SIG-B (common field) CRC pass\n');
        elseif strcmp(status,'ContentChannel1CRCFail')
            fprintf('  ** HE-SIG-B CRC fail for content channel-1\n **');
        elseif strcmp(status,'ContentChannel2CRCFail')
            fprintf('  ** HE-SIG-B CRC fail for content channel-2\n **');
        elseif any(strcmp(status,{'UnknownNumUsersContentChannel1','UnknownNumUsersContentChannel2'}))
            error('  ** Unknown packet length, discard packet\n **');
        else
            % Discard the packet if all HE-SIG-B content channels fail
            error('  ** HE-SIG-B CRC fail **');
        end
        % Update field indices as the number of HE-SIG-B symbols are
        % updated
        ind = wlanFieldIndices(cfgRx);
    end

    % Get complete HE-SIG-B field samples
    rxSIGB = rx(pktOffset+(ind.HESIGB(1):ind.HESIGB(2)),:);
    fprintf(' Decoding HE-SIG-B user field... \n');
    % Decode HE-SIG-B user field
    [failCRC,cfgUsers] = heSIGBUserFieldDecode(rxSIGB,preHEChanEst,noiseVar,cfgRx);

    % CRC on HE-SIG-B users
    if ~all(failCRC)
        fprintf('  HE-SIG-B (user field) CRC pass\n\n');
        numUsers = numel(cfgUsers);
    elseif all(failCRC)
        % Discard the packet if all users fail the CRC
        error('  ** HE-SIG-B CRC fail for all users **');
    else
        fprintf('  ** HE-SIG-B CRC fail for at least one user\n **');
        % Only process users with valid CRC
        numUsers = numel(cfgUsers);
    end

else % HE-SU, HE-EXT-SU
    cfgUsers = {cfgRx};
    numUsers = 1;
end
Decoding HE-SIG-B...
 Decoding HE-SIG-B common field...
  HE-SIG-B (common field) CRC pass
 Decoding HE-SIG-B user field... 
  HE-SIG-B (user field) CRC pass

Декодирование HE-данных

Обновленный объект wlanHERecoveryConfig для каждого пользователя может затем использоваться для восстановления бит PSDU для каждого пользователя в поле HE-Data.

cfgDataRec = trackingRecoveryConfig;
cfgDataRec.PilotTracking = pilotTracking;

fprintf('Decoding HE-Data...\n');
for iu = 1:numUsers
    % Get recovery configuration object for each user
    user = cfgUsers{iu};
    if strcmp(pktFormat,'HE-MU')
        fprintf(' Decoding User:%d, STAID:%d, RUSize:%d\n',iu,user.STAID,user.RUSize);
    else
        fprintf(' Decoding RUSize:%d\n',user.RUSize);
    end

    heInfo = wlanHEOFDMInfo('HE-Data',chanBW,user.GuardInterval,[user.RUSize user.RUIndex]);

    % HE-LTF demodulation and channel estimation
    rxHELTF = rx(pktOffset+(ind.HELTF(1):ind.HELTF(2)),:);
    heltfDemod = wlanHEDemodulate(rxHELTF,'HE-LTF',chanBW,user.GuardInterval, ...
        user.HELTFType,[user.RUSize user.RUIndex]);
    [chanEst,pilotEst] = heLTFChannelEstimate(heltfDemod,user);

    % Number of expected data OFDM symbols
    symLen = heInfo.FFTLength+heInfo.CPLength;
    numOFDMSym = (ind.HEData(2)-ind.HEData(1)+1)/symLen;

    % HE-Data demodulation with pilot phase and timing tracking
    % Account for extra samples when extracting data field from the packet
    % for sample rate offset tracking. Extra samples may be required if the
    % receiver clock is significantly faster than the transmitter.
    maxSRO = 120; % Parts per million
    Ne = ceil(numRxSamples*maxSRO*1e-6); % Number of extra samples
    Ne = min(Ne,rxWaveLen-numRxSamples); % Limited to length of waveform
    numRxSamplesProcess = numRxSamples+Ne;
    rxData = rx(pktOffset+(ind.HEData(1):numRxSamplesProcess),:);
    if user.RUSize==26
        % Force CPE only tracking for 26-tone RU as algorithm susceptible
        % to noise
        cfgDataRec.PilotTracking = 'CPE';
    else
        cfgDataRec.PilotTracking = pilotTracking;
    end
        [demodSym,cpe,peg] = heTrackingOFDMDemodulate(rxData,chanEst,numOFDMSym,user,cfgDataRec);

    % Estimate noise power in HE fields
    demodPilotSym = demodSym(heInfo.PilotIndices,:,:);
    nVarEst = heNoiseEstimate(demodPilotSym,pilotEst,user);

    % Equalize
    [eqSym,csi] = heEqualizeCombine(demodSym,chanEst,nVarEst,user);

    % Discard pilot subcarriers
    eqSymUser = eqSym(heInfo.DataIndices,:,:);
    csiData = csi(heInfo.DataIndices,:);

    % Demap and decode bits
    rxPSDU = wlanHEDataBitRecover(eqSymUser,nVarEst,csiData,user,'LDPCDecodingMethod','layered-bp');

    % Deaggregate the A-MPDU
    [mpduList,~,status] = wlanAMPDUDeaggregate(rxPSDU,wlanHESUConfig);
    if strcmp(status,'Success')
        fprintf('  A-MPDU deaggregation successful \n');
    else
        fprintf('  A-MPDU deaggregation unsuccessful \n');
    end

    % Decode the list of MPDUs and check the FCS for each MPDU
    for i = 1:numel(mpduList)
        [~,~,status] = wlanMPDUDecode(mpduList{i},wlanHESUConfig,'DataFormat','octets');
        if strcmp(status,'Success')
            fprintf('  FCS pass for MPDU:%d\n',i);
        else
            fprintf('  FCS fail for MPDU:%d\n',i);
        end
    end

    % Plot equalized constellation of the recovered HE data symbols for all
    % spatial streams per user
    hePlotEQConstellation(eqSymUser,user,ConstellationDiagram,iu,numUsers);

    % Measure EVM of HE-Data symbols
    release(EVM);
    EVM.ReferenceConstellation = wlanReferenceSymbols(user);
    rmsEVM = EVM(eqSymUser(:));
    fprintf('  HE-Data EVM:%2.2fdB\n\n',20*log10(rmsEVM/100));

    % Plot EVM per symbol of the recovered HE data symbols
    hePlotEVMPerSymbol(eqSymUser,user,EVMPerSymbol,iu,numUsers);

    % Plot EVM per subcarrier of the recovered HE data symbols
    hePlotEVMPerSubcarrier(eqSymUser,user,EVMPerSubcarrier,iu,numUsers);
end
Decoding HE-Data...
 Decoding User:1, STAID:1, RUSize:52
  A-MPDU deaggregation successful 
  FCS pass for MPDU:1
  HE-Data EVM:-28.61dB

 Decoding User:2, STAID:2, RUSize:52
  A-MPDU deaggregation successful 
  FCS pass for MPDU:1
  HE-Data EVM:-39.94dB

 Decoding User:3, STAID:3, RUSize:106
  A-MPDU deaggregation successful 
  FCS pass for MPDU:1
  HE-Data EVM:-28.22dB

 Decoding User:4, STAID:4, RUSize:106
  A-MPDU deaggregation successful 
  FCS pass for MPDU:1
  HE-Data EVM:-31.44dB

Приложение

В этом примере используются следующие вспомогательные функции:

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

  1. IEEE P802.11ax™/D4.1 Проект стандарта на информационные технологии - Телекоммуникации и обмен информацией между системами - Локальные и столичные сети - Особые требования - Часть 11: Спецификации управления доступом к среде беспроводной локальной сети (MAC) и физического Слоя (PHY) - Поправка 6: Усовершенствования для высокой Эффективности WLAN.

  2. Стандарт IEEE Std 802.11™-2016 IEEE на информационные технологии - Телекоммуникации и обмен информацией между системами - Локальные и столичные сети - Особые требования - Часть 11: Беспроводное управление доступом к среде локальной сети (MAC) и физический слой (PHY) Спецификации.