Передайте и восстановите L-SIG, VHT-SIG-A, VHT-SIG-B в исчезающем канале

Передайте форму волны VHT через шумный канал MIMO. Извлеките L-SIG, VHT-SIG-A и поля VHT-SIG-B и проверьте, что они были правильно восстановлены.

Установите параметры, используемые в примере.

cbw = 'CBW40';                     % Channel bandwidth
fs = 40e6;                         % Sample rate (Hz)
ntx = 2;                           % Number of transmit antennas
nsts = 2;                          % Number of space-time streams
nrx = 3;                           % Number of receive antennas

Создайте объект настройки VHT, что поддержки 2x2 передача MIMO и имеют длину APEP 2 000.

vht = wlanVHTConfig('ChannelBandwidth',cbw,'APEPLength',2000, ...
    'NumTransmitAntennas',ntx,'NumSpaceTimeStreams',nsts, ...
    'SpatialMapping','Direct','STBC',false);

Сгенерируйте форму волны VHT, содержащую случайный PSDU.

txPSDU = randi([0 1],vht.PSDULength*8,1);
txPPDU = wlanWaveformGenerator(txPSDU,vht);

Создайте 2x2 канал TGac и канал AWGN с дБ SNR=10.

tgacChan = wlanTGacChannel('SampleRate',fs,'ChannelBandwidth',cbw, ...
    'NumTransmitAntennas',ntx,'NumReceiveAntennas',nrx, ...
    'LargeScaleFadingEffect','Pathloss and shadowing', ...
    'DelayProfile','Model-C');

chNoise = comm.AWGNChannel('NoiseMethod','Signal to noise ratio (SNR)',...
    'SNR',10);

Передайте формы волны VHT через 2x2, TGac образовывают канал и добавляют шум канала AWGN.

rxPPDU = chNoise(tgacChan(txPPDU));

Добавьте дополнительный белый шум, соответствующий приемнику с шумовой фигурой на 9 дБ. Шумовое отклонение равно k*T*B*F, где k является константой Больцманна, T является температурой окружающей среды, B является полосой пропускания канала (частота дискретизации), и F является фигурой шума приемника.

nVar = 10^((-228.6+10*log10(290) + 10*log10(fs) + 9 )/10);
rxNoise = comm.AWGNChannel('NoiseMethod','Variance','Variance',nVar);

rxPPDU = rxNoise(rxPPDU);

Найдите запуск и индексы остановки для всех полей компонента PPDU.

ind = wlanFieldIndices(vht)
ind = struct with fields:
       LSTF: [1 320]
       LLTF: [321 640]
       LSIG: [641 800]
    VHTSIGA: [801 1120]
     VHTSTF: [1121 1280]
     VHTLTF: [1281 1600]
    VHTSIGB: [1601 1760]
    VHTData: [1761 25600]

Преамбула содержится в первых 1 760 символах. Постройте преамбулу.

plot(abs(rxPPDU(1:1760)))

Figure contains an axes object. The axes object contains an object of type line.

Извлеките L-LTF из полученного PPDU использование запуска и индексов остановки, определенных wlanFieldIndices функция. Демодулируйте L-LTF и оцените коэффициенты канала.

rxLLTF = rxPPDU(ind.LLTF(1):ind.LLTF(2),:);
demodLLTF = wlanLLTFDemodulate(rxLLTF,vht);
chEstLLTF = wlanLLTFChannelEstimate(demodLLTF,vht);

Извлеките поле L-SIG из полученного PPDU и восстановите его информационные биты.

rxLSIG = rxPPDU(ind.LSIG(1):ind.LSIG(2),:);
infoLSIG = wlanLSIGRecover(rxLSIG,chEstLLTF,nVar,cbw);

Смотрите информацию об уровне L-SIG и подтвердите что последовательность [1 1 0 1] получен. Эта последовательность соответствует скорости передачи данных на 6 МГц, которая используется для всех передач VHT.

rate = infoLSIG(1:4)'
rate = 1x4 int8 row vector

   0   1   1   1

Извлеките VHT-SIG-A и подтвердите, что проверка CRC передала.

rxVHTSIGA = rxPPDU(ind.VHTSIGA(1):ind.VHTSIGA(2),:);
[infoVHTSIGA,failCRC] = wlanVHTSIGARecover(rxVHTSIGA, ...
    chEstLLTF,nVar,cbw);
failCRC
failCRC = logical
   1

Извлеките и демодулируйте VHT-LTF. Используйте демодулируемый сигнал оценить, что коэффициенты канала должны были восстановить поле VHT-SIG-B.

rxVHTLTF = rxPPDU(ind.VHTLTF(1):ind.VHTLTF(2),:);
demodVHTLTF = wlanVHTLTFDemodulate(rxVHTLTF,vht);
chEstVHTLTF = wlanVHTLTFChannelEstimate(demodVHTLTF,vht);

Извлеките и восстановите VHT-SIG-B.

rxVHTSIGB = rxPPDU(ind.VHTSIGB(1):ind.VHTSIGB(2),:);
infoVHTSIGB = wlanVHTSIGBRecover(rxVHTSIGB,chEstVHTLTF,nVar,cbw);

Проверьте, что длина APEP, содержавшаяся в первых 19 битах VHT-SIG-B, соответствует заданной длине 2 000 битов.

pktLbits = infoVHTSIGB(1:19)';
pktLen = bi2de(double(pktLbits))*4
pktLen = 1676920