菜鸟之MATLAB学习——QPSK OQPSK信号生成及频谱分析

本人MATLAB学习小白,仅做笔记记录和分享~~

% qpsk && oqpsk 

clc;
close all;

Ts=1;
fc=10;

N_sample=16;
N_sum=100;
dt=1/fc/N_sample;
t=0:dt:N_sum*Ts-dt;
T=dt*length(t);

d1=sign(randn(1,N_sum));
d2=sign(randn(1,N_sum));

gt=ones(1,fc*N_sample);                          %基本码元波形
s1=sigxpand(d1,fc*N_sample);
s2=sigxpand(d2,fc*N_sample);

b1=conv(gt,s1);
b2=conv(gt,s2);

s1=b1(1:length(s1));
s2=b2(1:length(s2));

st_qpsk=s1.*cos(2*pi*fc*t)-s2.*sin(2*pi*fc*t);   %QPSK波形
s2_delay=[ones(1,fc*N_sample/2),s2(1:end-fc*N_sample/2)];  %%  重要!!!
st_oqpsk=s1.*cos(2*pi*fc*t)-s2_delay.*sin(2*pi*fc*t);

                                     %QPSK 与OQPSK原始信号波形
subplot(421),plot(t,st_qpsk);xlabel('QPSK原始信号');
axis([0,40,-2,2])
subplot(422),plot(t,st_oqpsk);xlabel('OQPSK原始信号');
axis([0,40,-2,2])

%-----------将QPSK和OQPSK经过BPF--------------%

bpf1=sinc(2/Ts*t).*cos(2*pi*fc*t);
st_bpf_qpsk=conv(st_qpsk,bpf1);
st_bpf_qpsk=st_bpf_qpsk(1:length(st_qpsk));

st_bpf_oqpsk=conv(st_oqpsk,bpf1);
st_bpf_oqpsk=st_bpf_oqpsk(1:length(st_oqpsk));
                                      %QPSK 与OQPSK原始信号波形
subplot(423),plot(t,st_bpf_qpsk);xlabel('QPSK经过低通滤波器后信号');
axis([0,40,-40,40]);
subplot(424),plot(t,st_bpf_oqpsk);xlabel('OQPSK经过低通滤波器后信号');
axis([0,40,-40,40]);

%----------------------end--------------------%

%-----------QPSK和OQPSK经过BPF前频谱------------------%
[f,sf_qpsk]=T2F(t,st_qpsk(1:length(t)));
[f,sf_oqpsk]=T2F(t,st_oqpsk(1:length(t)));
subplot(425),plot(f,abs(sf_qpsk));xlabel('QPSK经过滤波器前的频谱');hold on;
subplot(426),plot(f,abs(sf_oqpsk),'r--');xlabel('OQPSK经过滤波器前的频谱');
%----------------------end--------------------%


%-------------QPSK和OQPSK经过BPF后频谱-----------------%
[f,sf_qpsk_lpf]=T2F(t,st_bpf_qpsk(1:length(t)));
[f,sf_oqpsk_lpf]=T2F(t,st_bpf_oqpsk(1:length(t)));


subplot(427),plot(f,abs(sf_qpsk_lpf));hold on;xlabel('QPSK经过滤波器后的频谱');
subplot(428),plot(f,abs(sf_oqpsk_lpf),'r--');xlabel('OQPSK经过滤波器后的频谱');
%----------------------end--------------------%


运行结果

在这里插入图片描述

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

如若内容造成侵权/违法违规/事实不符,请联系我们进行投诉反馈qq邮箱809451989@qq.com,一经查实,立即删除!

相关文章

Java基础综合练习(飞机票,打印素数,验证码,复制数组,评委打分,数字加密,数字解密,抽奖,双色球)

练习一:飞机票 需求: ​ 机票价格按照淡季旺季、头等舱和经济舱收费、输入机票原价、月份和头等舱或经济舱。 ​ 按照如下规则计算机票价格:旺季(5-10月)头等舱9折,经济舱8.5折,淡季(11月到来…

产品电子画册用什么工具可以轻松制作

​随着互联网的普及和移动设备的增多,电子画册已经成为了企业宣传和产品展示的重要工具。然而,制作电子画册并不是一件容易的事情,需要耗费大量的时间和精力。现在,我们可以通过使用一些专业的工具来轻松制作产品电子画册&#xf…

想升职or转岗,可以考一个PMP吗?

现在就业形式比较严峻,如果不想被淘汰,就得提升自己的能力,增加自己的职场竞争力,今天就来推荐一个能在工作中起到非常大重要的证书--pmp项目管理证书。 首先,pmp是什么呢? PMP是由美国项目管理协会&…

Windows搭建Emby媒体库服务器,无公网IP远程访问本地影音文件

文章目录 1.前言2. Emby网站搭建2.1. Emby下载和安装2.2 Emby网页测试 3. 本地网页发布3.1 注册并安装cpolar内网穿透3.2 Cpolar云端设置3.3 Cpolar内网穿透本地设置 4.公网访问测试5.结语 1.前言 在现代五花八门的网络应用场景中,观看视频绝对是主力应用场景之一&…

UCOSIII移植

1、“sys.h” 头文件修改 //0,不支持ucos //1,支持ucos #define SYSTEM_SUPPORT_OS 1 //定义系统文件夹是否支持UCOS2、stm32f10x_it.c中断屏蔽 注释掉void PendSV_Handler(void) 和 void SysTick_Handler(void)中断 //void PendSV_Handler(void) //{ //} // //void Sys…

New!DevExpress WinForms v23.2系统环境配置要求

DevExpress WinForms拥有180组件和UI库,能为Windows Forms平台创建具有影响力的业务解决方案。DevExpress WinForms能完美构建流畅、美观且易于使用的应用程序,无论是Office风格的界面,还是分析处理大批量的业务数据,它都能轻松胜…

创建x11vnc系统进程

为方便使用vnc,所以寻找到一个比较好用的vnc服务端那就是x11vnc,索性就创建了一个系统进程 一、环境 系统:银河麒麟v4-sp2-server 软件:x11vnc【linux下】、VNCviewer【win下】 二、安装x11vnc 1、挂载光盘源并修改apt源 mou…

test ui-02-UI 测试组件之 Appium 入门介绍

Appium简介 正如主页所述,Appium的目标是支持许多不同平台(移动、Web、桌面等)的UI自动化。 不仅如此,它还旨在支持用不同语言(JS、Java、Python等)编写的自动化代码。 将所有这些功能组合到一个程序中是…

反转链表、链表的中间结点、合并两个有序链表【LeetCode刷题日志】

一、反转链表 给你单链表的头节点 head ,请你反转链表,并返回反转后的链表。 力扣(LeetCode)官网 - 全球极客挚爱的技术成长平台 思路一:翻转单链表指针方向 这里解释一下三个指针的作用: n1&#xff1…

OpenWrt 编译入门(小白版)

编译环境 示例编译所用系统为 Ubuntu 22.04,信息如下 编译时由于网络问题,部分软件包可能出现下载问题,还请自备网络工具或尝试重新运行命令 编译步骤 下图为官网指示 编译环境设置(Build system setup) 这里根据我…

软件开发的价格谜团:实战谈判技巧分享!

随着科技的飞速发展,软件开发已经渗透到我们生活的方方面面,无论是手机APP、网站还是企业级应用,软件开发的需求无处不在。 然而,面对市场上琳琅满目的开发报价,你是否曾感到困惑?软件开发的价格范围到底有多大?我们…

探秘AI数字人克隆系统OEM源码:实现24小时无人值守直播间的奥秘

随着人工智能技术的不断发展,AI数字人克隆系统OEM源码正在引起广泛的关注。其中,实现24小时无人值守直播间成为了许多企业和机构的追求。本文将深入探讨如何利用AI数字人克隆系统OEM源码实现24小时无人值守直播间,并揭示其背后的奥秘。 一、…

什么是软件测试?这是我听过最通俗易懂的解释

很多人总是说我要学习软件测试,因为他可以拿到一个不错的薪资。 但是当我问他你知道什么是软件测试吗?这个时候,他总会愣住了,一脸不屑的表情说着,不就是找bug,给软件找问题,找茬吗&#xff1f…

Windows 使用 nmap软件测试 UDP 端口

下载windows版nmap ,下载后双机默认安装。 Download the Free Nmap Security Scanner for Linux/Mac/Windows 打开CMD , 输入 cd C:\Program Files (x86)\Nmap C:\Program Files (x86)\Nmap>ncat -z -v -u ntp.aliyun.com 123 Ncat: Version 7.80 ( …

正运动技术荣获2023年度“AI天马”认定

2023年12月28,在深圳宝立方国际酒店圆满举办了由深圳市人工智能产业协会主办的2023年度“AI天马”颁奖典礼。该奖项是由中国新一代人工智能发展战略研究院指导,深圳市人工智能产业协会主办,广东未来产业研究院承办,旨在表彰为人工…

【源码】-MyBatis-如何系统地看源码

写在前面 前段时间做过一个项目,期间用到了动态数据源dynamic-datasource,经历了dbcp2的数据库连接池没有生效到排查定位、MyBatis多种数据库产品兼容、手写MyBatis拦截器等事情。 花费了好久,一直在打磨这篇文章(不知道花费这么长…

新网域名外部入库流程

注册商是新网,且在新网管理的,请使用此教程外部入库。 如您的域名注册商是新网但在聚名管理,请参考教程:https://www.west.cn/faq/list.asp?unid2539 在外部入库操作之前,请先登录新网获取用户ID和绑定邮箱信息。…

【LeetCode:LCR 143. 子结构判断 | 二叉树 + 递归】

🚀 算法题 🚀 🌲 算法刷题专栏 | 面试必备算法 | 面试高频算法 🍀 🌲 越难的东西,越要努力坚持,因为它具有很高的价值,算法就是这样✨ 🌲 作者简介:硕风和炜,…

python调用openai api报错self._sslobj.do_handshake()OSError: [Errno 0] Error

python调用openai api报错self._sslobj.do_handshake()OSError: [Errno 0] Error 废话不说,先上代码,根据官网的介绍写的,chatgpt3.5 api简单调用 import os from openai import OpenAI from dotenv import load_dotenv# 加载 .env 文件中的变量 load_…

2023年下半年信息系统项目管理师考试

目录 引言 结果 论文 案例分析 综合知识 总结 引言 2023年下半年参加了信息系统项目管理师考试,考试结果情理之中,意料之外。论文压线,综合和案例差一分。从个人参加考试的整个过程来看,属于历史性的突破。以本文&#xff…