mskdemod

Демодуляция с минимальным сдвигом

Синтаксис

z = mskdemod(y,nsamp)
z = mskdemod(y,nsamp,dataenc)
z = mskdemod(y,nsamp,dataenc,ini_phase)
z = mskdemod(y,nsamp,dataenc,ini_phase,ini_state)
[z,phaseout] = mskdemod(...)
[z,phaseout,stateout] = mskdemod(...)

Описание

z = mskdemod(y,nsamp) демодулирует комплексный конверт y из сигнала с помощью дифференцированно закодированного метода минимального манипулирования сдвига (MSK). nsamp обозначает количество отсчетов на символ и должно быть положительное целое число. Начальная фаза демодулятора 0. Если y матрица с несколькими строками и столбцами, функция обрабатывает столбцы как независимые каналы и обрабатывает их независимо.

z = mskdemod(y,nsamp,dataenc) задает метод кодирования данных для MSK. dataenc может быть любой 'diff' для дифференцированно закодированного MSK или 'nondiff' для недифференцированно закодированного MSK.

z = mskdemod(y,nsamp,dataenc,ini_phase) задает начальную фазу демодулятора. ini_phase вектор-строка, длина которого является количеством каналов в y и чьи значения являются целочисленными множителями pi/2. Постараться не заменять значение по умолчанию dataenc, установите dataenc к [].

z = mskdemod(y,nsamp,dataenc,ini_phase,ini_state) задает начальное состояние демодулятора. ini_state содержит последнюю половину символа ранее полученного сигнала. ini_state nsamp- C матрица, где C является количеством каналов в y.

[z,phaseout] = mskdemod(...) возвращает итоговую фазу y, который важен для демодуляции будущего сигнала. Выход phaseout имеет те же размерности как ini_phase введите, и принимает значения 0, pi/2\Pi, и 3*pi/2.

[z,phaseout,stateout] = mskdemod(...) возвращает итоговый nsamp значения y, который полезен для демодуляции первого символа будущего сигнала. stateout имеет те же размерности как ini_state входной параметр.

Примеры

свернуть все

Модулируйте и демодулируйте шумный сигнал MSK. Отобразите количество полученных ошибок.

Задайте количество отсчетов на символ для сигнала MSK.

nsamp = 16;

Инициализируйте параметры симуляции.

numerrs = 0; 
modPhase = zeros(1,2);    
demodPhase = zeros(1,2);  
demodState = complex(zeros(nsamp,2));

Основной цикл обработки включает эти шаги:

  • Сгенерируйте двоичные данные.

  • MSK модулирует данные.

  • Передайте сигнал через канал AWGN.

  • Демодулируйте сигнал MSK.

  • Определите количество битовых ошибок.

for iRuns = 1:20
    txData = randi([0 1],100,2);
    [modSig,modPhase] = mskmod(txData,nsamp,[],modPhase);
    rxSig = awgn(modSig,20,'measured');
    [rxData,demodPhase,demodState] = mskdemod(rxSig,nsamp,[],demodPhase,demodState);
    numerrs = numerrs + biterr(txData,rxData);
end

Отобразите количество битовых ошибок.

numerrs
numerrs = 0

Ссылки

[1] Pasupathy, S., "Минимальное Манипулирование Сдвига: Спектрально Эффективная Модуляция". Коммуникационный Журнал IEEE, июль 1979, стр 14–22.

Представлено до R2006a