欧美极品高清xxxxhd,国产日产欧美最新,无码AV国产东京热AV无码,国产精品人与动性XXX,国产传媒亚洲综合一区二区,四库影院永久国产精品,毛片免费免费高清视频,福利所导航夜趣136

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

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

51單片機FFT運算轉換程序 adc數據

  [復制鏈接]
跳轉到指定樓層
樓主
ID:80436 發表于 2015-5-22 00:36 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
  1. #include<STC12C5A.H>

  2. #define uchar unsigned char

  3. #define uint unsigned int  

  4. #define  channel  0x01         //設置AD通道為 P1.1

  5. //---------------------------------------------------------------------


  6. sbit  SDA_R=P1^2;

  7. sbit  SDA_R_TOP=P1^3;

  8. sbit  SDA_G=P1^4;       

  9. sbit  SDA_G_TOP=P1^5;

  10. sbit  STCP=P1^6;

  11. sbit  SHCP=P1^7;

  12. //---------------------------------------------------------------------

  13. //----------------------------------------------------------------------------------------------------------------------

  14. //放大128倍后的sin整數表(128)       

  15. code char SIN_TAB[128] = { 0, 6, 12, 18, 24, 30, 36, 42, 48, 54, 59, 65, 70, 75, 80, 85, 89, 94, 98, 102,


  16. 105, 108, 112, 114, 117, 119, 121, 123, 124, 125, 126, 126, 126, 126, 126, 125, 124, 123, 121, 119, 117, 114, 112,


  17. 108, 105, 102, 98, 94, 89, 85, 80, 75, 70, 65, 59, 54, 48, 42, 36, 30, 24, 18, 12, 6, 0, -6, -12, -18, -24, -30,


  18. -36, -42, -48, -54, -59, -65, -70, -75, -80, -85, -89, -94, -98, -102, -105, -108, -112, -114, -117, -119, -121,


  19. -123, -124, -125, -126, -126, -126, -126, -126, -125, -124, -123, -121, -119, -117, -114, -112, -108, -105, -102,


  20. -98, -94, -89, -85, -80, -75, -70, -65, -59, -54, -48, -42, -36, -30, -24, -18, -12, -6 };


  21. //放大128倍后的cos整數表(128)

  22. code char COS_TAB[128] = { 127, 126, 126, 125, 124, 123, 121, 119, 117, 114, 112, 108, 105, 102, 98, 94,


  23. 89, 85, 80, 75, 70, 65, 59, 54, 48, 42, 36, 30, 24, 18, 12, 6, 0, -6, -12, -18, -24, -30, -36, -42, -48, -54, -59,


  24. -65, -70, -75, -80, -85, -89, -94, -98, -102, -105, -108, -112, -114, -117, -119, -121, -123, -124, -125, -126, -


  25. 126, -126, -126, -126, -125, -124, -123, -121, -119, -117, -114, -112, -108, -105, -102, -98, -94, -89, -85, -80,


  26. -75, -70, -65, -59, -54, -48, -42, -36, -30, -24, -18, -12, -6, 0, 6, 12, 18, 24, 30, 36, 42, 48, 54, 59, 65, 70,


  27. 75, 80, 85, 89, 94, 98, 102, 105, 108, 112, 114, 117, 119, 121, 123, 124, 125, 126, 126 };


  28. //采樣存儲序列表

  29. code char LIST_TAB[128] = { 0, 64, 32, 96, 16, 80, 48, 112,

  30. 8, 72, 40, 104, 24, 88, 56, 120,

  31. 4, 68, 36, 100, 20, 84, 52, 116,

  32. 12, 76, 44, 108, 28, 92, 60, 124,

  33. 2, 66, 34, 98, 18, 82, 50, 114,

  34. 10, 74, 42, 106, 26, 90, 58, 122,

  35. 6, 70, 38, 102, 22, 86, 54, 118,

  36. 14, 78, 46, 110, 30, 94, 62, 126,

  37. 1, 65, 33, 97, 17, 81, 49, 113,

  38. 9, 73, 41, 105, 25, 89, 57, 121,

  39. 5, 69, 37, 101, 21, 85, 53, 117,

  40. 13, 77, 45, 109, 29, 93, 61, 125,

  41. 3, 67, 35, 99, 19, 83, 51, 115,

  42. 11, 75, 43, 107, 27, 91, 59, 123,

  43. 7, 71, 39, 103, 23, 87, 55, 119,

  44. 15, 79, 47, 111, 31, 95, 63, 127

  45. };



  46. uchar COUNT=0,COUNT1=0,ADC_Count=0,LINE=15,G,T;

  47. uchar i,j,k,b,p;                 

  48. int Temp_Real,Temp_Imag,temp;                // 中間臨時變量  

  49. uint TEMP1;       

  50. int xdata Fft_Real[128];

  51. int xdata Fft_Image[128];               // fft的虛部

  52. uchar xdata LED_TAB2[64];        //記錄 漂浮物 是否需要 停頓一下

  53. uchar xdata LED_TAB[64];        //記錄紅色柱狀

  54. uchar xdata LED_TAB1[64];        //記錄 漂浮點



  55. void Delay(uint a)

  56. {

  57. while(a--);

  58. }


  59. void FFT()

  60. {    //uchar X;               

  61.     for( i=1; i<=7; i++)                            /* for(1) */

  62.     {

  63.         b=1;

  64.         b <<=(i-1);                                       //碟式運算,用于計算 隔多少行計算 例如 第一極 1和2行計算,,第二級

  65.         for( j=0; j<=b-1; j++)                              /* for (2) */

  66.         {

  67.             p=1;

  68.             p <<= (7-i);            

  69.             p = p*j;

  70.             for( k=j; k<128; k=k+2*b)                /* for (3) 基二fft */

  71.             {

  72.                 Temp_Real = Fft_Real[k]; Temp_Imag = Fft_Image[k]; temp = Fft_Real[k+b];

  73.                 Fft_Real[k] = Fft_Real[k] + ((Fft_Real[k+b]*COS_TAB[p])>>7) + ((Fft_Image[k+b]*SIN_TAB[p])>>7);

  74.                 Fft_Image[k] = Fft_Image[k] - ((Fft_Real[k+b]*SIN_TAB[p])>>7) + ((Fft_Image[k+b]*COS_TAB[p])>>7);

  75.                 Fft_Real[k+b] = Temp_Real - ((Fft_Real[k+b]*COS_TAB[p])>>7) - ((Fft_Image[k+b]*SIN_TAB[p])>>7);

  76.                 Fft_Image[k+b] = Temp_Imag + ((temp*SIN_TAB[p])>>7) - ((Fft_Image[k+b]*COS_TAB[p])>>7);     

  77.                 // 移位.防止溢出. 結果已經是本值的 1/64               

  78.               Fft_Real[k] >>= 1;            

  79.                 Fft_Image[k] >>= 1;

  80.                Fft_Real[k+b]  >>= 1;                 

  81.                 Fft_Image[k+b]  >>= 1;

  82.                                                                               

  83.             }     

  84.         }

  85.     }

  86. //        X=((((Fft_Real[1]* Fft_Real[1]))+((Fft_Image[1]*Fft_Image[1])))>>7);

  87. Fft_Real[0]=Fft_Image[0]=0;         //去掉直流分量

  88. //        Fft_Real[63]=Fft_Image[63]=0;

  89. for(j=0;j<64;j++)         

  90. {         

  91. TEMP1=((((Fft_Real[j]* Fft_Real[j]))+((Fft_Image[j]*Fft_Image[j])))>>1);//求功率

  92. if(TEMP1>1)TEMP1--;

  93. else TEMP1=0;

  94. if(TEMP1>31)TEMP1=31;

  95. if(TEMP1>(LED_TAB[j]))LED_TAB[j]=TEMP1;       

  96. if(TEMP1>(LED_TAB1[j]))

  97. {   LED_TAB1[j]=TEMP1;

  98. LED_TAB2[j]=18;        //提頓速度=12

  99. }

  100. }      

  101. }


  102. void Init()

  103. {  

  104. //-----------------------------------------------------------------------------------

  105.      P1ASF = 0x02;                 //0000,0010, 將 P1.1 置成模擬口   

  106.      AUXR1 &=0xFB;                 //1111,1011, 令 ADRJ=0

  107. EADC=1;          //AD中斷打開

  108. ADC_CONTR = ADC_POWER | ADC_SPEEDHH | ADC_START | channel;

  109.   //1110 1001   1打開 A/D (ADC_POWER)轉換電源;11速度為70周期一次;

  110.              //0中斷標志清零;1啟動adc(ADC_START);001AD通道打開(這里為P1.1);

  111. //-----------------------------------------------------------------------------------

  112. P2M0=1;

  113. P0M0=1;

  114.      TMOD=0X12;          

  115. TH0=0x30;      //大約20K的采樣率(要完整頻段需40K以上。但音頻中10k以下居多,故本人選擇20K采樣,美觀些)                           

  116. TL0=0x30;

  117. TH1=0xEE;          

  118. TL1=0XC0;

  119. ET0=1;              //定時器0 打開

  120. TR0=0;            //關閉定時器

  121. ET1=1;

  122. TR1=1;

  123. PT1=0;

  124. PT0=1;

  125.      IPH=PADCH;

  126. IP=PADC;         //中斷優先級

  127. EA=1;        //總中斷打開

  128. }



  129. void ADC_Finish() interrupt 5

  130. {          ADC_CONTR &= !ADC_FLAG;

  131.           Fft_Real[LIST_TAB[ADC_Count]]=(int)((ADC_RES)<<1)+(ADC_RESL>>1)-256;//-512; //按LIST_TAB表里的順序,進行存儲 采樣值,,

  132. //  ADC_CONTR = ADC_POWER | ADC_SPEEDHH| ADC_START | channel;        // 為了采集負電壓,采用 偏置采集。電壓提高到1/2 vcc,,所以要減去256

  133. if(ADC_Count<=127)ADC_Count++;

  134. else {EADC=0;TR0=0;}                  

  135. }


  136. void LED_Display() interrupt 3        //中斷一次 顯示一行。。。

  137. {         

  138.         TH1=0xF3;         

  139. TL1=0X00;       

  140. for        (G=0;G<64;G++)         //往點陣屏填充 一行的 數據

  141. {       

  142. if(LED_TAB[G]<=LINE+16)SDA_R_TOP=1;

  143. else SDA_R_TOP=0;

  144.         if(LED_TAB[G]<=LINE)SDA_R=1;

  145. else SDA_R=0;


  146. if(LED_TAB1[G]==LINE){SDA_G_TOP=1;SDA_G=0;}

  147. else if(LED_TAB1[G]==(LINE+16)){SDA_G_TOP=0;SDA_G=1;}

  148. else SDA_G=SDA_G_TOP=1;

  149. SHCP=1;SHCP=0;

  150. }

  151. STCP=1;STCP=0;

  152. P2=15-LINE;

  153. if(LINE>0)LINE--;

  154. else LINE=15;

  155.   //////////////////////////

  156.    if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;          //柱狀遞減,

  157.    COUNT++;

  158.    if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;

  159.    COUNT++;

  160.    if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;

  161.    COUNT++;

  162.    if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;

  163.    COUNT++;

  164.     if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;          //柱狀遞減,

  165.    COUNT++;

  166.    if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;

  167.    COUNT++;

  168.    if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;

  169.    COUNT++;

  170.    if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;

  171.    COUNT++;

  172.    if(COUNT>=64)COUNT=0;


  173.      //漂浮物遞減

  174.    if(LED_TAB2[COUNT1]==0)        //判斷是否需要停頓          

  175.    {

  176.    if(LED_TAB1[COUNT1]>LED_TAB[COUNT1])LED_TAB1[COUNT1]--;//大于柱狀則遞減(保持漂浮物在柱狀之上)

  177.    }

  178.    else LED_TAB2[COUNT1]--;

  179.    COUNT1++;

  180.    if(LED_TAB2[COUNT1]==0)

  181.    {

  182.    if(LED_TAB1[COUNT1]>LED_TAB[COUNT1])LED_TAB1[COUNT1]--;

  183.    }

  184.    else LED_TAB2[COUNT1]--;

  185.    COUNT1++;

  186.    if(LED_TAB2[COUNT1]==0)        //判斷是否需要停頓          

  187.    {

  188.    if(LED_TAB1[COUNT1]>LED_TAB[COUNT1])LED_TAB1[COUNT1]--;//大于柱狀則遞減(保持漂浮物在柱狀之上)

  189.    }

  190.    else LED_TAB2[COUNT1]--;

  191.    COUNT1++;

  192.    if(LED_TAB2[COUNT1]==0)

  193.    {

  194.    if(LED_TAB1[COUNT1]>LED_TAB[COUNT1])LED_TAB1[COUNT1]--;

  195.    }

  196.    else LED_TAB2[COUNT1]--;

  197.    COUNT1++;

  198.    if(COUNT1>=64)COUNT1=0;

  199. }


  200. void Ad_Control() interrupt 1        //控制采樣率

  201. {

  202. ADC_CONTR = ADC_POWER | ADC_SPEEDHH| ADC_START | channel;        //開始AD采集

  203. }

  204.   //==============================================================================================================

  205. //        *******************          main()        *********************************         

  206. //===============================================================================================================


  207. void main()

  208. {

  209.         Init();

  210. while(1)

  211. {       

  212. ADC_Count=0;

  213. TR0=1;

  214. EADC=1;          //開啟定時器中斷0,,開啟ADC

  215. while(ADC_Count<128);

  216. FFT();

  217. //FFT運算。并轉換為 功率值。。。          

  218. //        TR1=1;         

  219. }

  220. }
復制代碼


評分

參與人數 1威望 +8 黑幣 +8 收起 理由
王朗的誘惑 + 8 + 8 贊一個!

查看全部評分

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

使用道具 舉報

無效樓層,該帖已經被刪除
板凳
ID:122055 發表于 2016-5-19 21:29 | 只看該作者
想問下。這個放大整數倍的這個是固定的嗎??
回復

使用道具 舉報

地板
ID:122055 發表于 2016-5-19 21:42 | 只看該作者
想問下這個FFT的運算是大概什么原理呢??
回復

使用道具 舉報

5#
ID:120851 發表于 2016-7-14 16:38 | 只看該作者
好東西,很有用。
回復

使用道具 舉報

6#
ID:130626 發表于 2016-7-15 21:34 | 只看該作者
研究一下,看能不能拿為己用。哈哈
回復

使用道具 舉報

7#
ID:130196 發表于 2016-7-16 16:40 來自觸屏版 | 只看該作者
怎么收藏帖子
回復

使用道具 舉報

8#
ID:138343 發表于 2016-9-25 08:02 | 只看該作者
記錄 漂浮物 是否需要 停頓一下,這個效果很不錯
回復

使用道具 舉報

9#
ID:75062 發表于 2017-7-14 10:39 | 只看該作者
謝謝分享
回復

使用道具 舉報

10#
ID:377035 發表于 2018-7-22 06:49 | 只看該作者
FFT計算,你的單片機內存夠用嗎?為什么我用XDATA存儲數組值,用LCD顯示,為什么完全不對啊?






回復

使用道具 舉報

11#
ID:407843 發表于 2018-10-26 21:18 | 只看該作者
好東西
回復

使用道具 舉報

12#
ID:553031 發表于 2019-9-29 15:31 來自觸屏版 | 只看該作者
研究一下,看能不能拿為己用
回復

使用道具 舉報

13#
無效樓層,該帖已經被刪除
14#
無效樓層,該帖已經被刪除
15#
無效樓層,該帖已經被刪除
16#
ID:582255 發表于 2021-1-26 15:44 | 只看該作者
都是亂的
回復

使用道具 舉報

17#
無效樓層,該帖已經被刪除
18#
ID:1018819 發表于 2022-4-18 10:18 來自觸屏版 | 只看該作者
想認識一下樓主
回復

使用道具 舉報

19#
無效樓層,該帖已經被刪除
您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

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

Powered by 單片機教程網

快速回復 返回頂部 返回列表