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,一经查实,立即删除!

相关文章

数据结构银行排队问题

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

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

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

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

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

列表异步线程加载图片

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

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…

Ubuntu GNOME 15.10升级16.4LTS

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

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

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

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

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

gettype拿不到值_王者荣耀:被低估的强势打野,就是这位拿大锤子的阿姨!

王者峡谷的小伙伴你们好,今天就为你们推荐一下这位野区女霸主钟无艳,不仅高伤害而且操作简单!版本更新在5月14日版本更新中,钟无艳的三个技能都被加强了,所有的蓝耗都被固定,不再随技能等级的成长值&#x…

【笔记】MATLAB中的图形(2)

三维作图 1、mesh(z)语句 mesh(z)语句可以给出矩阵z元素的三维消隐图,网络表面由z坐标点定义,与前面叙述的x-y平面的线格相同,图形由临近的点连接而成。它可用来显示用其他方式难以输出的包含大量数据的大型矩阵,也可以用来绘制z变…

Kindeditor放置两个调用readonly错误

开始 需要调用Kindeditor中的readonly的方法,但是一直提示edit is undefined 而editor.readonly(true)又只对第一个对象有效 所以只能换换形式,干脆将下面的kindeditor拿上来 虽然是满足自己这个需求,但是真正的原因解决办法,还是…

acl在内核里的位置_Linux 进程在内核眼中是什么样子的?

本篇算是进程管理的的揭幕篇,简单介绍一个进程在内核眼里的来龙去脉,为接下来的进程创建,进程调度,进程管理等篇章做好学习准备。从程序到进程再到内核啥是程序,啥是进程,一张图可以给我们解释:…

majikan

转载于:https://www.cnblogs.com/YOUEN/p/3179091.html

经典中的品味:第一章 C++的Hello,World!

“程序设计要通过编写程序的实践来学习”—Brian Kernighan 1.1 程序 何为程序?简单的说,就是为了使计算机能够做事,你需要在繁琐的细节中告诉它怎么做。对于怎么做的描述就是程序。编程是书写和测试怎么做的过程。维基百科上说,一个程序就像…

使用eclipse svn塔建(配置)时的一点点心得

有没有人遇到下面这种情况??自己创建的SVN如下: 但网上别人搭建好的是这样子的: 就是为什么我的只有个主文件,而没有src、webroot、meta-inf、web-inf等子文件呢?? 这是我找了很多网上的资料&am…

实例构造器和类(引用类型)

构造器是允许将类型的实例初始化为良好状态的一种特殊方法。构造器方法在“方法定义元数据表”中始终教.ctor。创建一个引用类型的实例时,首先为实例的数据字段分配内存,然后初始化对象的附加字段(类型对象指针呵呵同步块索引)&am…

android 文件选择器_Android 开发 打开系统文件、图片、视频等 实现单选多选功能...

在网上搜下,如何实现图片的多选或者文件的多选,令人纳闷的是居然多是moudle、或第三方jar包,当然第三方的工程功能复杂或兼容性比较好,并没有说明Android系统是如何提供多选的。既然这么多图片选择器的工程、或者是文件选择器的工…

C语言错误: HEAP CORRUPTION DETECTED

程序源代码&#xff1a; //写文件两种方式(文本文件和二进制文件)#define _CRT_SECURE_NO_WARNINGS #include<stdio.h> #include<stdlib.h> #include<string.h>//文本写文件 int writeWord(const char *path,const char *pword){int ERRO_MSG 0;if (path N…

您不能不知的ToString()方法

1.1.1 摘要 相信大家对ToString()方法再熟悉不过了&#xff0c;由于该方法是.NET程序中最常用的方法之一&#xff0c;我们除了可以直接调用ToString()方法之外&#xff0c;.NET中的某些方法也隐式调用ToString()方法&#xff08;WPF&#xff0c;Windows Form和Silverlight等&am…

微信转账一次显示两个_微信为啥分红包和转账两大功能?这4个区别你要知道,望相互转告...

众所周知&#xff0c;自从移动支付普及之后&#xff0c;支付宝、微信就已经成为人们手机中必备的APP&#xff0c;其中微信更是具备社交、支付等一系列功能&#xff0c;所以在国内吸引了超十一亿用户的使用&#xff01;当我们节假日、过年时&#xff0c;很多用户都喜欢给亲朋好友…