一、一些Matlab函数

二、2PSK调制解调,性能分析

1、2PSK调制

(1)图示

(2)Matlab代码

function [ s_t ,bb_t,bits] = psk2_module( nSym ,Rb,fs,fc,Ac )
%UNTITLED7 此处显示有关此函数的摘要
% 此处显示详细说明
%nSym = 300; % 信息长度
%Rb = 200; % 信息速率
%fs = 48e3; % 采样率
%fc = 4e3; % 载波频率
%Ac = 1; % 载波幅度
%s_t % 已调波形
%bb_t % 码型时域波形
%bb % 码型 %%
%产生信号
% 随机产生二进制信息
bits = randint(nSym,1);
% 产生不归零码
bb = 2 * bits - 1; %%
%产生码型
% 每个符号包含的样点数
sample_bit = fs / Rb;
% 时间
t = (0:sample_bit*nSym-1)'/fs;
% 产生不归零码的时域波形
bb_t = reshape(repmat(bb', sample_bit, 1), sample_bit*nSym, 1); %%
%调制
% 产生载波信号
c_t = Ac*cos(2*pi*fc*t);
% 调制
s_t = bb_t .* c_t; end

2、2PSK解调

(1)图示

(2)Matlab代码

function [ bits,bb_t] = psk2_remodule( Rb,fs,fc,s_t)
%UNTITLED11 此处显示有关此函数的摘要
% 此处显示详细说明
% Rb = 200; % 信息速率
% fs = 48e3; % 采样率
% fc = 4e3; % 载波频率
% s_t % 调制波形 % bit_s % 抽样判决之后
% bb_t % 抽样判决之前 r_t = s_t; % 每个符号包含的样点数
sample_bit = fs/Rb;
% 时间
t = (0:length(r_t)-1)'/fs; % 产生同频同相载波信号
c_t = cos(2*pi*fc*t); % FIR群延迟,也是阶数一半
group_delay = 50;
b = fir1(group_delay*2, Rb/(fs/2)); % 主瓣占带宽Rb,这里可以放宽
bb_t = filter(b,1, r_t .* c_t); % 混频并滤波 % 抽样点下标
idx_decision = round(1+group_delay+sample_bit/2):sample_bit:length(r_t);
% 取得抽样点
val_decision = bb_t(idx_decision); % 判决
bits = zeros(length(val_decision),1);
bits(val_decision > 0) = 1; end

3、一个demo

clc,clear;

nSym = 1000;    % 信息长度
Rb = 1e3; % 信息速率
fs = 48e3; % 采样率
fc = 5e3; % 载波频率
Ac = 1; % 载波幅度 %%
[s_t ,bb_t,bb] = psk2_module( nSym ,Rb,fs,fc,Ac );
t = (0 : length(s_t) - 1) / fs' ; %%
%绘制已调波形
figure();
plot(t,s_t);
title('2PSK时域波形');
xlabel('time(t)');
ylabel('y'); %绘制功率谱
powerF_draw(s_t,fs); %%
%发送端码型变换后的波形
figure();
subplot(2,1,1);
plot(t,bb_t);
axis([min(t),max(t),-1.2,1.2]);
title('发送端码型波形');
xlabel('time(t)');
ylabel('y'); %接收端抽样判决前的波形
subplot(2,1,2);
[bits,rbb_t] = psk2_remodule(Rb,fs,fc,s_t);
plot(t,rbb_t);
title('接收端码型波形');
xlabel('time(t)');
ylabel('y'); %%
%眼图
eyediagram(rbb_t,4*fs/Rb); %取四个Bit
title('无信道噪声'); %小噪声
s_pow = sum(s_t.^2) / length(s_t);
n_pow = 0.01 * s_pow;
n_t = bandlimit_noise(length(s_t),fs,fc,2*Rb,n_pow);
[bits_low_noise,rbb_t_low_noise] = psk2_remodule(Rb,fs,fc,s_t + n_t);
eyediagram(rbb_t_low_noise,4*fs/Rb);
title('小信道噪声'); %大噪声
n_pow = 0.5 * s_pow;
n_t = bandlimit_noise(length(s_t),fs,fc,2*Rb,n_pow);
[bits_high_noise,rbb_t_high_noise] = psk2_remodule(Rb,fs,fc,s_t + n_t);
eyediagram(rbb_t_high_noise,4*fs/Rb);
title('大信道噪声'); %%
%2PSK通信系统评估
snr_i = (-3:1:8)'; % SNR输入(dB) %计算噪声功率
n_pow = s_pow ./ (10.^(snr_i ./ 10)); %初始化储存
number = zeros(1,length(snr_i));
ratio = zeros(1,length(snr_i)); %计算SNR
for i=1:length(snr_i)
n_t = bandlimit_noise(length(s_t),fs,fc,2*Rb,n_pow(i));
[bits,rbb_t] = psk2_remodule(Rb,fs,fc,s_t + n_t);
[number(i),ratio(i)] = symerr(bits,bb(1:nSym-1));
end %绘图
figure();
plot(snr_i,ratio*100);
title('误码率曲线');
xlabel('snr_i(dB)');
ylabel('误码率(%)');

三、2DPSK调制解调

1、2DPSK调制

function [ s_t ,bb_t,bits] = dpsk2_module( nSym ,Rb,fs,fc,Ac )
%UNTITLED7 此处显示有关此函数的摘要
% 此处显示详细说明
%nSym = 300; % 信息长度
%Rb = 200; % 信息速率
%fs = 48e3; % 采样率
%fc = 4e3; % 载波频率
%Ac = 1; % 载波幅度
%s_t % 已调波形
%bb_t % 码型时域波形
%bits % 码型 %%
%产生信号
% 随机产生二进制信息
bits = randint(nSym,1); %产生差分码
bits_d = zeros(nSym+1,1);
for i=1:length(bits)
bits_d(i+1) = mod(bits_d(i) + bits(i),2);
end % 产生不归零码
bb = 2 * bits_d - 1; %%
%产生码型
% 每个符号包含的样点数
sample_bit = fs / Rb;
% 时间
t = (0:sample_bit*(nSym+1)-1)'/fs;
% 产生不归零码的时域波形
bb_t = reshape(repmat(bb', sample_bit, 1), sample_bit* (nSym+1), 1); %%
%调制
% 产生载波信号
c_t = Ac*cos(2*pi*fc*t);
% 调制
s_t = bb_t .* c_t; end

2、2DPSK解调

function [ bits,bb_t] = dpsk2_remodule( Rb,fs,fc,s_t)
%UNTITLED11 此处显示有关此函数的摘要
% 此处显示详细说明
% Rb = 200; % 信息速率
% fs = 48e3; % 采样率
% fc = 4e3; % 载波频率
% s_t % 调制波形 % bit_s % 抽样判决之后
% bb_t % 抽样判决之前 r_t = s_t; % 每个符号包含的样点数
sample_bit = fs/Rb;
% 时间
t = (0:length(r_t)-1)'/fs; % 产生同频同相载波信号
c_t = cos(2*pi*fc*t); % FIR群延迟,也是阶数一半
group_delay = 50;
b = fir1(group_delay*2, Rb/(fs/2)); % 主瓣占带宽Rb,这里可以放宽
bb_t = filter(b,1, r_t .* c_t); % 混频并滤波 % 抽样点下标
idx_decision = round(1+group_delay+sample_bit/2):sample_bit:length(r_t);
% 取得抽样点
val_decision = bb_t(idx_decision); % 判决
bits_d = zeros(length(val_decision),1);
bits_d(val_decision > 0) = 1;
bits = zeros(length(bits_d)-1,1);
for i=1:length(bits)
bits(i) = mod(bits_d(i) + bits_d(i+1),2);
end end

3、一个demo

clc,clear;

nSym = 1000;    % 信息长度
Rb = 1e3; % 信息速率
fs = 48e3; % 采样率
fc = 5e3; % 载波频率
Ac = 1; % 载波幅度 %% 产生2PSK信号
[s_t,bb_t,bb] = psk2_module( nSym ,Rb,fs,fc,Ac ); %% 产生2DPSK信号
[s_d_t,bb_d_t,bb_d] = dpsk2_module( nSym ,Rb,fs,fc,Ac ); %% 绘制发送端差分编码前后的波形
figure()
%发送端差分编码前离散序列
subplot(2,1,1);
stem(bb_d);
axis([-5,nSym+5,-1.2,1.2]);
title('发送端差分编码前离散序列');
xlabel('time(t)');
ylabel('y'); %发送端差分不归零编码后离散序列
subplot(2,1,2);
stem(bb_d_t(1:fs/Rb:length(bb_d_t)));
axis([-5,nSym+5,-1.2,1.2]);
title('发送端差分不归零编码后离散序列');
xlabel('time(t)');
ylabel('y'); [bits_d,rbb_d_t] = dpsk2_remodule(Rb,fs,fc,s_d_t); %% 2PSK通信系统评估
s_pow = sum(s_t.^2) / length(s_t);
snr_i = (-3:1:8)'; % SNR输入(dB)
%计算噪声功率
n_pow = s_pow ./ (10.^(snr_i ./ 10)); %初始化储存
number = zeros(1,length(snr_i));
ratio = zeros(1,length(snr_i)); %计算SNR
for i=1:length(snr_i)
n_t = bandlimit_noise(length(s_t),fs,fc,2*Rb,n_pow(i));
[bits,rbb_t] = psk2_remodule(Rb,fs,fc,s_t + n_t);
[number(i),ratio(i)] = symerr(bits,bb(1:nSym-1));
end %% 2DPSK通信系统评估
s_d_pow = sum(s_d_t.^2) / length(s_d_t);
snr_i = (-3:1:8)'; % SNR输入(dB) %计算噪声功率
n_d_pow = s_d_pow ./ (10.^(snr_i ./ 10)); %初始化储存
number_d = zeros(1,length(snr_i));
ratio_d = zeros(1,length(snr_i)); %计算SNR
for i=1:length(snr_i)
n_d_t = bandlimit_noise(length(s_d_t),fs,fc,2*Rb,n_d_pow(i));
[bits_d,rbb_d_t] = dpsk2_remodule(Rb,fs,fc,s_d_t + n_d_t);
[number_d(i),ratio_d(i)] = symerr(bits_d,bb_d(1:nSym-1));
end %绘图
figure()
hold on;
plot(snr_i,ratio*100,'b');
plot(snr_i,ratio_d*100,'r');
title('2PSK和2DPSK误码率曲线对比');
xlabel('snr_i(dB)');
ylabel('误码率(%)');
legend('2PSK','2DPSK');

通信原理实践(五)——2PSK 与2DPSK 通信系统的更多相关文章

  1. 通信原理实践(六)——基带传输

    一.基带传输引入 1.从数字带通传输说起 以上系统可以等价为: 这里"等价"的假设条件是 •信号通过滤波器不失真 •不存在码间串扰 意义:可以通过评估基带传输系统来获得数字带通传输 ...

  2. 通信原理实践(四)——模拟通信系统性能分析

    一.模拟通信系统性能分析 1.系统框图 2.信噪比定义 (1)输入信噪比: (2)输出信噪比: (3)调制制度增益: 3.模拟通信系统分析等价模型 即自己产生一个高斯白噪声,加入到调制信号,然后在送入 ...

  3. 通信原理实践(二)——幅度调制

    一.幅度调制,并画出时域和频域波形 1.代码如下: function [ p_n ] = AM_func( N,fs,fm,Am,fc,Ac,Ma ) %UNTITLED 此处显示有关此函数的摘要 % ...

  4. 通信原理实践(一)——音频信号处理

    一.信号的离散化 1.采样定理: –如果信号是带限的,并且采样频率fs超过信号最高频率的两倍,那么,原来的连续信号可以从采样样本中完全重建出来. 因此在仿真过程中,采样率(fs)是一个非常重要的参数. ...

  5. 通信原理实践(三)——FM调制

    一.FM调制 1.代码如下: clc,clear; fm = ; % 调制信号频率(Hz) Am = 0.5; % 调制信号幅度 fc = 5e3; % 载波频率(Hz) Ac = ; % 载波幅度 ...

  6. Socket 通信原理(Android客户端和服务器以TCP&&UDP方式互通)

    转载地址:http://blog.csdn.net/mad1989/article/details/9147661 ZERO.前言 有关通信原理内容是在网上或百科整理得到,代码部分为本人所写,如果不当 ...

  7. SSL 通信原理及Tomcat SSL 配置

    SSL 通信原理及Tomcat SSL 双向配置 目录1 参考资料 .................................................................. ...

  8. Java 下 SSL 通信原理及实例

    有关SSL的原理和介绍在网上已经有不少,对于Java下使用keytool生成证书,配置SSL通信的教程也非常多.但如果我们不能够亲自动手做一个SSL Sever和SSL Client,可能就永远也不能 ...

  9. Python Socket通信原理

    [Python之旅]第五篇(一):Python Socket通信原理   python Socket 通信理论 socket例子 摘要:  只要和网络服务涉及的,就离不开Socket以及Socket编 ...

随机推荐

  1. jenkins gitlab整合注意事项

    jenkins整合gitlab时,Source Code Management添加gitlab仓库路径无论怎么尝试都报如下两个异常: Failed to connect to repository : ...

  2. ACM/ICPC 之 DP-基因相似度(POJ1080-ZOJ1027)

    题意:两端基因片段,各有明确的碱基序列,现有一个碱基匹配的相似度数组,设计程序使得该相似度最大. //POJ1080-ZOJ1027 //题解:将s1碱基和s2碱基看做等长,添加一个碱基为'-',即每 ...

  3. C Primer Plus_第四章_字符串和格式化输入输出_编程练习

    Practice 1.输入名字和姓氏,以"名字,姓氏"的格式输出打印. #include int main(void) { char name[20]; char family[2 ...

  4. codeforces 492C. Vanya and Exams 解题报告

    题目链接:http://codeforces.com/problemset/problem/492/C 题目意思:给出 3 个整数:n,  r,  avg.然后有 n 行,每行有两个数:第 i 行有 ...

  5. CSS3实现圆角效果

    利用border-radius属性可以给元素div,input元素等添加圆角效果 后跟 值为这个圆角的半径,即数值越大效果越明显 -webkit-border-top/bottom-left/righ ...

  6. odoo注销后在登录时的用户名和密码

    初识odoo时会遇到注销后无法登陆的情况,一般原因是没有留意管理员邮件地址和对应的密码所致.初始情况下默认的邮件地址为admin,密码为数据库创建时提供的密码.

  7. Delphi 2010 Can't load package C:\Programme\Afalinasoft\Add-in Express 2\d5units\adxwizardd5.bpl.

    "Can't load package C:\Programme\Afalinasoft\Add-in Express 2\d5units\adxwizardd5.bpl. Componen ...

  8. 如何激活webstorm 11

    以前使用webstorm 10,可以在网上搜个注册码进行激活.后来升级了webstorm 11,发现原来的注册码和注册机已经不能激活了.查询后,才知道WebStorm 11改变了注册方法,可以在Lic ...

  9. c语言中的浮点数

    一.浮点数常量(小数) 0.11L, 0.0f ,0.0,1.88,2.5f ,0.188E1 E3表示103        比如 1.88E 3=1.88*1000=1880.0f E-3表示10- ...

  10. RxJava学习入门

    RxJava是什么 一个词:异步. RxJava 在 GitHub 主页上的自我介绍是 "a library for composing asynchronous and event-bas ...