【嵌入式】单片机fft

  • 使用cmsis-dsp
  • 开启单片机的FPU
c 复制代码
#define DEF_APP_FFT_MODULE 
/*********************************************************************************   
 *                                   INCLUDES                                        
 *********************************************************************************/  
#include "app_fft.h" 
#include "arm_math.h"
#include "transform_functions.h"
#include "arm_const_structs.h"
#include <stdio.h>
/*********************************************************************************   
 *                                   DEFINES                                         
 *********************************************************************************/  
// FFT点数 = 采样率 ÷ 目标分辨率,向上取整到2的幂次
#define FFT_LENGTH      256

//采样频率 ≥ 2 × 最高频率(建议2.5倍以上)
#define SAMPLE_FREQ     256

// 缓冲区
float adcBuffer[FFT_LENGTH];
float fftBuffer[FFT_LENGTH * 2]; // 实部+虚部
float magBuffer[FFT_LENGTH / 2];
/*********************************************************************************   
 *                                   MACROS                                          
 *********************************************************************************/  

/*********************************************************************************   
 *                                  TYPEDEFS                                         
 *********************************************************************************/  

/*********************************************************************************   
 *                               STATIC FUNCTION                                     
 *********************************************************************************/  


void app_CollectData(void)
{
    uint16_t i = 0;
    
    // 从ADC采集数据到adcBuffer
    // 这里用模拟数据代替
    for(i = 0; i < FFT_LENGTH; i++)
    {
        float time = (float)i / SAMPLE_FREQ;
        adcBuffer[i] = 0.2f * arm_sin_f32(2 * PI * 50 * time) + 
                       0.8f * arm_sin_f32(2 * PI * 51 * time);
        
        // 填充FFT缓冲区(实部)
        fftBuffer[2*i] = adcBuffer[i];
        // 虚部设为0
        fftBuffer[2*i+1] = 0;
    }
}

void app_FFTProcess(void)
{
    uint32_t maxIndex;
    float maxValue;
    float frequency = 0;
		float magValue = 0;
    
    // 执行FFT
    arm_cfft_f32(&arm_cfft_sR_f32_len256, fftBuffer, 0, 1);
    
    // 计算幅度
    arm_cmplx_mag_f32(fftBuffer, magBuffer, FFT_LENGTH/2);
    
    // 寻找峰值频率
    arm_max_f32(magBuffer, FFT_LENGTH/2, &maxValue, &maxIndex);
    
    // 计算频率
    frequency = (float)maxIndex * SAMPLE_FREQ / FFT_LENGTH;
    
    //幅值
    magValue = maxValue * 2 / SAMPLE_FREQ;
    
    printf("原始:%d Hz, 峰值频率: %.2f Hz, 幅度: %.2f\n", maxIndex, frequency, magValue);
    
}
c 复制代码
void main()
{
	app_CollectData();
	app_FFTProcess();
}
相关推荐
浩浩测试一下19 分钟前
汇编 16位32位64位通用寄存器(逆向分析)
汇编·windows·stm32·单片机·嵌入式硬件·逆向·二进制
潜创微科技2 小时前
IT68353:双 DP1.4a+HDMI2.0 转 HDMI2.0 单芯片 KVM 切换方案
嵌入式硬件·音视频
踏着七彩祥云的小丑3 小时前
嵌入式测试学习第 17 天:常见接口:USB、Type-C、排针
单片机·嵌入式硬件
szxinmai主板定制专家4 小时前
电力设备RK3568/RK3576+FPGA,多系统混合部署Linux+RTOS RT-THREAD,强实时性
linux·运维·服务器·人工智能·嵌入式硬件·fpga开发
振南的单片机世界5 小时前
EXTI边沿触发:按键一按就通知CPU,不用轮询
stm32·单片机·嵌入式硬件
jllllyuz5 小时前
STM32 BMP280 I2C通信驱动程序
stm32·单片机·嵌入式硬件
优信电子6 小时前
基于STM32F103C8T6单片机驱动ACS712模块进行电流检测
stm32·单片机·嵌入式硬件·嵌入式·电流检测·acs712·电流采集
崇山峻岭之间7 小时前
单片机外部中断实验
单片机·嵌入式硬件
chipsense7 小时前
工业UPS电流传感器选型实战指南:AS1V系列如何应对工业配电特殊挑战
单片机·嵌入式硬件·ups·电流传感器
振浩微433射频芯片7 小时前
告别“喊破嗓”:深度解析433MHz射频在宠物训练器中的核心应用与选型
单片机·嵌入式硬件·物联网·学习·宠物