使用傅里叶变换测量声卡的频率失真

文章目录

  • 一、说明
  • 二、关于声卡的技术详述
  • 三、实验代码获取
  • 四、结论

一、说明

假如我希望使用我的声卡来模拟软件无线电,利用声音而不是射频信号。我的声卡能胜任这项任务吗?本文将研究一种技术来找出答案。另外,需要了解音频技术的读者也可以阅读。

二、关于声卡的技术详述

使用声卡是一种有趣且低成本的方式来尝试软件定义无线电 (SDR) 技术并听取结果。大多数简单的 SDR 数字调制方案将其数据编码为正弦波形的相位或频率。因此,我感兴趣的是声卡如何重现这些波形,特别是它对波形相位和频率的扭曲程度。
这些信息对于配置调制方法以传输信息非常有用,即使在声卡有限制的情况下也是如此。我可以通过测量正弦波形的相位并用它来计算其瞬时频率(即相位随时间的变化率)来量化相位和频率的失真。对于以固定频率传输的正弦波,相位应随时间以恒定的速率变化,类似于物体以恒定速度沿无摩擦水平表面移动。如果正弦波的频率或物体的速度发生变化,则捕获“失真”可能表明系统中存在不理想的效果。测量正弦波失真的技术是本文的主题。但只关注相位失真,因此该技术必须不受声卡引起的幅度波动的影响。

注意:在本文中,术语“正弦”和“正弦波”将互换使用,指具有任意相位偏移的波形。例如,在本文中,余弦波将被称为正弦波,因为它是具有 90 度相移的正弦波。

查找相位的一种方法是将反正弦函数应用于捕获的信号;然而,这种方法假设一个完美的正弦波,其幅度在 -1 和 +1 之间振荡。幅度波动违反了这一假设,因此不能直接使用反正弦函数。

另一种技术是从将正弦波的视图从一维实信号扩展到二维复平面中旋转矢量的投影开始。图 1A 通过显示以恒定速度逆时针旋转的相位矢量(因此相位不断变化)来说明这一概念,其中矢量在实轴(图 1B)和虚轴(图 1C)上的投影产生具有不同相位偏移的 12 kHz 正弦波。声卡可以传输和记录每个通道的单个信号。因为我将音频系统限制为一个通道,类似于具有单个天线的 SDR,所以我需要选择两个矢量轴之一上的信号。我任意选择该矢量的实部(x 坐标),因为它在文章中更容易引用。因此,虚部(y 坐标)在音频通道上保持未观察到。因此,该技术的目标是使用瞬时频率计算将记录的旋转矢量的相位角 (ϑ) 与传输相位进行比较,以揭示声卡引入的失真。

在这里插入图片描述

图 1:图示了用于表示正弦波的复杂矢量概念的概述。 (A) 显示相位矢量以恒定速度逆时针旋转,建立稳定的相位变化率。 (B) 描述该旋转矢量在实轴上的投影,生成具有 90 度相位偏移的 12 kHz 正弦波。 © 说明在虚轴上的投影,产生没有相位偏移的 12 kHz 正弦波。

仅从记录的实部测量相位的挑战在于,如果正弦波的振幅波动,则单个周期可能对应两个甚至更多的不同相位值。图 2A 和 2D 演示了这种情况,两个不同的向量(标记为向量 1 和向量 2)具有固定长度,可以共享相同的实数坐标,同时对应不同的相位偏移。虽然在这种情况下反三角函数将产生两个相位值,但如果向量的长度发生变化,则不能直接应用反函数。图 2B、2C、2E 和 2F 说明了这个问题,其中向量长度现在大于 1,这导致不同的相位角对应于相同的实数值。
在这里插入图片描述
图 2:该图演示了当不同的向量属性产生相同的实数坐标时,相位确定中如何产生模糊性。(A)展示一个固定长度(单位长度)的向量(向量 1),它与另一个相位可能性共享一个实数坐标。(B)显示一个长度大于 1 的向量导致多个相位角对应于相同实数值的场景。(C)进一步说明增加向量长度对相位测量模糊性的影响。(D)显示固定长度(单位长度)向量(向量 2)尽管共享相同的实数坐标,也表现出相位模糊性。(E)继续演示长度大于 1 的向量如何导致相同实部的相位值重叠。(F)强化了增加向量长度对从实部产生非唯一相位表示的影响。

在图 3A 中,矢量长度问题与矢量的旋转速度随时间增加而加剧,这种情况可能由于声卡的振荡器组件漂移或放大器增益变化而发生。如图 3B 所示,从相应的实分量计算矢量的相位很难引起底层矢量模型的变化。
在这里插入图片描述

图 3:该图突出显示了随时间变化的旋转速度对从实部提取相位的额外复杂性。(A)说明了矢量长度问题以及随时间增加的旋转速度。(B)描述了从实部计算出的相位,强调了在动态条件下准确恢复相位的难度。

改变底层矢量模型的目的是恢复隐藏矢量的相位,该相位与记录信号的相位相同。如果矢量的实部(x 坐标)和虚部(y 坐标)都可以直接获得,则相位测量将很简单。但是,由于只有 x 坐标可用,因此该技术不能依赖于未观察到的 y 坐标。通过添加一个反向旋转(顺时针)矢量来消除这种依赖性,该矢量镜像原始矢量的 y 坐标,以便得到的 y 坐标始终为零。此外,两个矢量都缩放了一半以保留 x 坐标的正确值。图 4A 显示两个矢量以取消 y 坐标的关系旋转,同时保持原始 x 坐标值。图 4B 显示得到的信号(x 坐标)与图 3B 中的单个旋转矢量相同。由于 x 坐标相同,因此无法确定信号是由一个还是两个向量生成,因此我将假设两个向量模型。
在这里插入图片描述

图 4:引入改进的矢量模型来恢复仅观察到实部时的隐藏相位。(A)显示原始逆时针旋转矢量以及按一半缩放的反向旋转(顺时针)矢量,以取消 y 坐标。(B)证明所得的 x 坐标信号与先前计算的单个旋转矢量相同。(C)通过傅立叶变换峰值说明如何根据频率符号表示和分离两个相反的矢量

随着第二个向量抵消 y 分量,任务转移到分离两个旋转向量的贡献。黑色向量以常规的逆时针方向旋转,而灰色向量则顺时针旋转。逆时针向量只是出于惯例才被首选。按照惯例,逆时针向量对应于正频率,并用于分析信号形成和调制方案。此外,按照惯例,顺时针向量对应于负频率。使用傅里叶变换可以分离两个向量,该变换将信号分离为正频率和负频率。在此过程中,傅里叶变换将分离顺时针和逆时针旋转的向量。这通过两个旋转向量产生的固定频率、固定幅度的正弦波得到证明,如图 5A 所示,它产生了图 5B 中的实信号。当应用傅里叶变换时,如图 5C 所示,结果图显示沿水平轴的两个不同的幅度峰值,对应于旋转向量的有符号频率。图 4C 进一步说明了这些峰值如何表示两个相反的向量。在本分析中,仅显示傅里叶变换的幅度部分(通常以分贝为单位),省略每个频率的完整复数值。关键见解是,当矢量以固定速度和幅度旋转时,傅里叶变换会有效地分离逆时针和顺时针分量。这种分离意味着逆时针矢量被隔离,以便测量其随时间变化的相位。
在这里插入图片描述
图 5:显示了从双旋转矢量生成实信号及其频率分解。(A)描绘了两个旋转矢量(一个逆时针,一个顺时针),它们一起生成固定频率、固定幅度的正弦波。(B)显示由这些矢量组合产生的最终实信号。(C)显示傅里叶变换输出,其中水平轴上有不同的幅度峰值,与各个旋转组件的有符号频率相对应。

然而,在实际情况中,捕获的信号在幅度和频率上都会发生变化,如图 4B 和 6B 所示。对这种动态信号进行傅里叶变换会产生一个频谱(图 6C),其特征是两个由多个频率组成的宽峰,而不是两个尖峰。这个宽峰的出现是因为傅里叶变换将信号的幅度和频率变化分解为固定频率、固定幅度矢量的等效和。

在这里插入图片描述
图 6:该图探索了具有可变幅度和频率的信号的动态及其频谱表示。(A)描绘了两个旋转矢量(一个逆时针,一个顺时针),它们一起产生可变频率、可变幅度的正弦波。(B)显示捕获的信号,其中幅度和频率随时间变化。(C)显示相应的傅里叶变换频谱,其特征是宽峰,反映了分解为多个固定频率分量。

图 7 和图 8 从概念上说明了长度和旋转速度不断变化的旋转矢量等效于多个固定矢量之和,而逆傅里叶变换从这些固定分量重新组合出原始矢量的动态行为。
在这里插入图片描述
图 7:概念图,表明动态变化的旋转矢量可以表示为多个固定矢量的总和。
在这里插入图片描述
图 8:概念图,显示逆傅里叶变换如何从固定频率分量重新组合原始矢量的动态行为。

图 9 描述了使用傅里叶变换测量瞬时频率的处理链。首先,使用傅里叶变换将信号(图 9A)的底层矢量分离为逆时针和顺时针矢量。接下来,将负(顺时针)频率(图 9B)归零,只留下逆时针旋转矢量。逆傅里叶变换重建(图 9C)单个逆时针旋转矢量的实部(x 坐标)和虚部(y 坐标)值。实部和虚部还包括任何振幅波动。通过从矢量幅度归一化的坐标计算相位角(图 9D)可以消除这些波动,从而得到一个单位幅度旋转矢量(图 9E),其旋转速度变化反映了其相位变化率。由于瞬时频率定义为相位随时间的变化,计算连续相位测量值之间的差异,并按采样率除以 2π 进行缩放,可得到图 9F 所示的瞬时频率图。分析瞬时频率值的界限可以了解各种相位和频率调制方案的预期错误率。
在这里插入图片描述
图 9:使用傅立叶变换技术测量瞬时频率的完整处理链。(A)描述了傅立叶变换对基础矢量的初始分离。(B)将负(顺时针)频率分量归零以隔离逆时针旋转矢量。(C)逆傅立叶变换重建逆时针矢量的实部和虚部。(D)从标准化坐标计算相位角,消除幅度波动。(E)得到的单位幅度旋转矢量,其可变的旋转速度反映了其相位变化。(F)通过区分连续相位测量并按适当因子缩放获得的瞬时频率图。

使用已知参数的测试数据验证了整个处理链,如图 10 所示。在图 10A 中,旋转频率在 11,999.5 Hz 至 12,000.5 Hz 范围内变化的矢量产生的正弦波因添加的噪声而受到干扰。计算出的瞬时频率与预期值非常接近,观察到的最小值为 11,996.24 Hz,最大值为 12,003.68 Hz。在另一项测试(图 10B)中,旋转频率范围为 11,965 Hz 至 12,035 Hz 的宽带信号产生的最小值为 11,962.70 Hz,最大值为 12,037.96 Hz。

测试数据定性成功,该技术应用于 12 kHz 正弦波,由同一声卡以 44.1 kHz 采样率和 16 位样本传输和记录。生成的正弦波没有添加合成噪声,因此任何观察到的波动都源自声卡和量化效应。图 10C 的结果显示,声卡产生的最小瞬时频率为 11,999.29 Hz,最大瞬时频率为 12,000.64 Hz — 表明在一分钟的测量时间内变化率约为 1.5 Hz。可以通过对瞬时频率进行积分来获得相位。

在这里插入图片描述
图 10:显示已知参数的测试数据验证结果,以确认该技术的准确性。(A)显示旋转频率在 11,999.5 Hz 和 12,000.5 Hz 之间变化的正弦波的测试数据,包括瞬时频率的观测最小值和最大值。(B)显示具有更宽旋转频率范围和相应频率极值的宽带信号测试的验证结果。(C)描述声卡记录的测量结果,显示在一分钟的持续时间内变化率约为 1.5 Hz。

三、实验代码获取

代码使用Python 的 SciPy 工具箱,相关连接地址是:“见资源绑定”。

四、结论

使用通常的 USB 声卡测量到的约一分钟内 1.5 Hz 的非对称变化表明,这种硬件对于基本的 SDR 应用来说足够稳定。这些结果表明,基于傅立叶变换的方法可以从记录的正弦波中提取相位信息。未来的工作将探索相位和频率调制技术,确保任何符号调制都保持在变化阈值之内。一个简单的频移键控方法,涉及两个间隔 100 Hz 的频率,频率为 12 kHz,每秒传输几比特,预计作为初步测试。进一步的研究还将检查声卡可实现的数据速率极限并评估替代调制方案。

同时,对声卡进行额外的特性分析将有助于了解其局限性并找到潜在的解决方法。除了使用傅里叶变换将信号与本底噪声隔离之外,其他分析技术(如频谱直方图分析、时频分析和噪声建模)也可以提供对声卡通道特性的更深入的了解。这些方法可以揭示噪声频谱中的细微特征,这些特征可能被用来提高整个系统的性能。

通过相当于应用希尔伯特变换的过程,可以消除与负频率相对应的不需要的顺时针旋转矢量。希尔伯特变换在数学和信号处理中都用于从实值信号创建解析信号。这就是本文所做的。通过抑制负频率分量,可以创建一个解析信号,即可以进行瞬时频率分析的逆时针矢量。Python 的 SciPy 工具箱中有一个希尔伯特函数可以做到这一点。

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

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

相关文章

LeetCode 解题思路 18(Hot 100)

解题思路: 继承 LinkedHashMap: 内置双向链表,自动维护节点的插入顺序和访问顺序。LRU 淘汰逻辑: 覆盖 removeEldestEntry,当元素数量超过 capacity 时,移除最旧条目。removeEldestEntry 方法提供钩子&…

JS基础部分

引入方式 内部脚本 外部脚本 变量 使用let声明变量,弱类型,使用const声明常量 因为箭头函数中this指针有问题,会默认指向父级对象 DOM 文档对象模型,将标记语言的各个部分封装成对应的对象。js通过dom就能够对html进行操作 …

Linux与深入HTTP序列化和反序列化

深入HTTP序列化和反序列化 本篇介绍 在上一节已经完成了客户端和服务端基本的HTTP通信,但是前面的传递并没有完全体现出HTTP的序列化和反序列化,为了更好得理解其工作流程,在本节会以更加具体的方式分析到HTTP序列化和反序列化 本节会在介绍…

QT入门笔记2

目录 一、前言 二、串口助手实现 2.1、串口 2.1.1、可用串口信息-QSerialPortInfo 2.1.2、打开串口-QSerialPort 2.1.3、串口发送接收信息 2.2、定时器-QTimer 2.3、常用属性类型转换(会更新) 2.4、子控件组规则命名优化 一、前言 这个是学习Q…

DeepSeek(3):DeepSeek R1 提示词⼯程

1 提示词⼯程 5W1H(What, Who, When, Where, Why, How)是⼀种常⽤的信息收集和指令下达的⽅法。以下是根据这个⽅法为DeepSeek R1模型下指令的例⼦,以“学习⼤模型应⽤开发”为例: (1)What(是什…

Linux入门 全面整理终端 Bash、Vim 基础命令速记

Linux入门 2025 超详细全面整理 Bash、Vim 基础命令速记 刚面对高级感满满的 终端窗口是不是有点懵?于是乎,这份手册就是为你准备的高效学习指南!我把那些让人头大的系统设置、记不住的命令都整理成了对你更友好的格式,让你快速学…

RBA+minibatch的尝试

目录 还是咬着牙来写 RBA了 JAX JAX->TORCH torch tensor的变形 pytorch怎么把一个【3,3,5】的tensor变成【3,10,5】,多的用0填充 pytorch如何把shape【100】转成【100,1】 把torch shape【100,1】变成【100】 SQUEEZE grad_fn 不能两次反向传播 还…

Jupyter notebook的安装与使用

jupyter notebook的安装需要在已经安装配置好的conda环境下 win r 打开运行窗口 输入cmd回车 在cmd窗口中输入以下命令 conda install jupyter notebook安装完成后启动 jupyter notebook 也是在cmd窗口 输入 : jupyter notebook运行成功后第一次打开的时候需要选择一个浏览…

如何在Ubuntu上构建编译LLVM和ISPC,以及Ubuntu上ISPC的使用方法

之前一直在 Mac 上使用 ISPC,奈何核心/线程太少了。最近想在 Ubuntu 上搞搞,但是 snap 安装的 ISPC不知道为什么只能单核,很奇怪,就想着编译一下,需要 Clang 和 LLVM。但是 Ubuntu 很搞,他的很多软件版本是…

特殊的数字排序

0特殊的数字排序 - 蓝桥云课 问题描述 小明被挑选去参加一个ACM比赛。他的任务是解决一个很特别的问题:给定一个整数数组,但是只能通过交换任意两个数的方式来排序。听起来很简单对吗?但是这个问题的难点在于,只有某些数字是可以…

汽车感性负载-智能高边钳位能量计算

随着汽车电子技术的发展,新的电子电气架构下,越来越多的执行部件在车身出现,比如电磁阀、风机、水泵、油泵、雨刮继电器等常用的执行器, 它们一般都表现为感性特点。驱动这些负载的最简单和最常见的方法是将它们连接到高边侧开关(…

量化交易学习笔记02:双均线策略

双均线策略示例 个股:中国平安 回测日期:2022-5-1至2023-5-1 短均线:5天 长无线:10天 代码: def initialize(context):# 初始化此策略# 设置我们要操作的股票池, 这里我们只操作一支股票# """标的&qu…

利用余弦相似度在大量文章中找出抄袭的文章

我前面的2篇文章分别讲了如果利用余弦相似度来判断2篇文章的相似度,来确定文章是否存在抄袭,和余弦相似度的原理,即余弦相似度到底是怎么来判断文章的相似性高低的等等。这一篇再说下,对于文章字数多和大量文章时,如果…

在 Kaggle 中绘制中文乱码解决

在 Kaggle 中绘制中文时,需要设置 Matplotlib 的字体,否则中文会显示为乱码。可以使用 SimHei(黑体)或 Microsoft YaHei(微软雅黑)。 解决方案 使用 matplotlib 设置中文字体在 Kaggle 安装 SimHei 字体 …

在 Ubuntu 服务器上使用宝塔面板搭建博客

📌 介绍 在本教程中,我们将介绍如何在 Ubuntu 服务器 上安装 宝塔面板,并使用 Nginx PHP MySQL 搭建一个博客(如 WordPress)。 主要步骤包括: 安装宝塔面板配置 Nginx PHP MySQL绑定域名与 SSL 证书…

Linux线程

1.线程概念 在一个程序里的一个执行路线就叫做线程(thread),更准确定义:线程是一个进程内部的控制序列 进程至少有一个执行路线,线程在进程内部运行,本质是在进程地址空间内运行,在Linux系统中,CPU眼中&a…

【TI MSPM0】GPIO学习

一、文件样例查找 以GPIO软件轮询为例 下面的四个文件夹分别为不同开发环境提供支持 二、工程导入 1.点击file-点击import project 2.点击browse 3.找到对应的文件打开,选择 推荐使用ticlang,能够提供更加优化的效率 点击finish 三、工程学习 1.readme 文件 &a…

二叉树的基本操作与实现:C语言深度剖析

目录 代码整体框架 1. #define _CRT_SECURE_NO_WARNINGS 2. 头文件引入 3. typedef int BTtype; 4. 二叉树节点结构体定义 二叉树的创建 1. BuyNode 函数 2. CreatNode 函数 二叉树的遍历 前序遍历 中序遍历 后序遍历 二叉树属性的计算 节点个…

深入解析 Latent Diffusion Model(潜在扩散模型,LDMs)(代码实现)

深入解析 Latent Diffusion Model:从传统 Diffusion Model 到高效图像生成的进化 近年来,生成模型在图像合成领域取得了显著进展,其中 Diffusion Model(扩散模型,DMs)以其出色的生成质量和理论上的稳健性逐…

线性回归原理推导与应用(五):波士顿房价预测实战

波士顿房价是一个非常经典的多元线性回归入门案例数据集。波士顿房价预测数据集包含了可能会影响房价的十三个因素,并给出了实际的房价(单位为万美元) 波士顿房价数据集数据集下载地址:https://www.kaggle.com/datasets/altavish…