Передайте форму волны 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)))
Извлеките 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