Фазовая демодуляция
Сравните схемы 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')
scatterplot(rxpam);
title('Noisy PAM Scatter Plot')
Демодулируйте принятые сигналы.
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])

y - PSK-модулированный входной сигналPSK-модулированный входной сигнал, заданный как действительный или комплексный вектор или матрица. Если y является матрицей, функция обрабатывает столбцы независимо.
Типы данных: double
Поддержка комплексного числа: Да
M - Порядок модуляцииПорядок модуляции, заданный как целочисленная степень двойки.
Пример: 2 | 4 | 16
Типы данных: double
ini_phase - Начальная фаза[]Начальная фаза PSK-модуляции, заданная в радианах как действительный скаляр.
Если ini_phase пуст, тогда pskdemod использует начальную фазу 0.
Пример: pi/4
Типы данных: double
symorder - Порядок символов'bin' (по умолчанию) | 'gray'Порядок символа, заданный как 'bin' или 'gray'. Этот аргумент задает, как функция присваивает двоичные векторы соответствующим целым числам.
Если symorder является 'bin', функция использует естественное двоичное закодированное упорядоченное расположение.
Если symorder является 'gray', функция использует Серый-закодированное упорядоченное расположение.
Типы данных: char
z - PSK-демодулированный выходной сигналPSK-демодулированный выходной сигнал, возвращаемый как вектор или матрица, имеющая одинаковое число столбцов, что и входной сигнал y.
У вас есть измененная версия этого примера. Вы хотите открыть этот пример с вашими правками?
1. Если смысл перевода понятен, то лучше оставьте как есть и не придирайтесь к словам, синонимам и тому подобному. О вкусах не спорим.
2. Не дополняйте перевод комментариями “от себя”. В исправлении не должно появляться дополнительных смыслов и комментариев, отсутствующих в оригинале. Такие правки не получится интегрировать в алгоритме автоматического перевода.
3. Сохраняйте структуру оригинального текста - например, не разбивайте одно предложение на два.
4. Не имеет смысла однотипное исправление перевода какого-то термина во всех предложениях. Исправляйте только в одном месте. Когда Вашу правку одобрят, это исправление будет алгоритмически распространено и на другие части документации.
5. По иным вопросам, например если надо исправить заблокированное для перевода слово, обратитесь к редакторам через форму технической поддержки.