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

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 5707|回復: 4
收起左側

stm32f103官方DSP庫測試程序 可做128點、256點的fft運算,時間很短

  [復制鏈接]
ID:672840 發表于 2019-12-24 20:23 | 顯示全部樓層 |閱讀模式
基于stm32f103測試,103存儲較少,自己寫的fft程序不適合在103上運行,使用STM32官方的庫,可以做128點、256點的fft,運算時間很短;運算所需要的官方庫文件在user目錄下。
QFL%){$R0{$T8Y`0IV~NPH2.png

單片機源程序如下:
  1. #include "led.h"
  2. #include "delay.h"
  3. #include "key.h"
  4. #include "sys.h"
  5. #include "lcd.h"
  6. #include "usart.h"         
  7. #include "adc.h"
  8. #include "timer.h"
  9. #include "oled.h"
  10. #include "bmp.h"
  11. #include "stm32_dsp.h"
  12. #include "table_fft.h"
  13. #include "GetADValueBuffer.h"

  14. /*感謝大壯提供的頻率采集部分程序*/

  15. /***************************************************************************************************  很重要
  16. //#define Fs 400 //采樣頻率,在函數中沒定義,但是出的波形和它有關,具體體現在AD采樣頻率上,調節AD的采樣周期,
  17.                                                                                 和采樣函數GetADValueBuffer()的delay時間,可以設置其大小。數據裝入MATLAB,橫軸為點數,乘以頻域的分辨率即可。
  18.                                                                                 Fs=1/T;Tp=NT;Fs=NF;
  19.                                                                                 其中:
  20.                                                                                 Fs--時域采樣頻率;
  21.                                                                                 Tp--數據時間長度;
  22.                                                                                 T--時域采樣間隔;
  23.                                                                                 N--采樣點數;
  24.                                                                                 F--頻域采樣間隔;。。。。!分辨率
  25. PS:記得#include<math.h>,不然做sqrt時會出錯!并且編譯器不報錯。。
  26. ***************************************************************************************************/

  27. #define NPT 256 //fft點數,即N

  28. extern u16        count;
  29. extern u16        pinlv;

  30. extern long lBufInArray[NPT]; //輸入緩沖區
  31. extern long lBufOutArray[NPT/2]; //輸出緩沖區
  32. extern long lBufMagArray[NPT/2];  //變換后緩沖區


  33. int main(void)
  34. {
  35.         int i;
  36.   u16 adcx;
  37.         int gewei,shifenwei,baifenwei,qianfenwei;
  38.         float temp;
  39.         delay_init();                     //延時函數初始化         
  40.         NVIC_PriorityGroupConfig(NVIC_PriorityGroup_2);//設置中斷優先級分組為組2:2位搶占優先級,2位響應優先級
  41.         uart_init(115200);                 //串口初始化為115200
  42.                         
  43.          Adc_Init();                                  //ADC初始化
  44.          
  45.         TIM3_Int_Init(9999,7199);//改成1s
  46.          TIM5_Cap_Init(0XFFFF,72-1);        //以1Mhz的頻率計數
  47.          
  48.                  OLED_Init();                        //初始化OLED  
  49.                 OLED_Clear()          ;



  50.         while(1)
  51.         {
  52. //                adcx=Get_Adc_Average(ADC_Channel_1,10);

  53.                 GetADValueBuffer();

  54.                
  55. //                for(i=0;i<NPT;i++)
  56. //                {
  57. //                        printf("%ld\r\n",lBufInArray[i]);
  58. //                }
  59.                
  60.                
  61.                 cr4_fft_256_stm32(lBufOutArray, lBufInArray, NPT);
  62.                 GetPowerMag();
  63.                
  64. //                for(i=0;i<NPT/2;i++)
  65. //                {
  66. //                        printf("%ld\r\n",lBufOutArray[i]);
  67. //                }
  68.                
  69.                         for(i=0;i<NPT/2;i++)
  70.                 {
  71.                         printf("%ld\r\n",lBufMagArray[i]);
  72.                 }
  73.                
  74.                 printf("helloworld");
  75.                
  76. //                temp=(float)adcx*(3.3/4096);
  77. //                temp=temp/10;
  78.                 //printf("v=%.3f A\r\n",temp);
  79.                 //printf("f:%d Hz\r\n",pinlv);//打印頻率
  80.                
  81.                 gewei=(int)temp;
  82.                 shifenwei=(int)(temp*10);
  83.                 baifenwei=(int)(temp*100);
  84.                 qianfenwei=(int)(temp*1000);
  85. //               
  86. //                OLED_ShowCHinese(0,0,0);
  87. //                OLED_ShowCHinese(18,0,1);
  88. //                OLED_ShowCHinese(36,0,2);
  89. //                OLED_ShowCHinese(54,0,3);
  90. //                OLED_ShowCHinese(72,0,4);
  91. //                OLED_ShowCHinese(90,0,5);
  92. //                OLED_ShowCHinese(108,0,6);//中文,不得出現校名,注釋了
  93.                
  94.                 OLED_ShowString(0,3,"Ipp:");
  95.                 OLED_ShowNum(46,3,gewei,1,16);
  96.                 OLED_ShowString(54,3,".");
  97.                 OLED_ShowNum(62,3,shifenwei,1,16);
  98.                 OLED_ShowNum(70,3,baifenwei,1,16);
  99.                 OLED_ShowNum(78,3,qianfenwei,1,16);
  100.                 OLED_ShowString(90,3,"A");//電流
  101.                
  102.                 OLED_ShowString(0,6,"Fre:");
  103.                 OLED_ShowNum(46,6,pinlv,5,16);//最多5位數字
  104.                 OLED_ShowString(90,6,"Hz");

  105.                
  106.                 LED0=!LED0;
  107.                 delay_ms(1000);
  108.         }
  109. }
復制代碼
TS%R9BS{V7__UUBXY2[J{KO.png
所有資料51hei提供下載:
STM官方DSP庫測試.7z (238.55 KB, 下載次數: 145)

評分

參與人數 1黑幣 +50 收起 理由
admin + 50 共享資料的黑幣獎勵!

查看全部評分

回復

使用道具 舉報

ID:1089115 發表于 2023-7-20 16:56 | 顯示全部樓層
感謝樓主分享,比官方的點猛
回復

使用道具 舉報

ID:778733 發表于 2023-3-23 18:33 | 顯示全部樓層
收下了,謝樓主分享,很NB的
回復

使用道具 舉報

ID:334838 發表于 2020-6-1 11:17 | 顯示全部樓層
官方庫不是 4基的嘛?還能測128點?
回復

使用道具 舉報

ID:652775 發表于 2019-12-28 08:51 | 顯示全部樓層
收下了,謝樓主分享
回復

使用道具 舉報

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

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 久久久久久久av麻豆果冻 | 国产精品久久久久久久免费大片 | 亚洲福利在线视频 | 91成人在线 | 久久久91精品国产一区二区三区 | 91欧美精品成人综合在线观看 | 久久久青草婷婷精品综合日韩 | www.亚洲一区二区三区 | 国产成人免费视频 | 精品人伦一区二区三区蜜桃网站 | 国产精品久久福利 | 久久久久久国产 | 日韩一区二区三区四区五区六区 | 久久久久久免费毛片精品 | 精品久久久久久久久久久久久久久久久 | 97超级碰碰| 97日日碰人人模人人澡分享吧 | 亚洲精品丝袜日韩 | 国产婷婷色一区二区三区 | 欧美一级片免费看 | 99热视 | 国产天天操 | 在线观看黄色大片 | 91av国产在线视频 | 黄页网址在线观看 | 九九久久99 | 国产乱码高清区二区三区在线 | xxxcom在线观看 | 国产99久久久久 | 国产成人精品一区二 | 日韩高清在线观看 | 日韩中文久久 | 可以在线观看av的网站 | 久久久91精品国产一区二区三区 | 精品国产鲁一鲁一区二区张丽 | 日韩欧美在线精品 | 日本不卡一区二区三区 | 九色在线 | 中文一区二区视频 | 欧美成人自拍视频 | 欧美日韩综合一区 |