久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊(cè)

QQ登錄

只需一步,快速開(kāi)始

搜索
查看: 10284|回復(fù): 10
收起左側(cè)

STM32M4 ADC采樣并FFT串口輸出源程序

  [復(fù)制鏈接]
ID:277651 發(fā)表于 2018-1-19 10:56 | 顯示全部樓層 |閱讀模式
實(shí)驗(yàn)?zāi)康?
    學(xué)習(xí)STM32F4 DSP功能(FFT計(jì)算)的使用
   
硬件資源:
    1,DS0(連接在PF9)
    2,串口1(波特率:115200,PA9/PA10連接在板載USB轉(zhuǎn)串口芯片CH340上面)
    3,ALIENTEK 2.8/3.5/4.3/7寸TFTLCD模塊(通過(guò)FSMC驅(qū)動(dòng),FSMC_NE4接LCD片選/A6接RS)  
    4,按鍵KEY0(PE4)
   
實(shí)驗(yàn)現(xiàn)象:
    本實(shí)驗(yàn)測(cè)試STM32F4的DSP 庫(kù)的FFT函數(shù),程序運(yùn)行后,自動(dòng)生成1024點(diǎn)測(cè)試序列,然后,每當(dāng)KEY0
    按下后,調(diào)用DSP庫(kù)的FFT算法(基4法)執(zhí)行FFT運(yùn)算,在LCD屏幕上面顯示運(yùn)算時(shí)間,同時(shí)將FFT結(jié)果
    輸出到串口,DS0用于提示程序正在運(yùn)行。

注意事項(xiàng):
    1,4.3寸和7寸屏需要比較大電流,USB供電可能不足,請(qǐng)用外部電源適配器(推薦外接12V 1A電源).
    2,本例程在LCD_Init函數(shù)里面(在ILI93xx.c),用到了printf,如果不初始化串口1,將導(dǎo)致液晶無(wú)法顯示!!

單片機(jī)源程序如下:
  1. #include "sys.h"
  2. #include "delay.h"  
  3. #include "usart.h"  
  4. #include "led.h"
  5. #include "key.h"
  6. #include "lcd.h"
  7. #include "timer.h"
  8. #include "math.h"
  9. #include "arm_math.h"  
  10. #include "adc.h"

  11. void Adc_change(void);//把a(bǔ)dc采樣的數(shù)值轉(zhuǎn)化成FFT 輸入數(shù)據(jù)

  12. #define ADC_LENGTH  256  //FFT長(zhǎng)度

  13. float ADC_Data_input[ADC_LENGTH*2];//adc數(shù)據(jù)
  14. float fft_outputbuf[ADC_LENGTH];        //FFT輸出數(shù)組

  15. u8 timeout;//定時(shí)器溢出次數(shù)
  16. int flag;


  17. int main(void)
  18. {
  19.   arm_cfft_radix4_instance_f32 scfft;
  20.          u8 key,t=0;
  21.         float time;
  22.         u8 buf[50];
  23.         u16 i;

  24.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設(shè)置系統(tǒng)中斷優(yōu)先級(jí)分組2
  25.         delay_init(168);  //初始化延時(shí)函數(shù)
  26.         uart_init(115200);                //初始化串口波特率為115200
  27.         
  28.         LED_Init();                                        //初始化LED
  29.         KEY_Init();                                        //初始化按鍵
  30.          LCD_Init();                                        //初始化LCD
  31.         Adc_Init();         //初始化ADC
  32.         TIM3_Int_Init(65535,84-1);        //1Mhz計(jì)數(shù)頻率,最大計(jì)時(shí)65ms左右超出
  33.           POINT_COLOR=RED;
  34.         LCD_ShowString(30,50,200,16,16,"Explorer STM32F4");        
  35.         LCD_ShowString(30,70,200,16,16,"DSP FFT TEST");        
  36.         LCD_ShowString(30,90,200,16,16,"ATOM@ALIENTEK");
  37.         LCD_ShowString(30,110,200,16,16,"2014/7/2");        
  38.         LCD_ShowString(30,130,200,16,16,"KEY0:Run FFT");//顯示提示信息
  39.         LCD_ShowString(30,160,200,16,16,"FFT runtime:");//顯示FFT執(zhí)行時(shí)間
  40.          POINT_COLOR=BLUE;        //設(shè)置字體為藍(lán)色   
  41.         arm_cfft_radix4_init_f32(&scfft,ADC_LENGTH,0,1);//初始化scfft結(jié)構(gòu)體,設(shè)定FFT相關(guān)參數(shù)
  42. while(1)
  43.         {
  44.                 //key=KEY_Scan(0);
  45.                 Adc_change();
  46.         if(flag)
  47.                 {
  48.                 for(i=0;i<ADC_LENGTH;i++) //顯示輸入數(shù)據(jù)
  49.                         {
  50.                         printf(" ADC_Data_input[%d]:%f  %f \r\n",i,  ADC_Data_input[2*i],  ADC_Data_input[2*i+1]);
  51.                         }
  52.                         TIM_SetCounter(TIM3,0);//重設(shè)TIM3定時(shí)器的計(jì)數(shù)器值
  53.                         timeout=0;
  54.                         arm_cfft_radix4_f32(&scfft,ADC_Data_input);        //FFT計(jì)算(基4)
  55.                         time=TIM_GetCounter(TIM3)+(u32)timeout*65536;                         //計(jì)算所用時(shí)間
  56.                         sprintf((char*)buf,"%0.3fms\r\n",time/1000);        
  57.                         LCD_ShowString(30+12*8,160,100,16,16,buf);        //顯示運(yùn)行時(shí)間               
  58.                         arm_cmplx_mag_f32(ADC_Data_input,fft_outputbuf,ADC_LENGTH);        //把運(yùn)算結(jié)果復(fù)數(shù)求模得幅值
  59.                         printf("\r\n%d point FFT runtime:%0.3fms\r\n",ADC_LENGTH,time/1000);
  60.                         printf("FFT Result:\r\n");
  61.                         for(i=0;i<ADC_LENGTH;i++)
  62.                         {
  63.                                 printf("fft_outputbuf[%d]:%f\r\n",i,fft_outputbuf[i]);
  64.                         }
  65.                         key=0;
  66.                 }
  67.                 t++;
  68.                 if((t%10)==0)LED0=!LED0;                  
  69.         }
  70. }

  71. void Adc_change(void)//把a(bǔ)dc采樣的數(shù)值轉(zhuǎn)化成FFT 輸入數(shù)據(jù)
  72. {
  73.         int i;
  74. for(i=0;i<ADC_LENGTH;i++)
  75.         {
  76.         ADC_Data_input[2*i]=Get_Adc(ADC_Channel_5)*3.3/4096;//實(shí)部
  77.         ADC_Data_input[2*i+1]=0;//虛部
  78.         }
  79.         flag=1;
  80. }
復(fù)制代碼

所有資料51hei提供下載:
ADC采樣FFT變換.rar (1.09 MB, 下載次數(shù): 215)


回復(fù)

使用道具 舉報(bào)

ID:370382 發(fā)表于 2018-7-20 21:00 | 顯示全部樓層
你是在逗我吧
回復(fù)

使用道具 舉報(bào)

ID:158903 發(fā)表于 2018-7-21 01:13 | 顯示全部樓層
謝謝
回復(fù)

使用道具 舉報(bào)

ID:382200 發(fā)表于 2018-8-2 16:12 | 顯示全部樓層
謝謝謝謝
回復(fù)

使用道具 舉報(bào)

ID:358705 發(fā)表于 2019-3-6 11:47 | 顯示全部樓層
不錯(cuò)啊
回復(fù)

使用道具 舉報(bào)

ID:68875 發(fā)表于 2019-5-16 23:08 | 顯示全部樓層
謝謝
回復(fù)

使用道具 舉報(bào)

ID:68875 發(fā)表于 2019-6-9 09:57 | 顯示全部樓層
不錯(cuò),
謝謝
回復(fù)

使用道具 舉報(bào)

ID:511461 發(fā)表于 2019-6-9 11:29 | 顯示全部樓層
FFT是傅里葉變換嗎
回復(fù)

使用道具 舉報(bào)

ID:511461 發(fā)表于 2019-6-9 11:29 | 顯示全部樓層
謝謝分享
回復(fù)

使用道具 舉報(bào)

ID:68875 發(fā)表于 2019-12-6 23:23 | 顯示全部樓層

謝謝謝謝
回復(fù)

使用道具 舉報(bào)

ID:643833 發(fā)表于 2020-10-5 13:56 | 顯示全部樓層
能顯示頻率嗎
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術(shù)交流QQ群281945664

Powered by 單片機(jī)教程網(wǎng)

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 国产吃瓜黑料一区二区 | 亚洲 欧美 综合 | 国产99对白在线播放 | 精品国产99久久久久久宅男i | 亚洲高清免费视频 | 欧美在线一区二区 | 黄色影音 | 解开岳的丰满奶罩bd | www.色网| 国产高清91 | 黄色三级视频在线观看 | 91久久久久久久久 | 久久五月婷 | 黑人精品一区二区 | 久久草视频 | 成人三级小说 | 超碰777| 一区二区三区国产 | 国产午夜在线 | 激情视频网址 | 99热最新| av小说在线观看 | 久操av在线 | 99福利视频| 亚洲精品在线视频观看 | 日韩国产欧美 | 国产精品入口夜色视频大尺度 | a级片免费在线观看 | 在线播放中文字幕 | 国产盗摄一区二区 | 91免费黄| 亚洲色网址| 午夜国产福利 | 中日韩毛片 | 国产精品123 | 亚洲精品视频免费在线观看 | 国产区av| 久草青青草 | 日韩福利片 | 91免费看视频 | 午夜网址 |