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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 6155|回復: 5
打印 上一主題 下一主題
收起左側

STM32F1DMA方式ADC采集雙聲道音頻FFT變換顯示頻譜 源程序

  [復制鏈接]
跳轉到指定樓層
樓主
STM32F103C8_DMA方式2路ADC采集雙聲道音頻FFT變換顯示頻譜
這是一個完整的項目,沒有加狗
關鍵點在于多路采集,FFT庫函數應用,這個FFT函數用匯編優化,速度比較快。
當然,本系統速度瓶頸在畫點顯示。后期我采用直接寫顯存,就比較快了。
上段忙,這也是我對同道的一點小小的貢獻

單片機源程序如下:
  1. #include "stm32f10x.h"
  2. #include "usart.h"
  3. #include "adc.h"
  4. #include "delay.h"
  5. #include "Lcd_Driver.h"
  6. #include "LCD_Config.h"
  7. #include "stm32_dsp.h"
  8. #include "math.h"

  9. #define NPT        256  //FFT采樣點數

  10. long lBUFMAG[NPT+NPT];                //存儲求模后的數據[NPT+NPT/2]
  11. long lBUFOUT[NPT];          //FFT輸出序列NPT=256
  12. long lBUFIN0[NPT];           //FFT輸入系列
  13. long lBUFIN1[NPT];           //FFT輸入系列

  14. void dsp_column0(void);
  15. void dsp_column1(void);
  16. void powerMag(long nfill);//計算頻點幅值
  17. void dsp_column_1(void);
  18. void OLED_Fill(u8 x1,u8 y1,u8 x2,u8 y2,u16 dot);

  19. extern __IO uint16_t ADC_ConvertedValue[NOFCHANEL];

  20. // 局部變量,用于保存轉換計算后的電壓值         
  21. float ADC_ConvertedValueLocal[NOFCHANEL];   

  22. int main(void)
  23. {
  24.         u16 i;
  25.         uart_init(115200);
  26.         ADCx_Init();
  27.         delay_init();
  28.     Lcd_Init();//初始化硬件SPI
  29.          Lcd_Clear(BLUE);  //清屏函數            

  30.         while(1)
  31.         {
  32.                              ADC_SoftwareStartConvCmd(ADC_x, ENABLE);
  33.         while(!DMA_GetFlagStatus(DMA1_FLAG_TC1));
  34.                                    DMA_ClearFlag(DMA1_FLAG_TC1);            
  35.                                    ADC_SoftwareStartConvCmd(ADC1, DISABLE);
  36.                     ADC_ConvertedValueLocal[0] =(float) ADC_ConvertedValue[0]/4096*3.3;
  37.                                 ADC_ConvertedValueLocal[1] =(float) ADC_ConvertedValue[1]/4096*3.3;
  38.         printf("CH0 = %f V \r\n",ADC_ConvertedValueLocal[0]);
  39.                                 printf("CH1 = %f V \r\n",ADC_ConvertedValueLocal[1]);


  40.      for(i=0;i<NPT;i++)
  41.                    {// 由于沒有采用外部觸發,所以使用軟件觸發ADC轉換
  42.                     ADC_SoftwareStartConvCmd(ADC_x, ENABLE);
  43.         while(!DMA_GetFlagStatus(DMA1_FLAG_TC1));
  44.                                    DMA_ClearFlag(DMA1_FLAG_TC1);            
  45.                                    ADC_SoftwareStartConvCmd(ADC1, DISABLE);
  46.                     lBUFIN0[i] =(float) ADC_ConvertedValue[0];
  47.                                 lBUFIN1[i] =(float) ADC_ConvertedValue[1];
  48.                    }
  49.                                                  cr4_fft_256_stm32(lBUFOUT,lBUFIN1,NPT);//調用STM32的DSP庫作FFT變換
  50.                                      powerMag(NPT);//計算頻點幅值                                
  51.              dsp_column1();//顯示x根柱條。        
  52.                         
  53.                                                  cr4_fft_256_stm32(lBUFOUT,lBUFIN0,NPT);//調用STM32的DSP庫作FFT變換
  54.                                                        //(FFT輸出序列,輸入序列,NPT=256)
  55.                                      powerMag(NPT);//計算頻點幅值                                
  56.              dsp_column0();//顯示x根柱條。

  57.         }
  58. }

  59. //顯示各頻點的柱條
  60. void dsp_column0(void)
  61. {
  62.    u8 i,j=80;
  63.          for(i=1;i<161;i+=2)
  64.            {    OLED_Fill(i,0,i,128,0x0000);    //填充區域的對角坐標
  65.                             OLED_Fill(i,0,i,lBUFMAG[j],RED);    //填充區域的對角坐標
  66.                             j --;                                                
  67.                  }
  68. }
  69. //顯示各頻點的柱條
  70. void dsp_column1(void)
  71. {
  72.    u8 i,j=80;
  73.          for(i=0;i<160;i+=2)
  74.            {    OLED_Fill(i,0,i,128,0x0000);    //填充區域的對角坐標
  75.                             OLED_Fill(i,0,i,lBUFMAG[j],GREEN);    //填充區域的對角坐標
  76.                             j --;                                                
  77.                  }
  78. }
  79. //x1,y1,x2,y2 填充區域的對角坐標
  80. //確保x1<=x2;y1<=y2 0<=x1<=127 0<=y1<=63                  
  81. //dot:0,清空;1,填充         
  82. void OLED_Fill(u8 x1,u8 y1,u8 x2,u8 y2,u16 dot)  //可以快
  83. {  
  84.         u8 x,y;  
  85.         for(x=x1;x<=x2;x++)
  86.         {
  87.                 for(y=y1;y<=y2;y++)  Gui_DrawPoint(x,y,dot);//畫一個點
  88.         }                                                                                                            
  89. }

  90. ////////////////////////////////////////////

  91. //計算各頻點的模值
  92. void powerMag(long nfill)   //計算頻點幅值
  93. {         int32_t lX,lY;
  94.                 uint32_t i,j;
  95.                 for (i=0; i < nfill; i++) //256
  96.                 {
  97.                         lX= (lBUFOUT[i]<<16)>>16; /* sine_cosine --> cos */
  98.                         lY= (lBUFOUT[i] >> 16);   /* sine_cosine --> sin */     
  99.                         {
  100.                                         float X=  64*((float)lX)/32768;
  101.                                         float Y = 64*((float)lY)/32768;
  102.                                         float Mag = sqrt(X*X+ Y*Y)/nfill;  // 先平方和,再開方sqrt
  103.                                   j= (long)(Mag*65536); //存儲求模后的數據
  104.                                   if(j>128) j=128;//避免顯示越界
  105.                                 lBUFMAG[i] =j;
  106.     }     
  107.   }
  108. }
復制代碼

所有程序51hei提供下載:
DMA2通道ADC_FFT.7z (216.08 KB, 下載次數: 169)

評分

參與人數 2黑幣 +115 收起 理由
楊雪飛 + 15 很給力!
admin + 100 共享資料的黑幣獎勵!

查看全部評分

分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏3 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:97554 發表于 2021-1-21 19:09 | 只看該作者
雖然不懂stm32,還是強烈支持一下。
回復

使用道具 舉報

板凳
ID:319585 發表于 2021-1-22 20:12 來自手機 | 只看該作者
這個不錯的,很好的東西。
回復

使用道具 舉報

地板
ID:90353 發表于 2021-1-27 23:06 | 只看該作者
thank  you very much!!!!!!!!!
回復

使用道具 舉報

5#
ID:89217 發表于 2021-1-28 08:14 | 只看該作者
加油,雖然我不會玩,看看也好
回復

使用道具 舉報

6#
ID:474173 發表于 2021-1-28 20:36 | 只看該作者
謝謝提供思路
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 99国产精品视频免费观看一公开 | 亚洲视频一区在线观看 | 亚洲精品视频在线播放 | 午夜小电影 | 欧美性成人 | 国产.com| 四虎影视免费观看 | 日韩三级免费网站 | 日韩一区中文字幕 | 中文字幕精品一区久久久久 | 五月婷婷在线播放 | 国产欧美精品 | 久久999 | 欧美色图另类 | www.色.com| 亚洲一区二区中文字幕 | 亚洲精品久久视频 | 国产精品欧美一区二区三区不卡 | 青青草原综合久久大伊人精品 | 日韩久久久久久 | 国产无人区一区二区三区 | 国产在线精品一区二区三区 | 一级黄a视频 | 欧美99| 国产精品观看 | 免费a级毛片在线播放 | 中文字幕第十五页 | 国产成人99久久亚洲综合精品 | 一区二区三区高清在线观看 | 久久久免费在线观看 | 在线观看免费毛片 | 2021天天干夜夜爽 | 国产成人精品一区二区在线 | 久久精品一级 | 国产成人一区在线 | 欧美久久视频 | 亚洲欧美国产精品久久 | 欧美精品一区在线 | 日韩在线视频一区二区三区 | 欧洲亚洲精品久久久久 | www.99热|