欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136
標題:
STM32M4 ADC采樣并FFT串口輸出源程序
[打印本頁]
作者:
芒果fwd
時間:
2018-1-19 10:56
標題:
STM32M4 ADC采樣并FFT串口輸出源程序
實驗目的:
學習STM32F4 DSP功能(FFT計算)的使用
硬件資源:
1,DS0(連接在PF9)
2,串口1(波特率:115200,PA9/PA10連接在板載USB轉串口芯片CH340上面)
3,ALIENTEK 2.8/3.5/4.3/7寸TFTLCD模塊(通過FSMC驅動,FSMC_NE4接LCD片選/A6接RS)
4,按鍵KEY0(PE4)
實驗現象:
本實驗測試STM32F4的DSP 庫的FFT函數,程序運行后,自動生成1024點測試序列,然后,每當KEY0
按下后,調用DSP庫的FFT算法(基4法)執行FFT運算,在LCD屏幕上面顯示運算時間,同時將FFT結果
輸出到串口,DS0用于提示程序正在運行。
注意事項:
1,4.3寸和7寸屏需要比較大電流,USB供電可能不足,請用外部電源適配器(推薦外接12V 1A電源).
2,本例程在LCD_Init函數里面(在ILI93xx.c),用到了printf,如果不初始化串口1,將導致液晶無法顯示!!
單片機源程序如下:
#include "sys.h"
#include "delay.h"
#include "usart.h"
#include "led.h"
#include "key.h"
#include "lcd.h"
#include "timer.h"
#include "math.h"
#include "arm_math.h"
#include "adc.h"
void Adc_change(void);//把adc采樣的數值轉化成FFT 輸入數據
#define ADC_LENGTH 256 //FFT長度
float ADC_Data_input[ADC_LENGTH*2];//adc數據
float fft_outputbuf[ADC_LENGTH]; //FFT輸出數組
u8 timeout;//定時器溢出次數
int flag;
int main(void)
{
arm_cfft_radix4_instance_f32 scfft;
u8 key,t=0;
float time;
u8 buf[50];
u16 i;
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置系統中斷優先級分組2
delay_init(168); //初始化延時函數
uart_init(115200); //初始化串口波特率為115200
LED_Init(); //初始化LED
KEY_Init(); //初始化按鍵
LCD_Init(); //初始化LCD
Adc_Init(); //初始化ADC
TIM3_Int_Init(65535,84-1); //1Mhz計數頻率,最大計時65ms左右超出
POINT_COLOR=RED;
LCD_ShowString(30,50,200,16,16,"Explorer STM32F4");
LCD_ShowString(30,70,200,16,16,"DSP FFT TEST");
LCD_ShowString(30,90,200,16,16,"ATOM@ALIENTEK");
LCD_ShowString(30,110,200,16,16,"2014/7/2");
LCD_ShowString(30,130,200,16,16,"KEY0:Run FFT");//顯示提示信息
LCD_ShowString(30,160,200,16,16,"FFT runtime:");//顯示FFT執行時間
POINT_COLOR=BLUE; //設置字體為藍色
arm_cfft_radix4_init_f32(&scfft,ADC_LENGTH,0,1);//初始化scfft結構體,設定FFT相關參數
while(1)
{
//key=KEY_Scan(0);
Adc_change();
if(flag)
{
for(i=0;i<ADC_LENGTH;i++) //顯示輸入數據
{
printf(" ADC_Data_input[%d]:%f %f \r\n",i, ADC_Data_input[2*i], ADC_Data_input[2*i+1]);
}
TIM_SetCounter(TIM3,0);//重設TIM3定時器的計數器值
timeout=0;
arm_cfft_radix4_f32(&scfft,ADC_Data_input); //FFT計算(基4)
time=TIM_GetCounter(TIM3)+(u32)timeout*65536; //計算所用時間
sprintf((char*)buf,"%0.3fms\r\n",time/1000);
LCD_ShowString(30+12*8,160,100,16,16,buf); //顯示運行時間
arm_cmplx_mag_f32(ADC_Data_input,fft_outputbuf,ADC_LENGTH); //把運算結果復數求模得幅值
printf("\r\n%d point FFT runtime:%0.3fms\r\n",ADC_LENGTH,time/1000);
printf("FFT Result:\r\n");
for(i=0;i<ADC_LENGTH;i++)
{
printf("fft_outputbuf[%d]:%f\r\n",i,fft_outputbuf[i]);
}
key=0;
}
t++;
if((t%10)==0)LED0=!LED0;
}
}
void Adc_change(void)//把adc采樣的數值轉化成FFT 輸入數據
{
int i;
for(i=0;i<ADC_LENGTH;i++)
{
ADC_Data_input[2*i]=Get_Adc(ADC_Channel_5)*3.3/4096;//實部
ADC_Data_input[2*i+1]=0;//虛部
}
flag=1;
}
復制代碼
所有資料51hei提供下載:
ADC采樣FFT變換.rar
(1.09 MB, 下載次數: 215)
2018-1-19 20:03 上傳
點擊文件名下載附件
STM32M4ADC采樣并作FFT串口輸出
下載積分: 黑幣 -5
作者:
Crushen
時間:
2018-7-20 21:00
你是在逗我吧
作者:
mrliangg
時間:
2018-7-21 01:13
謝謝
作者:
yuktai1215
時間:
2018-8-2 16:12
謝謝謝謝
作者:
hjgjgj
時間:
2019-3-6 11:47
不錯啊
作者:
cnc2020
時間:
2019-5-16 23:08
謝謝
作者:
cnc2020
時間:
2019-6-9 09:57
不錯,
謝謝
作者:
aaaaaa。
時間:
2019-6-9 11:29
FFT是傅里葉變換嗎
作者:
aaaaaa。
時間:
2019-6-9 11:29
謝謝分享
作者:
cnc2020
時間:
2019-12-6 23:23
謝謝謝謝
作者:
shana_0v0
時間:
2020-10-5 13:56
能顯示頻率嗎
歡迎光臨 (http://m.raoushi.com/bbs/)
Powered by Discuz! X3.1