2ASK调制与解调(包含maltab代码)

实验原理

image-20210528104751015

image-20210528104759875

image-20210528104807027

image-20210528104814643

image-20210528104822668

image-20210528104830126

image-20210528104837985

image-20210528104846403

image-20210528104853742

image-20210528104902246

image-20210528104910982

实验代码

信噪比为20db时代码:

clear all;
close all;
%%%%%%%     parameter settings      %%%%%   
Rb = 1000;%比特率
Rs = 1000;%符号率
Fs = 10000;%采样频率
N = 100000;%原始消息信号的长度
UpSampleRate = Fs/Rs;  % 一个符号周期内采样点数
RollOff = 0.25;
Span = 6;
Sps = UpSampleRate;
SNR = 20;
fc= 2000;
%%%%      信源       %%%%%      
%%% 随机信号
src_bit = randi([0,1],1,N); 
src_sym= src_bit;
%升采样
src_upsamp_sym = zeros(1,N*UpSampleRate);
src_upsamp_sym(1:UpSampleRate:end) = src_sym;
%脉冲成形
h_rcos = rcosdesign(RollOff,Span,Sps,'sqrt');
rcos_src_sym =conv(h_rcos,src_upsamp_sym);
%上载波
time = [1:length(rcos_src_sym)]/Fs;
rcos_src_sym_carrier = rcos_src_sym.*cos(2*pi*fc.*time);
% 频域观察
fft_rcos_src_sym= abs(fft(rcos_src_sym))/Fs;
fft_rcos_src_sym_carrier= abs(fft(rcos_src_sym_carrier))/Fs;
Ds = Fs/length(rcos_src_sym);%频率分辨率
f_s = -Fs/2:Ds:Fs/2-Ds;
%只关注前20个符号
figure(1);
stem(src_bit(1:20));
title("原始消息序列");
figure(2);
subplot(2,1,1);
plot(rcos_src_sym(1:230));
title("升余弦滚降脉冲成形");
subplot(2,1,2);
plot(f_s,fftshift(fft_rcos_src_sym));
axis([-Fs/2,Fs/2,0,1]);
title("升余弦滚降脉冲成形频域观察");
figure(3);
subplot(2,1,1);
plot(time(1:230),rcos_src_sym_carrier(1:230));
title("2ASK调制后的波形");
subplot(2,1,2);
plot(f_s,fftshift(fft_rcos_src_sym_carrier));
axis([-Fs/2,Fs/2,0,1]);
title("2ASK调制后的波形频域观察");
%信道
rcos_src_sym_carrier_noise = awgn(rcos_src_sym_carrier,SNR);
%接收端
%相干解调
rcos_src_sym_noise = rcos_src_sym_carrier_noise.*cos(2*pi*fc.*time);
LPF_fir128=fir1(128,0.2);%生成低通滤波器
rcos_src_sym_LP = 2*conv(LPF_fir128,rcos_src_sym_noise);
%匹配滤波
h1_rcos = rcosdesign(RollOff,Span,Sps,'sqrt');
rcos_src_sym_MF =conv(h1_rcos,rcos_src_sym_LP );
%抽样判决
delay = Sps*Span+64;
rcos_src_sym_MF_option= rcos_src_sym_MF(delay:UpSampleRate:end);%抽样值中前N个值为有效值
rcos_src_sym_MF_option = rcos_src_sym_MF_option(1:N);
rcos_src_sym_MF_option_judge = [abs(rcos_src_sym_MF_option)>0.5];
figure(4);
subplot(3,1,1);
plot(rcos_src_sym_MF(1:delay+200));
title("匹配滤波后的波形");
subplot(3,1,2);
stem(rcos_src_sym_MF_option(1:20));
title("抽样后的结果");
subplot(3,1,3);
stem(rcos_src_sym_MF_option_judge(1:20));
title("判决后的结果");

绘制误码率曲线代码:(设置不同的信噪比,使用for循环求出不同信噪比条件下的误码率)

%误码率曲线的绘制
clear all;
close all;
%%%%%%%     parameter settings      %%%%%   
Rb = 1000;%比特率
Rs = 1000;%符号率
Fs = 10000;%采样频率
N = 100000;%原始消息信号的长度
UpSampleRate = Fs/Rs;  % 一个符号周期内采样点数
RollOff = 0.25;
Span = 6;
Sps = UpSampleRate;
SNR = 20;
fc= 2000;
%%%%      信源       %%%%%      
%%% 随机信号
src_bit = randi([0,1],1,N); 
src_sym= src_bit;
%升采样
src_upsamp_sym = zeros(1,N*UpSampleRate);
src_upsamp_sym(1:UpSampleRate:end) = src_sym;
%脉冲成形
h_rcos = rcosdesign(RollOff,Span,Sps,'sqrt');
rcos_src_sym =conv(h_rcos,src_upsamp_sym);
%上载波
time = [1:length(rcos_src_sym)]/Fs;
rcos_src_sym_carrier = rcos_src_sym.*cos(2*pi*fc.*time);
% 频域观察
fft_rcos_src_sym= abs(fft(rcos_src_sym))/Fs;
fft_rcos_src_sym_carrier= abs(fft(rcos_src_sym_carrier))/Fs;
Ds = Fs/length(rcos_src_sym);%频率分辨率
f_s = -Fs/2:Ds:Fs/2-Ds;
%只关注前20个符号
figure(1);
stem(src_bit(1:20));
title("原始消息序列");
figure(2);
subplot(2,1,1);
plot(rcos_src_sym(1:230));
title("升余弦滚降脉冲成形");
subplot(2,1,2);
plot(f_s,fftshift(fft_rcos_src_sym));
axis([-Fs/2,Fs/2,0,1]);
title("升余弦滚降脉冲成形频域观察");
figure(3);
subplot(2,1,1);
plot(time(1:230),rcos_src_sym_carrier(1:230));
title("2ASK调制后的波形");
subplot(2,1,2);
plot(f_s,fftshift(fft_rcos_src_sym_carrier));
axis([-Fs/2,Fs/2,0,1]);
title("2ASK调制后的波形频域观察");
snr_db_tab = 1:100;
SER = zeros(size(snr_db_tab));%实际误码率
for index = 1:length(snr_db_tab)
%信道
SNR = snr_db_tab(index);
rcos_src_sym_carrier_noise = awgn(rcos_src_sym_carrier,SNR);
%接收端
%相干解调
rcos_src_sym_noise = rcos_src_sym_carrier_noise.*cos(2*pi*fc.*time);
LPF_fir128=fir1(128,0.2);%生成低通滤波器
rcos_src_sym_LP = 2*conv(LPF_fir128,rcos_src_sym_noise);
%匹配滤波
h1_rcos = rcosdesign(RollOff,Span,Sps,'sqrt');
rcos_src_sym_MF =conv(h1_rcos,rcos_src_sym_LP );
%抽样判决
delay = Sps*Span+64;
rcos_src_sym_MF_option= rcos_src_sym_MF(delay:UpSampleRate:end);%抽样值中前N个值为有效值
rcos_src_sym_MF_option = rcos_src_sym_MF_option(1:N);
rcos_src_sym_MF_option_judge = [abs(rcos_src_sym_MF_option)>0.5];
%计算误码率
[num,ratio]=biterr(src_sym,rcos_src_sym_MF_option_judge);
SER(index) = ratio;
end
figure(4);
subplot(3,1,1);
plot(rcos_src_sym_MF(1:delay+200));
title("匹配滤波后的波形");
subplot(3,1,2);
stem(rcos_src_sym_MF_option(1:20));
title("抽样后的结果");
subplot(3,1,3);
stem(rcos_src_sym_MF_option_judge(1:20));
title("判决后的结果");
figure(5);
semilogy(snr_db_tab,SER);
title("误码率曲线");

运行结果

信噪比为20db时运行结果:(载波频率为2000hz,只绘制了前20个码元)

image-20210528105415918

image-20210528105425384

image-20210528105437593

image-20210528105447596

计算误符号率:
%计算误码率,由于是2ask误符号率与误比特率一样
[num,ratio]=biterr(src_sym,rcos_src_sym_MF_option_judge);
num;
ratio;

image-20210528105515460

Snr=20db时,10万个符号错138个,误符号率为0.0014,可以接受.

误码率曲线的绘制:

image-20210528105545589

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/261456.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

XAML 编码规范 (思考)

<?xml version"1.0" encoding"UTF-8"?> 1.尽量和Blend统一2.兄弟元素之间需要空行4.父子元素之间不需要空格3.每行尽量单个属性5.Grid的Row和Column定义不需要空行6.Style里的Setter中不需要单行一个属性7.Trigger里的Binding和Conditions中不需要…

数据结构银行排队问题

实验任务 银行排队模拟程序功能 假设某银行有四个窗口对外接待客户,从早晨银行开门起不断有客户进入银行。由于每个窗口只能接待一个客户&#xff0c;因此在客户人数众多时需在每个窗口前顺次排队&#xff0c;对于刚进入银行的客户&#xff0c;如果某个窗口的业务员正在空闲&a…

STL vector容器

介绍 这篇文章的目的是为了介绍std::vector&#xff0c;如何恰当地使用它们的成员函数等操作。本文中还讨论了条件函数和函数指针在迭代算法中使用&#xff0c;如在remove_if()和for_each()中的使用。通过阅读这篇文章读者应该能够有效地使用vector容器&#xff0c;而且应该不…

通讯中断 pc_S7程序RFID 与PC连接区别FB 65/UDT65

同样是使用使用FB65但RFID与PC的连接DB用法有一定的区别:首先说一下什么是FB65:通过TCP和ISO on TCP使用两个通信伙伴都调用FB 65 "TCON"来设置和建立通信连接。在这些参数中&#xff0c;您要指定哪个伙伴是主动通信传输点、哪个伙伴是被动通信传输点。设置并建立连接…

JavaScript 设计模式之构造函数模式

一、构造函数模式概念解读 1.构造函数模式概念文字解读 构造函数用于创建特定类型的对象——不仅声明了使用的对象&#xff0c;构造函数还可以接受参数以便第一次创建对象的时候设置对象的成员值。你可以自定义自己的构造函数&#xff0c;然后在里面声明自定义类型对象的属性或…

列表异步线程加载图片

手机客户端以列表形式展示数据是非常常见的一种方式。然而列表中要显示图片&#xff08;比如&#xff1a;头像&#xff09;就要采用异步线程加载的方式&#xff0c;这样做是为了防止加载图片数据的时候&#xff0c;花费时间过长&#xff0c;阻塞UI线程&#xff0c;从而达到保持…

matlab连续卷积动画实现(gui编程)

一.代码运行结果 二.代码 function varargout tianqi(varargin) % TIANQI MATLAB code for tianqi.fig % TIANQI, by itself, creates a new TIANQI or raises the existing % singleton*. % % H TIANQI returns the handle to a new TIANQI or the handle t…

sql2005备份还原详解

1、备份 点击要备份的数据库右键-任务-备份 备份类型&#xff1a;完整 2、还原 点击数据库右键-还原数据库 目标数据库&#xff1a;&#xff08;数据库名&#xff09; 选择 原设备&#xff1a;&#xff08;你备份的xxx.bak文件&#xff09; 在选…

python爬虫框架怎么安装_celery如何在python爬虫中安装?

在我们学习了不少关于celery框架的知识后&#xff0c;很多小伙伴已经想要正式使用celery了。这里小编也不知道大家安装好了celery没有~为了照顾一下动手能力不太强的python小白&#xff0c;小编把celery框架安装的方法整理了出来&#xff0c;没有安装成功的小伙伴也可以参考一下…

codeforces C. Diverse Permutation(构造)

题意&#xff1a;1...n 的全排列中 p1, p2, p3....pn中&#xff0c;找到至少有k个|p1-p2| , |p2-p3|, ...|pn-1 - pn| 互不相同的元素&#xff01; 思路&#xff1a; 保证相邻的两个数的差值的绝对值为单调递减序列..... 如果够k个了&#xff0c;最后将没有访问到的元素直接添加…

(转)父子节点遍历

原创作品&#xff0c;允许转载&#xff0c;转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://qianzhang.blog.51cto.com/317608/1205679 对于树/图的遍历&#xff0c;通常有2种算法来实现&#xff1a;迭代(Iteration)和递归(Recursi…

SharePoint 2007 做Migration后用户处理

新公司的一部分任务是做Migration&#xff0c;从用户角度来说分为两种情况&#xff0c;第一种是在同一个Domain下作网站的Migration&#xff0c;另外一种就是在不同Domain下做Migration。在同一Domain下做Migration&#xff0c;User不会出现问题&#xff0c;因为在Import后&…

Ubuntu GNOME 15.10升级16.4LTS

为什么80%的码农都做不了架构师&#xff1f;>>> 当Ubuntu GNOME官方已经发送16.4后&#xff0c;执行以下命令 sudo do-release-upgrade 显示没有新系统更新 在网上找到另一种方法是执行以下命令&#xff1a; sudo ppa-purge ppa:gnome3-team/gnome3-staging sudo p…

matplotlib plot 分组_小白学 Python 数据分析(16):Matplotlib(一)坐标系

人生苦短&#xff0c;我用 Python前文传送门&#xff1a;小白学 Python 数据分析(1)&#xff1a;数据分析基础小白学 Python 数据分析(2)&#xff1a;Pandas (一)概述小白学 Python 数据分析(3)&#xff1a;Pandas (二)数据结构 Series小白学 Python 数据分析(4)&#xff1a;Pa…

hdu 1423 最长公共递增子序列

这题一开始把我给坑了&#xff0c;我还没知道LCIS的算法&#xff0c;然后就慢慢搞吧&#xff0c;幸运的是还真写出来了&#xff0c;只不过麻烦了一点。 我是将该题转换为多条线段相交&#xff0c;然后找出最多多少条不相交&#xff0c;并且其数值死递增的。 代码如下&#xff1…

安卓从业者应该关注:Android 6.0的运行时权限

Android 6.0&#xff0c;代号棉花糖&#xff0c;自发布伊始&#xff0c;其主要的特征运行时权限就很受关注。因为这一特征不仅改善了用户对于应用的使用体验&#xff0c;还使得应用开发者在实践开发中需要做出改变。 没有深入了解运行时权限的开发者通常会有很多疑问&#xff0…

git把另一个盘的代码上传_如何使用Git上传代码到GitHub

初始化Git1. 安装Git客户端一路下一步下一步既可2. 配置Git1. 在电脑硬盘里找一块地方存放本地仓库,右键Git Bash进入git命令行执行如下代码 生成.git文件夹,表示本地git创建成功git config --global user.name "littonishir"git config --global user.email "l…

sh脚本学习之: sh脚本 、sed、awk

sh脚本 sh命令的批处理文件&#xff0c;支持更复杂的逻辑。  Shell中的变量 参数   $0  当前脚本路径 $1....$n  脚本执行对应的第n个参数 条件判断   文件判断 test [op] path e存在  f是文件  d是目录  r可读  w可写  x可执行   if判断/case if[条件判…

Silverlight OOB Setup

Sl的安装大家都知道&#xff1a;在程序点右键&#xff0c;选择安装。有没有另外一种方法&#xff0c;类似普通软件那样&#xff0c;通过安装包安装&#xff1f;答案当然是 有参考&#xff1a;http://www.code Technorati 标签: project.com/KB/install/slsetup.aspx思路很简单&…

2016-04-29 二分查找的面试题

为什么80%的码农都做不了架构师&#xff1f;>>> 1.面试题 例如&#xff1a; ip计算后的值&#xff1d;53文本内容&#xff1a;1,100,北京 101,1000,上海 1001,3001,广州 ...求ip53对应的省份2.代码如下&#xff1a; #!/usr/bin/python # coding: utf8def ip_find(i…