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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 10227|回復: 10
收起左側

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

  [復制鏈接]
ID:277651 發表于 2018-1-19 10:56 | 顯示全部樓層 |閱讀模式
實驗目的:
    學習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,將導致液晶無法顯示!!

單片機源程序如下:
  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);//把adc采樣的數值轉化成FFT 輸入數據

  12. #define ADC_LENGTH  256  //FFT長度

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

  15. u8 timeout;//定時器溢出次數
  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);//設置系統中斷優先級分組2
  25.         delay_init(168);  //初始化延時函數
  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計數頻率,最大計時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執行時間
  40.          POINT_COLOR=BLUE;        //設置字體為藍色   
  41.         arm_cfft_radix4_init_f32(&scfft,ADC_LENGTH,0,1);//初始化scfft結構體,設定FFT相關參數
  42. while(1)
  43.         {
  44.                 //key=KEY_Scan(0);
  45.                 Adc_change();
  46.         if(flag)
  47.                 {
  48.                 for(i=0;i<ADC_LENGTH;i++) //顯示輸入數據
  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);//重設TIM3定時器的計數器值
  53.                         timeout=0;
  54.                         arm_cfft_radix4_f32(&scfft,ADC_Data_input);        //FFT計算(基4)
  55.                         time=TIM_GetCounter(TIM3)+(u32)timeout*65536;                         //計算所用時間
  56.                         sprintf((char*)buf,"%0.3fms\r\n",time/1000);        
  57.                         LCD_ShowString(30+12*8,160,100,16,16,buf);        //顯示運行時間               
  58.                         arm_cmplx_mag_f32(ADC_Data_input,fft_outputbuf,ADC_LENGTH);        //把運算結果復數求模得幅值
  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)//把adc采樣的數值轉化成FFT 輸入數據
  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;//實部
  77.         ADC_Data_input[2*i+1]=0;//虛部
  78.         }
  79.         flag=1;
  80. }
復制代碼

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


回復

使用道具 舉報

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

使用道具 舉報

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

使用道具 舉報

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

使用道具 舉報

ID:358705 發表于 2019-3-6 11:47 | 顯示全部樓層
不錯啊
回復

使用道具 舉報

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

使用道具 舉報

ID:68875 發表于 2019-6-9 09:57 | 顯示全部樓層
不錯,
謝謝
回復

使用道具 舉報

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

使用道具 舉報

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

使用道具 舉報

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

謝謝謝謝
回復

使用道具 舉報

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

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 色888www视频在线观看 | 久久精品欧美一区二区三区不卡 | 欧美精品第一页 | 精品日韩一区二区 | 国产午夜精品一区二区三区 | 亚洲va中文字幕 | 米奇成人网 | 亚洲乱码一区二区三区在线观看 | 日本不卡一区 | 欧美精品一区二区免费视频 | 欧美精品区 | 日韩高清国产一区在线 | 国产精品久久久久久久久久久久久 | 日日碰狠狠躁久久躁96avv | 97日韩精品| 一区二区三区不卡视频 | 午夜资源| 色接久久 | 四虎影院免费在线 | 亚洲丝袜天堂 | 日韩免费视频 | 国产精品一区二区视频 | 国产电影一区二区在线观看 | 成人免费视频播放 | 精品久久亚洲 | 国产精品99久久免费观看 | 成人免费观看男女羞羞视频 | 亚洲综合五月天婷婷 | 久久国产精品-国产精品 | 国产精品一区二 | 久久久99国产精品免费 | 日韩一区二区三区av | 亚洲精品99 | 可以在线看的黄色网址 | 亚洲视频第一页 | 国产三区精品 | 亚洲美女网站 | 国产综合av | 中文字幕在线看人 | 丁香一区二区 | 婷婷色国产偷v国产偷v小说 |