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

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

QQ登錄

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

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

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

  [復(fù)制鏈接]
ID:716413 發(fā)表于 2021-1-21 15:48 | 顯示全部樓層 |閱讀模式
STM32F103C8_DMA方式2路ADC采集雙聲道音頻FFT變換顯示頻譜
這是一個(gè)完整的項(xiàng)目,沒(méi)有加狗
關(guān)鍵點(diǎn)在于多路采集,F(xiàn)FT庫(kù)函數(shù)應(yīng)用,這個(gè)FFT函數(shù)用匯編優(yōu)化,速度比較快。
當(dāng)然,本系統(tǒng)速度瓶頸在畫(huà)點(diǎn)顯示。后期我采用直接寫顯存,就比較快了。
上段忙,這也是我對(duì)同道的一點(diǎn)小小的貢獻(xiàn) 51hei圖片20210121160005.jpg

單片機(jī)源程序如下:
  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采樣點(diǎn)數(shù)

  10. long lBUFMAG[NPT+NPT];                //存儲(chǔ)求模后的數(shù)據(jù)[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);//計(jì)算頻點(diǎn)幅值
  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. // 局部變量,用于保存轉(zhuǎn)換計(jì)算后的電壓值         
  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);  //清屏函數(shù)            

  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.                    {// 由于沒(méi)有采用外部觸發(fā),所以使用軟件觸發(fā)ADC轉(zhuǎn)換
  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);//調(diào)用STM32的DSP庫(kù)作FFT變換
  50.                                      powerMag(NPT);//計(jì)算頻點(diǎn)幅值                                
  51.              dsp_column1();//顯示x根柱條。        
  52.                         
  53.                                                  cr4_fft_256_stm32(lBUFOUT,lBUFIN0,NPT);//調(diào)用STM32的DSP庫(kù)作FFT變換
  54.                                                        //(FFT輸出序列,輸入序列,NPT=256)
  55.                                      powerMag(NPT);//計(jì)算頻點(diǎn)幅值                                
  56.              dsp_column0();//顯示x根柱條。

  57.         }
  58. }

  59. //顯示各頻點(diǎn)的柱條
  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);    //填充區(qū)域的對(duì)角坐標(biāo)
  65.                             OLED_Fill(i,0,i,lBUFMAG[j],RED);    //填充區(qū)域的對(duì)角坐標(biāo)
  66.                             j --;                                                
  67.                  }
  68. }
  69. //顯示各頻點(diǎn)的柱條
  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);    //填充區(qū)域的對(duì)角坐標(biāo)
  75.                             OLED_Fill(i,0,i,lBUFMAG[j],GREEN);    //填充區(qū)域的對(duì)角坐標(biāo)
  76.                             j --;                                                
  77.                  }
  78. }
  79. //x1,y1,x2,y2 填充區(qū)域的對(duì)角坐標(biāo)
  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);//畫(huà)一個(gè)點(diǎn)
  88.         }                                                                                                            
  89. }

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

  91. //計(jì)算各頻點(diǎn)的模值
  92. void powerMag(long nfill)   //計(jì)算頻點(diǎn)幅值
  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;  // 先平方和,再開(kāi)方sqrt
  103.                                   j= (long)(Mag*65536); //存儲(chǔ)求模后的數(shù)據(jù)
  104.                                   if(j>128) j=128;//避免顯示越界
  105.                                 lBUFMAG[i] =j;
  106.     }     
  107.   }
  108. }
復(fù)制代碼

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

評(píng)分

參與人數(shù) 2黑幣 +115 收起 理由
楊雪飛 + 15 很給力!
admin + 100 共享資料的黑幣獎(jiǎng)勵(lì)!

查看全部評(píng)分

回復(fù)

使用道具 舉報(bào)

ID:97554 發(fā)表于 2021-1-21 19:09 | 顯示全部樓層
雖然不懂stm32,還是強(qiáng)烈支持一下。
回復(fù)

使用道具 舉報(bào)

ID:319585 發(fā)表于 2021-1-22 20:12 來(lái)自手機(jī) | 顯示全部樓層
這個(gè)不錯(cuò)的,很好的東西。
回復(fù)

使用道具 舉報(bào)

ID:90353 發(fā)表于 2021-1-27 23:06 | 顯示全部樓層
thank  you very much!!!!!!!!!
回復(fù)

使用道具 舉報(bào)

ID:89217 發(fā)表于 2021-1-28 08:14 | 顯示全部樓層
加油,雖然我不會(huì)玩,看看也好
回復(fù)

使用道具 舉報(bào)

ID:474173 發(fā)表于 2021-1-28 20:36 | 顯示全部樓層
謝謝提供思路
回復(fù)

使用道具 舉報(bào)

本版積分規(guī)則

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

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

快速回復(fù) 返回頂部 返回列表
主站蜘蛛池模板: 精品福利一区二区三区 | 一区二区三区国产精品 | 在线免费观看a级片 | 久久久久久亚洲国产精品 | 国产精品国产亚洲精品看不卡15 | 99pao成人国产永久免费视频 | 欧美精品综合在线 | 日本久久网站 | 日韩欧美国产精品一区二区 | 日韩一级免费 | 一区二区成人 | 亚州激情 | 精品在线免费看 | 91久久精品 | 四虎最新| 午夜免费视频 | 狠狠操狠狠干 | 97精品国产一区二区三区 | 欧美男人天堂 | 国产午夜精品一区二区三区在线观看 | 国产69精品久久99不卡免费版 | 天堂中文资源在线 | 综合久久综合久久 | 欧美日韩一二区 | 亚洲第一av | 夜夜夜操| 91视频电影 | 欧美国产日韩一区 | 国产91精品久久久久久久网曝门 | 亚洲免费久久久 | 亚洲国产精品99久久久久久久久 | 久久天天躁狠狠躁夜夜躁2014 | 免费看a | 久久久久久久一区二区三区 | 亚洲啪啪 | 欧美在线精品一区 | 日韩在线免费视频 | 亚洲精品中文字幕 | 日本午夜精品一区二区三区 | 国产激情视频在线观看 | 日本公妇乱淫xxxⅹ 国产在线不卡 |