qpsk调制matlab代码
时间: 2023-11-22 20:03:16 浏览: 98
QPSK(Quadrature Phase Shift Keying,2进制相移键控)是一种常见的调制技术,常用于数字通信系统中。下面是一个使用MATLAB编写的QPSK调制的示例代码:
% 定义调制参数
fc = 100e3; % 载波频率为100kHz
fs = 1e6; % 采样频率为1MHz
T = 1/fs; % 采样周期
Ts = 1/fc; % 符号周期
% 生成随机二进制序列
bitStream = randi([0 1], 1, 1000); % 生成长度为1000的随机二进制序列
% 将二进制序列转换为QPSK调制符号
symbols = zeros(1, length(bitStream)/2); % 生成QPSK调制符号序列
for i = 1:length(symbols)
if bitStream(2*i-1) == 0 && bitStream(2*i) == 0
symbols(i) = -1 - 1i; % 映射00为-Q
elseif bitStream(2*i-1) == 0 && bitStream(2*i) == 1
symbols(i) = -1 + 1i; % 映射01为+Q
elseif bitStream(2*i-1) == 1 && bitStream(2*i) == 0
symbols(i) = 1 - 1i; % 映射10为-Q
elseif bitStream(2*i-1) == 1 && bitStream(2*i) == 1
symbols(i) = 1 + 1i; % 映射11为+Q
end
end
% 生成QPSK调制信号
t = 0:T:(length(symbols)*Ts-T); % 生成时间序列
I = real(symbols); % 获取实部
Q = imag(symbols); % 获取虚部
transmittedSignal = sqrt(2/Ts)*cos(2*pi*fc*t) .* I - sqrt(2/Ts)*sin(2*pi*fc*t) .* Q; % 构建QPSK调制信号
% 显示调制结果
figure;
subplot(2,1,1); stem(t, bitStream); % 显示原始二进制序列
title('输入二进制序列');
xlabel('时间 (s)');
ylabel('幅度');
subplot(2,1,2); plot(t, transmittedSignal); % 显示QPSK调制信号
title('QPSK调制信号');
xlabel('时间 (s)');
ylabel('幅度');
以上代码将生成一个长度为1000的随机二进制序列,并使用QPSK调制对其进行调制,最后显示原始二进制序列和QPSK调制信号的波形图。
阅读全文