间接调制和带通采样!!(非奈奎斯特采样定理)

1. 直接变频

前面讲解数字调制原理时,直接利用IQ调制将基带信号变换为频带信号,这种频率变换一般被称为直接上变频;解调时,直接利用IQ解调,将频带信号变换回基带信号,这种频率变换一般被称为直接下变频。直接上变频和直接下变频统称直接变频。

在采用直接变频的情况下,假定基带IQ信号的波形如下图所示。

基带IQ信号波形

则射频信号的波形如下图所示。 

射频信号波形

 

2. 间接变频

通信系统中,考虑到实现难度等因素,有时候不将基带信号直接变换为射频信号,或者将射频信号直接变换为基带信号,而是先将基带信号变换到中频,再从中频变换到射频,这被称为间接上变频;反之:先将射频信号变换到中频,再从中频变换到基带,这被称为间接下变频。间接上变频和间接下变频统称间接变频。

在采用间接变频的情况下,假定基带IQ信号的波形如下图所示。

基带IQ信号波形

则中频信号的波形如下图所示 

中频信号波形

射频信号的波形如下图所示 。

射频信号波形

2.1 间接上变频

将基带信号调制到中频载波上,再将中频载波变换为射频载波的过程,就是间接上变频,如下图所示。 

间接上变频

a 基带变换到中频

这个变换过程实质上就是IQ调制的过程,只不过载波的频率是中频而已。

 

 b 中频变换到射频

通过滤波器滤除低频成分:

 2.2 间接下变频

将射频载波变换为中频载波,再从中频信号解调出基带信号的过程,就是间接下变频,如下图所示。

间接下变频

a 射频变换到中频

通过滤波器滤除高频成分:

 

这个过程实质上就是一个混频的过程,将载波频率由射频变换为中频。

b 中频变换到基带

 

通过滤波器滤除高频成分,即可得到I(t),Q(t)。 

这个过程实质上就是IQ解调的过程,只不过已调信号的载波频率是中频而已。

3. 数字变频

一般基带信号都是数字信号,中频处理也是数字化的,因此基带和中频之间的上变频和下变频一般都是通过数字信号处理来实现。

3.1 数字上变频

DUC:Digital Up Converter,数字上变频器,通过数字信号处理实现上变频功能,如下图所示。

数字上变频

 

3.2 数字下变频 

DDC:Digital Down Converter,数字下变频器,通过数字信号处理实现下变频功能,如下图所示。

数字下变频

 

4. 带通采样

模拟下变频得到的模拟中频信号,需要进行模数转换,才能进行后续的数字信号处理。

模数转换涉及采样。前面所讲的奈奎斯特采样定理(也被称为低通信号采样定理)是针对基带信号讲的,而这里的采样是针对带通信号讲的。

4.1 什么是带通信号

基带信号经过载波调制后得到的已调信号被称为频带信号,也称为带通信号。直接变频得到的射频信号、间接变频得到的中频信号和射频信号都是带通信号。

基带信号经过载波调制后得到的已调信号被称为频带信号,也称为带通信号。直接变频得到的射频信号、间接变频得到的中频信号和射频信号都是带通信号。如果根据前面讲的采样定理,以大于2倍最高频率的采样频率对带通信号进行采样,肯定可以从抽样信号中恢复出带通信号,这是毫无疑问的。但由于一般带通信号的载波频率都比较高,动辄几十、几百MHz,如果使用大于2倍最高频率的采样频率,对ADC的处理能力要求很高。按目前ADC器件的处理能力,能达到几百MSPS(Million Samples Per Second)采样频率的ADC就算是处理能力比较强的了,而且支持如此高采样频率的ADC价格很高。能不能用低一些的采样频率对带通信号进行采样呢?这就引出了带通信号采样定理。

4.2 带通信号采样定理

中心频率为f0、带宽为B的带通信号,其高、低截止频率分别为:fH=f0+B/2和fL=f0-B/2,其频谱如下图所示。

带通信号的频谱

 

这就是带通采样定理。

4.3 带通采样定理的推导过程

虽然带通采样定理的结论看起来不像低通信号采样定理那样简洁,但是它们的推导方法类似,都是从避免抽样信号频谱发生混叠的角度推导出来的。唯一需要注意的是:对带通信号进行采样,相当于对其频谱进行周期性拓展,在对频谱进行周期性拓展时,正频率部分和负频率部分要一起拓展。 

假定带通信号的频谱如下图所示,其截止频率:fL=2B,fH=3B。

带通信号的频谱

以采样频率fs对该信号进行采样时,频谱将会以fs为间隔进行周期性拓展。

(1)当采样频率很高时,很明显,周期拓展的频谱之间不会发生混叠,如下图所示。

抽样信号的频谱(1)

减小fs,右边的频谱将向左挪,左边的频谱将向右挪,直至和原频谱刚好挨上为止,此时fs=2fH,如下图所示。 

抽样信号的频谱(2)

如果继续减小fs,频谱就会发生混叠了,必须跳过一段频率,到达如下图所示位置才不会发生混叠,此时刚好fs=2fL。 

抽样信号的频谱(3)

继续减小fs,右边的频谱将向左挪,左边的频谱将向右挪,直至频谱刚好挨上为止,此时fs=fH,如下图所示。 

抽样信号的频谱(4)

如果继续减小fs,频谱就会发生混叠了,必须跳过一段频率,到达如下图所示位置才不会发生混叠,此时刚好fs=fL=2B。 

抽样信号的频谱(5)

注意:这时候fs不能再进一步减小了,否则就发生混叠了。

下面对比一下带通采样定理给出的结论。

 

根据带通采样定理,以满足下面条件的采样频率fs对带通信号进行采样,都可以将带通信号无失真地恢复出来:

 

满足条件的采样频率fs由高到低被分成了3个部分:

对比一下前面推导得到的结论,可以发现二者是完全相同的。

 

4.4 图解满足带通采样定理的采样频率

为了更清楚地认识带通采样定理中采样频率fs和最高信号频率fH的关系,我们以fH为横轴,以fs为纵轴,把满足带通采样定理的采样频率画在一张图中,如下图所示。

满足带通采样定理的采样频率

 图中灰色区域表示满足带通采样定理的采样频率范围。

还是以fH=3B为例,采样频率范围为:fs=2B,3B≤fs≤4B,fs≥6B。

黑线所示为满足带通采样定理的最低采样频率:

随着带通信号最高频率的增大,黑色斜线的斜率越来越小,当带通信号的最高频率远远大于信号带宽时,黑色斜线将趋近于一条水平线,只要以略大于2倍信号带宽的采样频率对带通信号采样即可,如下图所示。 

带通信号的最低采样频率随最高频率的变化

当带通信号的最高频率(fH)正好是信号带宽(B)的整数倍时,满足带通采样定理的最低采样频率正好是带宽的2倍。其他情况采样频率都大于信号带宽的2倍。 

为了用最低的采样频率(fs=2B)对带通信号进行采样,在设计带通信号时,一般将带通信号的最高频率设计成带宽的整数倍(fH=kB),如下图所示。

带通信号最高频率是信号带宽的整数倍

 

4.5 带通采样定理和奈奎斯特采样定理的关系

带通信号采样定理中,令fH=B,则mmax=1。对应的带通信号频谱如下图所示。这种信号一般被称为低通信号。

低通信号的频谱

根据带通信号采样定理,采样频率fs应满足:

 

这就是奈奎斯特采样定理。

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

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

相关文章

vue 使用自定义标签URL Protocol 调用本地exe 并传参

创建注册表文件reg,并运行 里面的路径需要替换成实际exe的绝对路径 Windows Registry Editor Version 5.00 [HKEY_CLASSES_ROOT\App] "URL:App Protocol Handler" "URL Protocol""" [HKEY_CLASSES_ROOT\App\DefaultIcon] &qu…

pycharm调试(步过(Step Over)、单步执行(Step Into)、步入(Step Into)、步出(Step Out))

pycharm调试 pycharm调试 pycharm调试为什么要学会调试?1. 步过 (Step Over)2. 单步执行 (Step Into)3. 步入(Step Into)4. 步出(Step Out) 为什么要学会调试? 调试可以帮助初学者更深入地理解编程基础&am…

【Android、 kotlin】kotlin学习笔记

基本语法 fun main(){val a2var b "Hello"println("$ (a - 1} $b Kotlin!")} Variables 只赋值一次用val read-only variables with val 赋值多次用var mutable variables with var Standard output printin() and print() functions String templ…

NKCTF2024 re VM?VM!WP

逻辑似乎很简单(个鬼啊) 这个函数是把输入的字符转化为二进制并倒序存储 sub_1570太大了加载不出来,应该是加密的主逻辑,目的是需要输出1 可以通过删除栈的方法强行转化伪代码 首先删掉这部分 9A0改小点 这个也是 栈这里U一下再…

DFS:深搜+回溯+剪枝解决组合问题

创作不易,感谢支持!!! 一、电话号码的组合 . - 力扣(LeetCode) class Solution { public:string hash[10]{"","","abc","def","ghi","jkl","mno","pqrs"…

爬虫部署平台crawlab使用说明

Crawlab 是一个基于 Go 语言的分布式网络爬虫管理平台,它支持 Python、Node.js、Jar、EXE 等多种类型的爬虫。 Crawlab 提供了一个可视化的界面,并且可以通过简单的配置来管理和监控爬虫程序。 以下是 Crawlab 的一些主要优点: 集中管理&am…

【C】leetcode力扣—— 141. 环形链表Ⅰ

目录 141. 环形链表 Ⅰ题目解题思路分析暴力求解??快慢指针 代码 141. 环形链表 Ⅰ 题目链接: https://leetcode.cn/problems/linked-list-cycle/description/ 题目 题目 给你一个链表的头节点 head ,判断链表中是否有环。 如果链表中有某…

E-魔法猫咪(遇到过的题,做个笔记)

题解: 来自学长们思路: 其中一种正解是写单调队列。限制队列内的数单调递增,方法为每当新来的数据比当前队尾数据小时队 尾出列,直到能够插入当前值,这保证了队头永远是最小值。因此总体思路是队尾不断插入新值的同时 …

openlayers 入门教程(九):overlay 篇

还是大剑师兰特:曾是美国某知名大学计算机专业研究生,现为航空航海领域高级前端工程师;CSDN知名博主,GIS领域优质创作者,深耕openlayers、leaflet、mapbox、cesium,canvas,webgl,ech…

vue-cli打包 nodejs内存溢出 vue2.x Last few GCs

遇到这种情况百度各种博客,什么改package.json里的配置,什么安装increase-memory-limit ,都尝试了并没什么用处,最后解决方案为执行下方名单,再次打包就成功了: export NODE_OPTIONS--max_old_space_size4…

单元测试 mockito(二)

1.返回指定值 2.void返回值指定插桩 3.插桩的两种方式 when(obj.someMethod()).thenXxx():其中obj可以是mock对象 doXxx().wien(obj).someMethod():其中obj可以是mock/spy对象 spy对象在没有插桩时是调用真实方法的,写在when中会导致先执行一次原方法,达不到mock的目的&#x…

好物视频素材在哪找?视频素材大全app下载

创作优质视频内容不仅仅是一种艺术,也是一种科学,需要对素材的深刻理解和精心挑选。掌握了这些高清无水印视频素材,您就拥有了创作引人入胜视频内容的强大工具。以下是更多精选的视频素材网站,旨在为您的视频项目提供更广阔的视野…

Python | Leetcode Python题解之第10题正则表达式匹配

题目: 题解: class Solution:def isMatch(self, s: str, p: str) -> bool:m, n len(s), len(p)dp [False] * (n1)# 初始化dp[0] Truefor j in range(1, n1):if p[j-1] *:dp[j] dp[j-2]# 状态更新for i in range(1, m1):dp2 [False] * (n1) …

专升本--python运算符总结

运算优先级 同一个等级是没有先后顺序的,此外,赋值语言的先后问题: 赋值的顺序从上往下,同一行一般都是代表同时进行赋值,如图所示: 一.and A and B,若A,B有任意一个为假(0&#x…

希尔排序和快排里的小区间优化

希尔排序 希尔排序是插入排序的优化。 当一串数是逆序时,那么每插入一个数,前面的数都会向后面挪动。 那么这是插入排序的时间复杂度,就会达到O(n^2) 希尔排序是对数组里的数进行预排序。 防止插入排序出现最坏的情况。 预排序&#xf…

ABC318 F - Octopus

解题思路 对于每个宝藏维护个区间,答案一定在这些区间中对于每个区间的端点由小到大排序对于每个点进行判断,若当前位置合法,则该点一定为一个右端点则该点到前一个端点之间均为合法点若前一个点不合法,则一定是某一个区间限制的…

Xen Server 8 Install

Xen Sevrer 前言 XenServer(以前称为 Citrix Hypervisor)是业界领先的平台,实现了经济高效的桌面、服务器和云虚拟化基础结构。XenServer 支持任意规模或类型的组织整合计算资源,以及将计算资源转换为虚拟工作负载,从…

c++协程详解(二)

前言 这是c协程实现第二篇,这里开始我们将开始真正意义上开始实现协程。对协程基础流程不清楚的,可以看我的第一篇。 后续可能需要一定的模板知识,可以看下我的模板的文章,那些知识就完全够用了。本篇将实现一个协程封装的异步任…

Redis慢日志

SLOWLOG 是用来读取和重置 Redis 慢查询日志的命令,Redis 2.2.12 版本开始支持 1.Redis 慢查询日志概述 客户端从发送命令到获取返回结果经过了以下几个步骤: 1. 客户端发送命令 2. 该命令进入 Redis 队列排队等待执行 3. Redis 开始执行命令 - Red…

浅析JavaWeb内存马基础原理与查杀思路

文章目录 前言Java内存马内存马分类&原理JavaWeb三大组件注入Servlet内存马注入Filter型内存马JAVA Agent内存马 哥斯拉木马0x01 WebShell0x02 MemShell0x03 FilterShell0x04 Arthas排查0x05 scanner查杀 总结 前言 几年前写过《Web安全-一句话木马》,主要介绍…