软件无线电之数字下变频(Matlab实例)

news2024/11/17 3:55:05

软件无线电之数字下变频

1 原理

在通信系统中,为了易于信号发射以及实现信道复用,传输的信号发射频率一般很高。

在接收机中,为了降低信号的载波频率或是直接去除载波频率得到基带信号,通常将接收信号与本地振荡器产生的本振信号相乘,然后通过低通滤波器获得变频后的信号,这种技术手段则是下变频。

数字下变频(Digital Down Converter,DDC)指在接收机中对ADC采样信号混频后得到的中频信号比原始信号的频率低的一种混频方式,是软件无线电(Software Defined Radio,SDF)的核心技术之一。

数字下变频的基本流程如下图,大致可分为两个基本的模块——数控振荡器NCO(Nu-merical Control Oscillator)混频模块和抽取滤波模块。其中NCO模块产生正余弦波样本值,然后分别与输入数据相乘,完成混频。

在这里插入图片描述
混频后的信号通过低通滤波器和抽取器得到输出信号。


2 实例

阐述原理的时候讨论了复信号的情况,在这儿我们只看一个时域信号数字下变频的例子,复信号只是多一个通道。

假设载波信号频率30MHz

% HIGH FREQUENCY (CARRIER)
f_carrier=30
w_carrier=2*pi*f_carrier;

原始信号频率2MHz

% BASE FREQUENCY (RIDER)
f_rider=2
w_rider=2*pi*f_rider;

接收机采样率80MHz(>2倍载波频率=60MHz,满足类奈奎斯特采样定理)

% SAMPLE RATE
N=60;
fs=80;
f=0:fs/N:fs-fs/N
t=0:1/fs:(N-1)/fs;

所以载波信号是

s_carrier=cos(w_carrier.*t);

ADC采样得到的信号是

s_carrier=cos(w_carrier.*t);

采样信号和本振信号做混频

%% MUL
s_multied=s_input.*s_carrier;

混频前后的频谱分别是

fre_map_input=fft(s_carrier);
fre_map_carrier=fft(s_multied);
figure
subplot(3,1,1)
plot(f,abs(fre_map_input))
title("采样输出频谱")
subplot(3,1,2)
plot(f,abs(fre_map_carrier))
title("本振叉乘输出频谱")

在这里插入图片描述
对比两图可知,采样信号和本振信号混频后,原始信号分量在频谱两侧上显现出来。要得到原始信号,只需要再对混频输出做低通滤波

%% FIR
st_filted = lowpass(s_multied,f_rider*4,fs);
fre_map_filted=fft(st_filted);
subplot(3,1,3)
plot(f,abs(fre_map_filted))
title("低通滤波输出频谱")

在这里插入图片描述
结果符合预期。


完整的MATLAB程序如下

%% PARAMETERS

% HIGH FREQUENCY (CARRIER)
f_carrier=30
w_carrier=2*pi*f_carrier;
% BASE FREQUENCY (RIDER)
f_rider=2
w_rider=2*pi*f_rider;
% SAMPLE RATE
N=60;
fs=80;
f=0:fs/N:fs-fs/N
t=0:1/fs:(N-1)/fs;

%% SIGNAL
s_input=cos(w_carrier.*t+w_rider*t.^2);
s_carrier=cos(w_carrier.*t);

%% MUL
s_multied=s_input.*s_carrier;
fre_map_input=fft(s_carrier);
fre_map_carrier=fft(s_multied);
figure
subplot(3,1,1)
plot(f,abs(fre_map_input))
title("采样输出频谱")
subplot(3,1,2)
plot(f,abs(fre_map_carrier))
title("本振叉乘输出频谱")

%% FIR
st_filted = lowpass(s_multied,f_rider*4,fs);
fre_map_filted=fft(st_filted);
subplot(3,1,3)
plot(f,abs(fre_map_filted))
title("低通滤波输出频谱")


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

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

相关文章

Java循环综合案例

文章目录Java循环综合案例案例一:逢 7 跳过案例二:数组元素求和案例三:判断两个数组是否相同案例四:查找元素在数组中的索引案例五:数组元素反转案例六:评委打分案例七:随机产生验证码Java循环综…

那些年我们拿下了 Zynq

小菜鸟的 Zynq 学习经验分享~ 资料来源:黑金 Zynq7035 开发板配套资料,完全适合于 Zynq 学习。 获取方式:【51爱电子】回复【Zynq7000】即可获取资料链接!本资料仅供学习使用,切勿商用。 另外四个是关于 Altera FPGA…

跨域和cookie

本文以前端的视角来探讨浏览器的跨域和cookie问题。 一、跨域 跨域简介: 为什么会出现跨域? 出于浏览器的同源策略限制,浏览器会拒绝跨域请求。 什么情况下出现跨域? 不同源就会跨域。同源即:协议、域名、端口号…

图文详解:箭头函数与常规函数的this指向问题

函数中this的指向问题特别容易让人迷糊,这里用示例来指点迷津,走出迷茫。 常规函数下的this指向 1. 纯粹的函数调用 function test(name) { console.log(name) console.log(this) } test(zjcopy) ; test.call(zjcopy, cuclife-2) ; test.call(fal…

pytesseract 安装错误总结

项目场景: 使用eclipse调用pytesseract接口,进行OCR识别。 在anaconda的python3.6.4版本,安装配置pytesseract 问题描述 pip install pytesseract 报错 错误提醒:pytesseract requires Python >3.7 but the running Python…

【数据结构】顺序栈的原理及实现

【数据结构】顺序栈的原理及实现 1.什么是栈 栈它是一种先进后出的有序列表数据结构。栈是线性表里的元素插入和删除只能在该线性表的同一端进行的一种特殊线性表。该线性表的插入和删除都叫栈顶,也就是变化的一端。另一端是固定不变的成为栈底。根据下图可以看出…

《高性能MySQL》——架构与历史(笔记)

文章目录一、MySQL架构与历史1.1.1 连接管理与安全性1.1.2 优化与执行1.2 并发控制1.2.1 读写锁1.2.2 锁粒度(锁模式)表锁(table lock)行级锁(row lock)1.3 事务1.3.1 隔离级别READ UNCOMITTED (读未提交)READ COMMITTED (读提交)REPEATABLE READ (可重复…

初识C++(学习计划)

前言 基于对C语言的学习,我将进一步学习C的相关知识。 我们在使用C语言时创建的是.c文件,使用C使用的是.cpp文件,其中p——plus(加,的意思),所以cpp就是c。 C是为了解决一些C语言不能解决的问题…

SpringBatch使用(一)

一、SpringBatch简介 1、Spring Batch是一个轻量级,全面的批处理框架,旨在开发对企业系统日常运营至关重要的强大批处理应用程序。Spring Batch构建了人们期望的Spring Framework特性(生产力,基于POJO的开发方法和一般易用性&…

docker安装elasticsearch kibana 8.6.0(设置密码+汉化+ik分词器)

安装eskibana安装:拉取镜像并安装设置密码汉化配置ik分词器安装: 记得开放使用的端口,或者关闭防火墙 提示:需要提升虚拟机或者服务器的内存到8G以上 拉取镜像并安装 docker pull elasticsearch:8.6.0 docker pull kibana:8.6.0docker network create es-netdocker run -it…

Itext7在PDF指定位置添加电子公章

目录 1. 电子公章的制作 2. java工具keytool生成p12数字证书文件 3. pom依赖 4. 实体类 5. 工具类及测试示例 6. 效果 1. 电子公章的制作 做章网站:http://seal.biaozhiku.com/ 我们选择圆形印章 然后输入公司名,输入章名输入编码然后点击395生成&…

快速幂及矩阵快速幂分析及代码实现

文章目录前言一、认识快速幂二、快速幂思路及代码三、矩阵快速幂3.1、矩阵乘法代码实现3.2、矩阵快速幂代码实现参考资料前言 在学习Acwing c蓝桥杯辅导课第九讲复杂DP-AcWing 1303. 斐波那契前 n 项和时有使用到矩阵快速幂算法,这里来记录下知识点正好也将快速幂部…

车载以太网 - SomeIP测试专栏 - 详细解析 - 01

对于介绍SomeIP协议,我还是想从最基础的协议解析来,所以今天还是先将SomeIP协议详解给大家列举一下,也方便大家在工作中如果不记得哪些信息随时可以查看学习,也算是留给我自己的笔记吧,毕竟确实容易忘记。 SomeIP数据&…

分布式数据库中间件——Mycat2

一、Mycat2 概述 Mycat是基于java语言编写的数据库中间件,核心功能是分库分表和读写分离,可以将大表水平分割为N个小表。 可以看做为Mysql的数据库服务器,可以用连接Mysql的方式去连接Mycat,端口为8066 二、Mycat的三大作用 2.…

Node 项目中常见的问题及解决方法

1. window和mac下设置NODE_ENV变量的问题 我们都知道在前端项目中会根据不同的环境变量来处理不同的逻辑,在node后端中也一样,我们需要设置本地开发环境、测试环境、 线上环境等,此时有一直设置环境变量的方案是在package.json中的script属性…

Python学习笔记——错误和异常

错误的分类编写程序过程中遇到的错误都分为两类:语法错误与运行时错误。语法错误:当代码不符合Python语法规则时, 在解析过程中会报SyntaxError。运行时错误:即语句或表达式在语法上都是正确的, 但在运行时发生了错误。当程序发生异常时&…

从零搭建完整python自动化测试框架(UI自动化和接口自动化

从零搭建完整python自动化测试框架(UI自动化和接口自动化) 文章目录 总体框架 PO模式、DDT数据驱动、关键字驱动 框架技术选择 框架运行结果 各用例对应的定义方式(PO/DDT) 测试执行结果 从零开始搭建项目 一、开发环境搭…

Vue-Vuex

前言 Vuex 是一个专为 Vue.js 应用程序开发的状态管理模式 库 官网介绍:https://vuex.vuejs.org/zh/ 以下主要讲解的是如何定义与使用,如果还没有对vuex进行了解的话,请先查看官网,了解其功能、用法及用途。 关于vuex&#xff0c…

代码随想录算法训练营第五十二天_第九章_动态规划 | 121. 买卖股票的最佳时机、122.买卖股票的最佳时机II

LeetCdoe 121. 买卖股票的最佳时机给定一个数组 prices ,它的第 i 个元素 prices[i] 表示一支给定股票第 i 天的价格。 你只能选择 某一天 买入这只股票,并选择在 未来的某一个不同的日子 卖出该股票。设计一个算法来计算你所能获取的最大利润。 返回你可…

verilog 数字系统设计读书笔记-------持久更新

Verilog模型可以是实际电路的不同级别的抽象。这些抽象的级别和它们所对应的模型类型共有以下5种:系统级、算法级、RTL级、门级、开关级‘bz :表示高阻态, ’bx表示不定值(0或1均可)include "muxtwo.v" 将文件引进{$ ra…