wlanMPDUDecode

Описание

пример

[cfgMAC,payload,status] = wlanMPDUDecode(mpdu,phyFormat) восстанавливает payload, один или несколько модулей эксплуатационных данных MAC (MSDUs), путем декодирования Модуля данных о протоколе MAC (MPDU) mpdu. Функция декодирует MPDU при помощи параметров, подходящих для заданного формата PHY.

Функция также возвращает status, результат декодирования MPDU и cfgMAC, wlanMACFrameConfig объект настройки.

пример

[cfgMAC,payload,status] = wlanMPDUDecode(mpdu,cfgPHY) декодирует MPDU при помощи параметров передачи PHY cfgPHY.

пример

[cfgMAC,payload,status] = wlanMPDUDecode(___,Name,Value) задает опции с помощью одного или нескольких аргументов пары "имя-значение", кроме того, любая комбинация входных аргументов от предыдущих синтаксисов.

Примеры

свернуть все

Создайте объект настройки системы координат ВЛАНА МАКА для MPDU в однопользовательской высокой эффективности (SU HE) формат, и затем сгенерируйте MPDU.

phyFormat = 'HE-SU';
cfgMAC =  wlanMACFrameConfig('FrameFormat',phyFormat);
payload = randi([0 255],1,40);
mpdu = wlanMACFrame(payload,cfgMAC,'OutputFormat','bits');

Возвратите MSDUs путем декодирования MPDU для заданной настройки формата PHY.

[rxCfgMAC,payload,status] = wlanMPDUDecode(mpdu,phyFormat);

Подтвердите успешное декодирование путем отображения состояния.

disp(status)
    Success

Создайте объект настройки системы координат ВЛАНА МАКА для системы координат Данных QoS, и затем сгенерируйте MPDU.

cfgMAC = wlanMACFrameConfig('FrameType','QoS Data');
payload = randi([0 255],1,40);
mpdu = wlanMACFrame(payload,cfgMAC,'OutputFormat','bits');

Создайте не высокий формат пропускной способности (non-HT-format) объект настройки с настройками по умолчанию.

cfgPHY = wlanNonHTConfig;

Возвратите MSDUs путем декодирования MPDU для заданной настройки формата PHY.

[cfgMAC,payload,status] = wlanMPDUDecode(mpdu,cfgPHY);

Подтвердите успешное декодирование путем отображения состояния.

disp(status)
    Success

Deaggregate VHT A-MPDU и декодируют извлеченный MPDUs.

Создайте объект настройки системы координат ВЛАНА МАКА для VHT A-MPDU.

txCfgMAC = wlanMACFrameConfig('FrameType','QoS Data','FrameFormat','VHT');

Создайте объект настройки VHT-формата с настройками по умолчанию.

cfgPHY = wlanVHTConfig;

Сгенерируйте случайную полезную нагрузку восьми MSDUs.

txPayload =  repmat({randi([0 255],1,40)},1,8);

Сгенерируйте A-MPDU, содержащий восемь MPDUs для заданного MAC и настроек PHY.

ampdu = wlanMACFrame(txPayload,txCfgMAC,cfgPHY);

Извлеките список MPDUs deaggregating A-MPDU. Отобразите состояние deaggregation и CRC разделителя.

[mpduList,failCRC,status] = wlanAMPDUDeaggregate(ampdu,cfgPHY,'DataFormat','octets');
disp(status)
    Success
disp(failCRC)
   0   0   0   0   0   0   0   0

Декодируйте все MPDUs в извлеченном. Подтвердите успешное декодирование путем отображения состояния.

if strcmp(status,'Success')
    for i = 1:numel(mpduList)
        if ~failCRC(i)
            [cfgMAC,payload,status(i)] = ...
                wlanMPDUDecode(mpduList{i},cfgPHY,'DataFormat','octets');
        end
    end
end
disp(status)
  Columns 1 through 7

    Success    Success    Success    Success    Success    Success    Success

  Column 8

    Success

Входные параметры

свернуть все

MPDU, который будет декодироваться в виде одного из этих значений.

  • Вектор с бинарным знаком, представляющий MPDU в битной форме

  • Вектор из целых чисел в интервале [0, 255] представление октетов в десятичном формате

  • Строковый скаляр, представляющий MPDU как октеты в шестнадцатеричном формате

  • Вектор символов, представляющий MPDU как октеты в шестнадцатеричном формате

  • Символьный массив, где каждая строка представляет октет в шестнадцатеричном формате

Типы данных: single | double | int8 | int16 | int32 | int64 | uint8 | uint16 | uint32 | uint64 | char | string

Формат PHY в виде одного из этих значений.

  • 'HE-SU' — Однопользовательская высокая эффективность (SU HE) формат

  • 'HE-EXT-SU' — SU расширенной области значений HE (HE SU ER) формат

  • 'HE-MU' — Многопользовательский HE (HE МУ) формат

  • 'HE-TB' — Основанный на триггере HE (Тбайт HE) формат

  • 'VHT' — Формат очень высокопроизводительного (VHT)

  • 'HT' — Высокопроизводительный (HT) формат

Типы данных: char | string

Формат PHY и параметры передачи в виде одного из этих объектов.

Аргументы в виде пар имя-значение

Задайте дополнительные разделенные запятой пары Name,Value аргументы. Name имя аргумента и Value соответствующее значение. Name должен появиться в кавычках. Вы можете задать несколько аргументов в виде пар имен и значений в любом порядке, например: Name1, Value1, ..., NameN, ValueN.

Пример: 'DataFormat','octets'

Формат входа MPDU в виде разделенной запятой пары, состоящей из 'DataFormat' и одно из этих значений.

  • 'bits' — Задайте mpdu введите в битном формате

  • 'octets' — Задайте mpdu введите в формате октета

Типы данных: char | string

Подавите предупреждающие сообщения в виде разделенной запятой пары, состоящей из 'SuppressWarnings' и одно из этих значений.

  • false или 0 — Позвольте предупреждающие сообщения.

  • true или 1 — Подавите предупреждающие сообщения.

Типы данных: логический

Выходные аргументы

свернуть все

Настройка системы координат MAC, возвращенная как wlanMACFrameConfig объект.

Один или несколько MSDUs, возвращенные как массив ячеек символьных массивов. Функция возвращает символьный массив для каждого MSDU. В этих символьных массивах каждая строка является шестнадцатеричным представлением октета. Для каждой системы координат MAC, которая не содержит данных, функция возвращает payload как массив пустой ячейки.

Типы данных: cell

Состояние декодирования MPDU, возвращенного как неположительное целое число в интервале [–20, 0]. Каждое значение status соответствует члену wlanMACDecodeStatus класс перечисления, который указывает на состояние декодирования системы координат MAC согласно этой таблице.

Перечислимая величинаЧлен класса перечисленияДекодирование состояния
0SuccessСистема координат MAC успешно декодируется
–1FCSFailedПоследовательность проверки системы координат (FCS) перестала работать
–2InvalidProtocolVersionНедопустимая версия протокола
–3UnsupportedFrameTypeНеподдерживаемый тип системы координат
–4UnsupportedFrameSubtypeНеподдерживаемый подтип системы координат
–5NotEnoughDataНедостаточные данные, чтобы декодировать систему координат
–6UnsupportedBAVariantВариант Unsupported Блока система координат Ack
–7UnknownBitmapSizeНеизвестный растровый размер
–8UnknownAddressExtModeНеизвестный режим расширения адреса
–9MalformedAMSDULengthУродливый агрегированный модуль эксплуатационных данных MAC (A-MSDU) с недопустимой длиной
–10MalformedSSIDУродливый сервис установил идентификатор (SSID) информационный элемент (IE)
–11MalformedSupportedRatesIEУродливый поддерживаемый IE уровней
–12MalformedIELengthУродливое поле длины IE
–13MissingMandatoryIEsОбязательные пропавшие без вести IES
–14NoMPDUFoundНикакой MPDU не найден в A-MPDU
–15CorruptedAMPDUВсе разделители в данном А-МПДУ привели контроль циклическим избыточным кодом (CRC) к сбою
–16InvalidDelimiterLengthНедопустимое поле длины в разделителе MPDU
–17MaxAMSDULenthExceededA-MSDU превышает максимальный предел длины
–18MaxMPDULengthExceededMPDU превышает максимальный предел длины
–19MaxMMPDULengthExceededСистема координат управления MAC превышает максимальный предел длины
–20MaxMSDULengthExceededMSDU превышает максимальный предел длины
–21UnexpectedProtectedFrameНедопустимое значение защищенного бита для этого типа системы координат

Перечислимая величина кроме 0 средние значения это MPDU декодирование не пройдено. Если декодирование перестало работать, выход cfgMAC отображения никакие свойства и выход payload возвращен как массив пустой ячейки.

Типы данных: int16

Расширенные возможности

Генерация кода C/C++
Генерация кода C и C++ с помощью MATLAB® Coder™.

Введенный в R2019a