【杂谈】STM32使用快速傅里叶变换库函数后如何比较准确地找到n次谐波幅值

目录

1.简单介绍傅里叶变换的作用

2.谐波是什么

3.解决方法


1.简单介绍傅里叶变换的作用

任何复杂的波形归根结底都是由多个频率和相位不一样的正弦波组成的

通过傅里叶变换可以找到组成一个复杂的波形的所有正弦波的频率和幅度信息

2.谐波是什么

假设有一个复杂的波形,它由多个正弦波有规律的叠加而成,且第一个正弦波频率为5KHz,第二个正弦波为10KHz,第三个正弦波为15KHz……

可以发现后续的正弦波频率都是第一个正弦波的整数倍,所以我们称第一个正弦波为基波(或一次谐波),第二个正弦波为二次谐波,以此类推

使用STM32以合适的频率对这个复杂的波形采样(用数组A存储),并将采样得到的数据利用DSP数学库中的快速傅里叶变换得到新的数据(也用数组B存储),我们该如何正确找出各谐波的幅值呢?

3.解决方法

假设基波的幅值比其他谐波的幅值都要高

我们可以先通过大小比较确定基波(一次谐波)在数组B中的下标N,当我们确定基波在数组B的下标后,由于谐波的频率必然是基波的整数倍,可以通过乘以基波下标的2倍、3倍、4倍……找到二次、三次、四次谐波……的位置是2N、3N、4N……

//假设基波的幅度高于直流分量和后续所有的谐波
//先找基波,假设B数组的长度为size
int i = 0;
int MAX_Location = 0;     //存储最大值所在位置
float MAX = B[0];         
for( i = 0; i < size; i++)
{if( B[i] > MAX ){MAX = B[i];MAX_Location = i;}
}

但这样的方法存在找不准的问题,比如二次谐波幅值实际是2V,由于采样频率问题,2倍的基波数组下标内存储的幅值只有1V,真正的二次谐波在应该在2N-1或者2N+1,那么可以通过在2N的小范围区间内再找一次最大值

当小区间内相邻两个值误差在一定范围内可视为由于采样频率的问题,其实在两者间真正的最大值没有采到,可以人为地在合适的范围修正

int i = 0;
int Number = 0;           //假设有Numer次谐波
int number = Number;
int arr[number] = {0};    //用于存储每个谐波在B数组中的下标
float correction = 30;    //人为修正刚好没有采到最大值,而是采到左右两个值的问题
float max = 0;number = 0;    
for( i = 2; i < Number; i++)	
{	max = B[Base_location * i - 2];            for( j = Base_location * i - 2; j < Base_location * i + 2; j++ )  //取±2的区间{if( fabs(arr[j] - arr[j + 1]) < 30)                           //修正{B[j] = (B[j] + B[j+1]) / 2 + 15;} if( B[j] > max ){max = B[j];arr[number] = j;number++;}}		
}

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

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

相关文章

芯科科技推出首批第三代无线开发平台SoC,高度集成的解决方案推动下一波物联网实现突破

SiXG301和SiXG302是芯科科技采用22纳米工艺节点推出的首批无线SoC系列产品&#xff0c;在计算能力、功效、集成度和安全性方面实现突破性进展 低功耗无线解决方案领导性创新厂商Silicon Labs&#xff08;亦称“芯科科技”&#xff0c;NASDAQ&#xff1a;SLAB&#xff09;近日宣…

写作即是生活

一个问题 “我是什么时候开始写作的呢&#xff1f;”请你先暂停一下&#xff0c;别往下读&#xff0c;先想想这个问题。 什么才是写作&#xff1f; 或许在想上个问题之后&#xff0c;你就会开始想问另外一个问题&#xff0c;什么才算是写作呢&#xff1f; 我的回答是&#x…

SpringBoot 执行Lua脚本 服务端执行 减少性能损耗 优化性能 优化连接性能

介绍 通过 Redis 执行 Lua 脚本时&#xff0c;所有的操作都在服务器端完成&#xff0c;而不是多次通过网络进行请求。这可以显著减少网络延迟&#xff0c;尤其是在需要多次与 Redis 交互的场景中。多个操作可以在 Lua 脚本中组合成一个操作&#xff0c;而不是分多次请求&#…

Nginx代理、缓存与Rewrite

目录 一、正向代理 &#xff08;一&#xff09;核心概念与应用场景 &#xff08;二&#xff09;Nginx正向代理编译安装&#xff08;以OpenEuler为例&#xff09; &#xff08;三&#xff09;验证正向代理 二、反向代理 &#xff08;一&#xff09;七层代理&#xff08;HT…

PortSwigger-02-XXE

一&#xff1a;漏洞原理 1、XXE XXE全称xml外部实体注入 XML&#xff1a;是一种用于标记电子文件使其具有结构性的标记语言&#xff0c;提供统一的方法来描述和交换独立于应用程序或者供应商的结构化数据&#xff0c;它可以用来标记数据&#xff0c;定义数据类型、是一种允许…

常规算法学习

算法 1. 排序算法1. 归并排序1.1 普通归并排序1.2 优化后的归并排序&#xff08;TimSort&#xff09; 2. 插入排序2.1 直接插入排序2.2 二分插入排序2.3 成对插入排序 3. 快速排序3.1 单轴快速排序3.2 双轴快排 4. 计数排序 2. 树1. 红黑树&#xff08;Red Black Tree&#xff…

关于线程死锁的相关知识

前言 今天学习了线程死锁的相关知识。线程死锁是非常重要的知识&#xff0c;写成博客&#xff0c;加深自己对于知识的理解。 线程死锁 结语 希望可以帮助到大家~

EMQX启用单向认证的SSl/TLS连接的配置步骤

先确保您已经安装了 OpenSSL 执行openssl version -a 获取 openssl.cnf 目录 生成自签名服务端证书 CA 证书生成 server-ca.crt openssl req \-new \-newkey rsa:2048 \-days 365 \-nodes \-x509 \-subj "/CCN/OEMQ Technologies Co., Ltd/CNEMQ CA" \-keyout s…

依赖nacos实例动态创建线程池并监听服务上下线

版本 Spring Booot 版本 3.2.4Spring Cloud 版本 2023.0.1Spring Cloud Alibaba 版本 2023.0.1.2 依赖 <dependency><groupId>com.alibaba.cloud</groupId><artifactId>spring-cloud-starter-alibaba-nacos-discovery</artifactId> </depe…

全面指南:使用Node.js和Python连接与操作MongoDB

在现代Web开发中&#xff0c;数据库是存储和管理数据的核心组件。MongoDB作为一款流行的NoSQL数据库&#xff0c;以其灵活的数据模型、高性能和易扩展性广受开发者欢迎。无论是使用Node.js还是Python&#xff0c;MongoDB都提供了强大的官方驱动和第三方库&#xff0c;使得数据库…

LeetCode 3068.最大节点价值之和:脑筋急转弯+动态规划(O(1)空间)

【LetMeFly】3068.最大节点价值之和&#xff1a;脑筋急转弯动态规划&#xff08;O(1)空间&#xff09; 力扣题目链接&#xff1a;https://leetcode.cn/problems/find-the-maximum-sum-of-node-values/ 给你一棵 n 个节点的 无向 树&#xff0c;节点从 0 到 n - 1 编号。树以长…

HTTPS加密通信详解及在Spring Boot中的实现

HTTPS&#xff08;Hyper Text Transfer Protocol Secure&#xff09;是HTTP的安全版本&#xff0c;通过SSL/TLS协议为通讯提供加密、身份验证和数据完整性保护。 一、HTTPS核心原理 1.加密流程概述 客户端发起HTTPS请求&#xff08;连接到服务器443端口&#xff09;服务器返…

解决线程安全问题

前言 昨天学习了如何去解决线程不安全的问题。一般方法都是通过加锁来处理&#xff0c;跟大家分享一波 。 解决线程安全问题 结语 希望可以帮助到大家~ byebye

网络常识:网线和光纤的区别

网络常识&#xff1a;网线和光纤的区别 一. 介绍二. 网线2.1 什么是网线&#xff1f;2.2 网线的主要类别2.3 网线的优势2.4 网线的劣势 三. 光纤3.1 什么是光纤&#xff1f;3.2 光纤的主要类别3.3 光纤的优势3.4 光纤的劣势 四. 网线 vs 光纤&#xff1a;谁更适合你&#xff1f…

win11 禁用/恢复 内置笔记本键盘(保证管用)

文章目录 禁用启用 禁用 1&#xff09;按下 win x&#xff0c;点击 设备管理器 2&#xff09;拔掉所有笔记本外设&#xff08;一定要都拔掉&#xff0c;不然后面禁用设备会混淆&#xff09;&#xff0c;然后右键点击 键盘 > HID Keyboard Device 2&#xff09;点击 更新…

Three.js搭建小米SU7三维汽车实战(5)su7登场

汽车模型加载 我们在sktechfab上下载的汽车是glb的文件格式&#xff0c;所以使用gltfLoader进行加载。这里将小车直接加载进来看看效果&#xff1b; import { GLTFLoader } from "three/addons/loaders/GLTFLoader.js"; ....其余代码省略 const gltfLoader new GLT…

ETL怎么实现多流自定义合并?

随着信息技术的迅猛发展以及数据生成环境的多样化&#xff0c;互联网、物联网和社交媒体的广泛应用导致各种设备和平台不断产生大量数据&#xff0c;需要整合这些数据&#xff0c;从而进行数据融合。数据集成和管理平台ETLCloud&#xff0c;主要用于支持数据的抽取&#xff08;…

数据结构- 10种常见树:二叉树、平衡二叉树、完全二叉树

一、树 树型结构是一类重要的非线性数据结构。其中以树和二叉树最为常用&#xff0c;直观看来&#xff0c;树是以分支关系定义的层次结构。把它叫做“树”是因为它常看起来像一棵倒挂的树&#xff0c;也就是说它常是根朝上&#xff0c;而叶朝下的。 1.树的定义&#xff1a; 树…

Java常用加密方式

一&#xff0c;加密算法分类 对称加密&#xff1a;指加密和解密的密钥相同&#xff0c;优点就是加解密的效率高且易于实现。 非对称加密&#xff1a;指加密和解密的密钥不相同&#xff0c;也称为公私要加密。 不可逆加密&#xff1a;特征就是加密过程不需要密钥&#xff0c;…

SQLite软件架构与实现源代码浅析

概述 SQLite 是一个用 C 语言编写的库&#xff0c;它成功打造出了一款小型、快速、独立、具备高可靠性且功能完备的 SQL 数据库引擎。本文档将为您简要介绍其架构、关键组件及其协同运作模式。 SQLite 显著特点之一是无服务器架构。不同于常规数据库&#xff0c;它并非以单独进…