pskdemod

Фазовая демодуляция

Описание

пример

z = pskdemod(y,M) демодулирует сложную огибающую, yPSK-модулированного сигнала, имеющего порядок модуляции M.

пример

z = pskdemod(y,M,ini_phase) задает начальную фазу PSK-модулированного сигнала.

z = pskdemod(y,M,ini_phase,symorder) задает порядок символа PSK-модулированного сигнала.

Примеры

свернуть все

Сравните схемы PSK и PAM модуляции, чтобы продемонстрировать, что PSK более чувствителен к фазовому шуму. Это ожидаемый результат, потому что созвездие PSK округлое, в то время как созвездие PAM линейное.

Задайте количество символов и параметры порядка модуляции. Сгенерируйте символы случайных данных.

len = 10000;                
M = 16;                     
msg = randi([0 M-1],len,1);

Модулируйте msg использование PSK и PAM для сравнения двух методов.

txpsk = pskmod(msg,M);
txpam = pammod(msg,M);

Возмущает фазу модулированных сигналов, применяя случайное вращение фазы.

phasenoise = randn(len,1)*.015;
rxpsk = txpsk.*exp(2i*pi*phasenoise);
rxpam = txpam.*exp(2i*pi*phasenoise);

Создайте графики поля точек принятых сигналов.

scatterplot(rxpsk);
title('Noisy PSK Scatter Plot')

Figure Scatter Plot contains an axes. The axes with title Noisy PSK Scatter Plot contains an object of type line. This object represents Channel 1.

scatterplot(rxpam);
title('Noisy PAM Scatter Plot')

Figure Scatter Plot contains an axes. The axes with title Noisy PAM Scatter Plot contains an object of type line. This object represents Channel 1.

Демодулируйте принятые сигналы.

recovpsk = pskdemod(rxpsk,M);
recovpam = pamdemod(rxpam,M);

Вычислите количество ошибок символов для каждой схемы модуляции. Сигнал PSK испытывает гораздо больше ошибок символов.

numerrs_psk = symerr(msg,recovpsk);
numerrs_pam = symerr(msg,recovpam);
[numerrs_psk numerrs_pam]
ans = 1×2

   343     1

Сгенерируйте случайные символы.

dataIn = randi([0 3],1000,1);

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

txSig = pskmod(dataIn,4,pi/4);

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

rxSig = awgn(txSig,10);

Демодулируйте принятый сигнал и вычислите количество ошибок символов.

dataOut = pskdemod(rxSig,4,pi/4);
numErrs = symerr(dataIn,dataOut)
numErrs = 2

Постройте отображение символов PSK для Серых и естественных двоичных закодированных данных.

Установите порядок модуляции, а затем создайте последовательность данных, содержащую полный набор созвездия точек.

M = 8;
data = (0:M-1);
phz = 0;

Модулируйте и демодулируйте данные с помощью Gray и естественных двоичных закодированных данных.

symgray = pskmod(data,M,phz,'gray');
mapgray = pskdemod(symgray,M,phz,'gray');

symbin = pskmod(data,M,phz,'bin');
mapbin = pskdemod(symbin,M,phz,'bin');

Постройте график точек созвездия с помощью одного из наборов символов. Для каждой точки созвездия назначьте метку, указывающую Серые и естественные двоичные значения для каждого символа.

  • Для отображения двоичных символов Грея, смежные точки созвездия отличаются одним двоичным битом и не являются численно последовательными.

  • Для естественного двоичного отображения символов смежные точки созвездия следуют естественному двоичному кодированию и являются последовательными.

scatterplot(symgray,1,0,'b*');
for k = 1:M
    text(real(symgray(k))-0.2,imag(symgray(k))+.15,...
        dec2base(mapgray(k),2,4));
     text(real(symgray(k))-0.2,imag(symgray(k))+.3,...
         num2str(mapgray(k)));
    
    text(real(symbin(k))-0.2,imag(symbin(k))-.15,...
        dec2base(mapbin(k),2,4),'Color',[1 0 0]);
    text(real(symbin(k))-0.2,imag(symbin(k))-.3,...
        num2str(mapbin(k)),'Color',[1 0 0]);
end
axis([-2 2 -2 2])

Figure Scatter Plot contains an axes. The axes with title Scatter plot contains 33 objects of type line, text. This object represents Channel 1.

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

свернуть все

PSK-модулированный входной сигнал, заданный как действительный или комплексный вектор или матрица. Если y является матрицей, функция обрабатывает столбцы независимо.

Типы данных: double
Поддержка комплексного числа: Да

Порядок модуляции, заданный как целочисленная степень двойки.

Пример: 2 | 4 | 16

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

Начальная фаза PSK-модуляции, заданная в радианах как действительный скаляр.

Если ini_phase пуст, тогда pskdemod использует начальную фазу 0.

Пример: pi/4

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

Порядок символа, заданный как 'bin' или 'gray'. Этот аргумент задает, как функция присваивает двоичные векторы соответствующим целым числам.

  • Если symorder является 'bin', функция использует естественное двоичное закодированное упорядоченное расположение.

  • Если symorder является 'gray', функция использует Серый-закодированное упорядоченное расположение.

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

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

свернуть все

PSK-демодулированный выходной сигнал, возвращаемый как вектор или матрица, имеющая одинаковое число столбцов, что и входной сигнал y.

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