matlab误码率理论,QDPSK理论误码率与实际误码率matlab仿真程序

本文探讨了使用格雷码对等效基带信号进行调制的过程,通过MATLAB代码展示了如何生成随机数据、进行逻辑运算、格雷码映射,并分析不同信噪比(SNR)下的误码率。关键步骤包括初始化参数、噪声功率计算和接收信号处理。
摘要由CSDN通过智能技术生成

%%dpsk格雷码矩形

%%等效基带调制

clc;

clear all;

close all;%%关闭所有窗口,比如之前画的图

nsymbol = 1e6;%%每种信噪比下符号数的发送符号数,10^6个数errornumber = zeros(1,10);

errorratio = zeros(1,10);

dataa = randi([0,1],1,2*nsymbol);%%产生1行,2*nsymbol列均匀分布的随机数datab = zeros(1,2*nsymbol);

data_mod1 = zeros(1,nsymbol);%%各参量初始化

data_mod2 = zeros(1,nsymbol);

data_demod1 = zeros(1,nsymbol);

data_demod2 = zeros(1,nsymbol);

s_receive1 = zeros(1,nsymbol);

s_receive2 = zeros(1,nsymbol);

datab_receive = zeros(1,2*nsymbol);

dataa_receive = zeros(1,2*nsymbol);

datab(1) = xor(0,dataa(1));%%给定初始相位

for l = 2:(2*nsymbol)%%逻辑运算

datab(l) = xor(dataa(l),datab(l-1));

end

for i = 1:nsymbol %%格雷码调制到星座图的映射

if datab(2*i-1)==0 && datab(2*i)==0

data_mod1(i) = 1;

data_mod2(i) = 1;

elseif datab(2*i-1)==0 && datab(2*i)==1

data_mod1(i) = -1;

data_mod2(i) = 1;

elseif datab(2*i-1)==1 && datab(2*i)==1

data_mod1(i) = -1;

data_mod2(i) = -1;

elseif datab(2*i-1)==1 && datab(2*i)==0

data_mod1(i) = 1;

data_mod2(i) = -1;

end

end

SNR_dB = 1:10;%%%信噪比dB形式

SNR = 10.^(SNR_dB/10);%%信噪比转化为线性值

for loop= 1:10

sigma = sqrt(1/SNR(loop));%%%根据符号功率求噪声功率

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值