標題:
stm32STM32F407_FFTDSP庫_ADC+DMA源碼
[打印本頁]
作者:
雞米花
時間:
2018-7-21 20:52
標題:
stm32STM32F407_FFTDSP庫_ADC+DMA源碼
stm32f407dma和adc
單片機源程序如下:
#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"
#define FFT_LENGTH 1024 //FFT長度,默認是1024點FFT
float fft_inputbuf[FFT_LENGTH*2]; //FFT輸入數(shù)組
float fft_outputbuf[FFT_LENGTH]; //FFT輸出數(shù)組
u8 timeout;//定時器溢出次數(shù)
extern u16 AD_Value[1024];
extern u16 After_filter[3];
u16 AD_FFT[1024];
int main(void)
{
arm_cfft_radix4_instance_f32 scfft;
u8 key,t=0;
float time;
u8 buf[50];
u16 i,tt;
NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置系統(tǒng)中斷優(yōu)先級分組2
delay_init(168); //初始化延時函數(shù)
uart_init(115200); //初始化串口波特率為115200
LED_Init(); //初始化LED
KEY_Init(); //初始化按鍵
LCD_Init(); //初始化LCD
DMA_Configuration();
ADC1_Configuration();
TIM3_Int_Init(65535,84-1); //1Mhz計數(shù)頻率,最大計時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執(zhí)行時間
POINT_COLOR=BLUE; //設置字體為藍色
arm_cfft_radix4_init_f32(&scfft,FFT_LENGTH,0,1);//初始化scfft結構體,設定FFT相關參數(shù)
while(1)
{
key=KEY_Scan(0);
if(key==KEY0_PRES)
{
for(i=0;i<FFT_LENGTH;i++)
AD_FFT[i]=AD_Value[i];
for(i=0,tt=0;i<FFT_LENGTH;i++)//來自ADC信號序列
{
fft_inputbuf[2*i] = AD_FFT[tt];
fft_inputbuf[2*i+1]=0;//虛部全部為0
tt++;
}
// for(i=0;i<FFT_LENGTH;i++)//手動生成信號序列
// {
// fft_inputbuf[2*i]=100+
// 10*arm_sin_f32(2*PI*i/FFT_LENGTH)+50*arm_cos_f32(2*PI*i*128/FFT_LENGTH)+
// 30*arm_sin_f32(2*PI*i*4/FFT_LENGTH)+
// 50*arm_cos_f32(2*PI*i*8/FFT_LENGTH); //生成輸入信號實部
// fft_inputbuf[2*i+1]=0;//虛部全部為0
// }
TIM_SetCounter(TIM3,0);//重設TIM3定時器的計數(shù)器值
timeout=0;
arm_cfft_radix4_f32(&scfft,fft_inputbuf); //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(fft_inputbuf,fft_outputbuf,FFT_LENGTH); //把運算結果復數(shù)求模得幅值
printf("\r\n%d point FFT runtime:%0.3fms\r\n",FFT_LENGTH,time/1000);
printf("FFT Result:\r\n");
for(i=0;i<FFT_LENGTH;i++)
{
printf("fft_outputbuf[%d]:%f\r\n",i,fft_outputbuf[i]);
LCD_DrawLine(i, 0,i,fft_outputbuf[i]/10000);
LCD_ShowxNum(30,5+i*20,fft_outputbuf[i],8,16,0);
}
}else delay_ms(10);
t++;
if((t%10)==0)LED0=!LED0;
}
}
復制代碼
所有資料51hei提供下載:
DSP-FFT-ADC我的(好的).rar
(1.09 MB, 下載次數(shù): 221)
2018-7-21 23:34 上傳
點擊文件名下載附件
下載積分: 黑幣 -5
作者:
z1026563274
時間:
2018-7-21 23:45
請問這個可以測得頻率嗎 咳咳 老哥
作者:
1245455936
時間:
2018-7-23 00:31
謝謝分享
作者:
Jimnice
時間:
2018-7-27 10:28
謝謝分享
作者:
hzpj01
時間:
2018-10-15 19:52
1024個點做完大概用時多少?
作者:
bouna
時間:
2020-3-19 21:11
where is please the schematic ?
作者:
我是你爸爸丶
時間:
2020-6-3 22:41
這代碼有點問題啊,adc壓根沒用到,fftoutput出來的都是一些隨機數(shù),keil仿真里 看就知道了。
作者:
Accelerat
時間:
2020-8-13 22:27
問一下各位,這個是干什么的
作者:
chenzm905
時間:
2021-8-1 14:53
有沒有頻率
歡迎光臨 (http://www.torrancerestoration.com/bbs/)
Powered by Discuz! X3.1