找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索

PIC單片機(jī)FFT音樂頻譜Proteus仿真程序

查看數(shù): 7836 | 評論數(shù): 8 | 收藏 6
關(guān)燈 | 提示:支持鍵盤翻頁<-左 右->
    組圖打開中,請稍候......
發(fā)布時間: 2020-1-3 11:50

正文摘要:

因為貼子附件大小問題,wav音樂文件沒有附上,請自行添加到目錄,打開FFT.pdsprj文件,然后雙擊Audio圖標(biāo)指定音樂wav位置,開始運行即可,稍后再發(fā)下電腦里以前做的東東

回復(fù)

ID:1136495 發(fā)表于 2024-11-27 10:32
audio無法使用怎么辦呀,proteus8.17
ID:1066888 發(fā)表于 2023-3-16 21:44
FFT自己編寫的C,不錯的內(nèi)容,學(xué)習(xí)一下
ID:651494 發(fā)表于 2022-12-20 15:14
王tt 發(fā)表于 2020-7-15 11:10
采樣數(shù)據(jù)存儲列表內(nèi)數(shù)據(jù)是怎么計算的呢?

把所有數(shù)據(jù)弄到EXECL,做個圖形就明白了
ID:512651 發(fā)表于 2020-11-16 17:58
感謝樓主共享學(xué)習(xí)資料!。
ID:801012 發(fā)表于 2020-7-15 11:10

采樣數(shù)據(jù)存儲列表內(nèi)數(shù)據(jù)是怎么計算的呢?
ID:767423 發(fā)表于 2020-7-9 21:37
單片機(jī)真好玩呀 發(fā)表于 2020-6-13 00:49
樓主能做一個用89c51實現(xiàn)音樂頻譜的嗎
  1. #include<STC12C5A60S2.H>
  2. typedef unsigned char uint8;
  3. typedef unsigned int  uint16;
  4. #define  channel  0x01                          //設(shè)置AD通道為 P1.0
  5. #define ADC_POWER   (1<<7)
  6. #define ADC_SPEEDHH (0x03<<5)
  7. #define ADC_START   (1<<3)
  8. #define PADCH       (1<<5)
  9. #define ADC_FLAG    (1<<4)
  10. #define P_3 P3 //32列掃描控制
  11. sbit sw=P1^2;//74HC154組切換控制位
  12. //放大128倍后的sin整數(shù)表(128)        
  13. 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,
  14.                         105,108,112,114,117,119,121,123,124,125,126,126,126,126,126,
  15.                                                 125,124,123,121,119,117,114,112,108,105,102,98,94,89,85,80,75,
  16.                                                 70,65,59,54,48,42,36,30,24,18,12,6,0,-6,-12,-18,-24,-30,-36,-42,
  17.                                                 -48,-54,-59,-65,-70,-75,-80,-85,-89,-94,-98,-102,-105,-108,-112,
  18.                                                 -114,-117,-119,-121,-123,-124,-125,-126,-126,-126,-126,-126,-125,
  19.                                                 -124,-123,-121,-119,-117,-114,-112,-108,-105,-102,-98,-94,-89,-85,
  20.                                                 -80,-75,-70,-65,-59,-54,-48,-42,-36,-30,-24,-18,-12,-6};

  21. //放大128倍后的cos整數(shù)表(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,
  24.                                                 -30,-36,-42,-48,-54,-59,-65,-70,-75,-80,-85,-89,-94,-98,-102,
  25.                                                 -105,-108,-112,-114,-117,-119,-121,-123,-124,-125,-126,-126,-126,
  26.                                                 -126,-126,-125,-124,-123,-121,-119,-117,-114,-112,-108,-105,-102,
  27.                                                 -98,-94,-89,-85,-80,-75,-70,-65,-59,-54,-48,-42,-36,-30,-24,-18,
  28.                                                 -12,-6,0,6,12,18,24,30,36,42,48,54,59,65,70,75,80,85,89,94,98,102,
  29.                                                 105,108,112,114,117,119,121,123,124,125,126,126};

  30. //采樣存儲序列表
  31. code char LIST_TAB[128] = {0,64,32,96,16,80,48,112,8,72,40,104,24,88,56,120,4,68,36,100,20,84,52,116,
  32.                            12,76,44,108,28,92,60,124,2,66,34,98,18,82,50,114,10,74,42,106,26,90,58,
  33.                                                    122,6,70,38,102,22,86,54,118,14,78,46,110,30,94,62,126,1,65,33,97,17,81,49,
  34.                                                    113,9,73,41,105,25,89,57,121,5,69,37,101,21,85,53,117,13,77,45,109,29,93,61,
  35.                                                    125,3,67,35,99,19,83,51,115,11,75,43,107,27,91,59,123,7,71,39,103,23,87,55,
  36.                                                    119,15,79,47,111,31,95,63,127};

  37. uint8 LED[32]={0x80,0x00,0xC0,0x00,0xE0,0x00,0xF0,0x00,
  38.                0xF8,0x00,0xFC,0x00,0xFE,0x00,0xFF,0x00,
  39.                0xff,0x80,0xff,0xC0,0xff,0xE0,0xff,0xF0,
  40.                            0xff,0xF8,0xff,0xFC,0xff,0xFE,0xff,0xFF,};
  41. uint8 COUNT=15,COUNT1=0,ADC_Count=0,LINE=15,G=0,T;
  42. uint8 i,j,k,b,p,anum,led=0;                 
  43. int Temp_Real,Temp_Imag,temp;                // 中間臨時變量  
  44. uint16 TEMP1,max=0;        
  45. int xdata Fft_Real[128];
  46. int xdata Fft_Image[128];               // fft的虛部
  47. uint8 xdata LED_TAB2[16];                                //記錄 漂浮物 是否需要 停頓一下
  48. uint8 xdata LED_TAB[16];                                //記錄紅色柱狀
  49. uint8 xdata LED_TAB1[16];                                //記錄 漂浮點
  50. /////////////shop60610364.taobao.com/////////
  51. void FFT()//基2fft
  52. {                 
  53.     for( i=1; i<=7; i++)                            /* for(1) */
  54.     {
  55.         b=1;
  56.         b <<=(i-1);                                 //碟式運算,用于計算隔多少行計算例如 第一極 1和2行計算
  57.         for( j=0; j<=b-1; j++)                      /* for (2) */
  58.         {
  59.             p=1;
  60.             p <<= (7-i);            
  61.             p = p*j;
  62.             for( k=j; k<128; k=k+2*b)               /* for (3)  */
  63.             {
  64.                 Temp_Real=Fft_Real[k];
  65.                                 Temp_Imag=Fft_Image[k];
  66.                                 temp=Fft_Real[k+b];
  67.                 Fft_Real[k]=Fft_Real[k]+((Fft_Real[k+b]*COS_TAB[p])>>7)+((Fft_Image[k+b]*SIN_TAB[p])>>7);
  68.                 Fft_Image[k]=Fft_Image[k]-((Fft_Real[k+b]*SIN_TAB[p])>>7)+((Fft_Image[k+b]*COS_TAB[p])>>7);
  69.                 Fft_Real[k+b]=Temp_Real-((Fft_Real[k+b]*COS_TAB[p])>>7)-((Fft_Image[k+b]*SIN_TAB[p])>>7);
  70.                 Fft_Image[k+b]=Temp_Imag+((temp*SIN_TAB[p])>>7)-((Fft_Image[k+b]*COS_TAB[p])>>7);          // 移位.防止溢出. 結(jié)果已經(jīng)是本值的 1/64               
  71.                 Fft_Real[k] >>= 1;            
  72.                 Fft_Image[k] >>= 1;
  73.                 Fft_Real[k+b] >>= 1;                 
  74.                 Fft_Image[k+b] >>= 1;
  75.                                                                               
  76.             }     
  77.         }
  78.     }

  79.         for(j=0;j<16;j++)//16分頻                                                                                         
  80.         {                                                                                                                                                         
  81.                 TEMP1=((((Fft_Real[j+1]* Fft_Real[j+1]))+((Fft_Image[j+1]*Fft_Image[j+1])))>>1);//求各頻段幅值
  82.                 if(TEMP1<1)TEMP1=0;
  83.                 LED_TAB[j]=TEMP1;        
  84.                 if(LED_TAB[j]>max)max=LED_TAB[j];
  85.         }
  86.         if(max>16)//分級量化
  87.         {
  88.           max/=16;
  89.           for(j=0;j<16;j++)LED_TAB[j]/=max;
  90.         }      
  91. }


  92. void delay2us(void)   //2us延時
  93. {
  94.     unsigned char a,b;
  95.     for(b=1;b>0;b--)
  96.         for(a=3;a>0;a--);
  97. }



  98. void Init()
  99. {  
  100.         
  101. //-----------------------------------------------------------------------------------

  102.      P1ASF = 0x02;                 //0000,0010, 將 P1.1 置成模擬口
  103.      AUXR1 &=0xFB;                 //1111,1011, 令 ADRJ=0
  104.          EADC=1;                                           //AD中斷打開
  105.          ADC_CONTR = ADC_POWER | ADC_SPEEDHH | ADC_START | channel;//1110 1001   1打開 A/D (ADC_POWER)轉(zhuǎn)換電源;11速度為90周期一次;
  106.                                                                            //0中斷標(biāo)志清零;1啟動adc(ADC_START);001AD通道打開(這里為P1.1);
  107. //-----------------------------------------------------------------------------------
  108.          
  109.          P2M0=1;
  110.      TMOD=0X12;                                          
  111.          TH0=0xb0;                                                                  
  112.          TL0=0xb0;
  113.          TH1=0xfe;                                                                                                   
  114.          TL1=0Xd4;
  115.          ET0=1;                                               //定時器0 打開
  116.          TR0=0;                                                      //關(guān)閉定時器
  117.          ET1=1;
  118.          TR1=1;
  119.          PT1=0;
  120.          PT0=1;
  121.      IPH=PADCH;
  122.          IP=PADC;                                           //中斷優(yōu)先級
  123.          EA=1;                                                   //總中斷打開
  124. }

  125. //----------------------------------------------------------------------------------------

  126. void ADC_Finish() interrupt 5
  127. {           ADC_CONTR &= !ADC_FLAG;
  128.             Fft_Real[LIST_TAB[ADC_Count]]=(int)((ADC_RES)<<1)+(ADC_RESL>>1)*2;//按LIST_TAB表里的順序,進(jìn)行存儲采樣值
  129.           if(ADC_Count<=127)ADC_Count++;
  130.           else {EADC=0;TR0=0;}                                                                                                                  
  131. }
  132. //---------------------------------------------------------------------------------------
  133. void LED_Display() interrupt 3                                         //中斷一次顯示一列
  134. {                  
  135.          TH1=0xfe;                                                                                                
  136.         TL1=0Xd4;                                                
  137.     G++;                                                         
  138.     if(G==33)G=1;
  139.         switch(G)                                                                     //往點陣屏填充一列的數(shù)據(jù)
  140.           {
  141.                 case 1:sw=1;anum=LED_TAB[0];P_3=0x00;break;
  142.                 case 2:anum=LED_TAB[0];P_3=0x01;break;
  143.                 case 3:anum=LED_TAB[1];P_3=0x02;break;
  144.                 case 4:anum=LED_TAB[1];P_3=0x03;break;
  145.                 case 5:anum=LED_TAB[2];P_3=0x04;break;
  146.                 case 6:anum=LED_TAB[2];P_3=0x05;break;
  147.                 case 7:anum=LED_TAB[3];P_3=0x06;break;
  148.                 case 8:anum=LED_TAB[3];P_3=0x07;break;
  149.                 case 9:anum=LED_TAB[4];P_3=0x08;break;
  150.                 case 10:anum=LED_TAB[4];P_3=0x09;break;
  151.                 case 11:anum=LED_TAB[5];P_3=0x0a;break;
  152.                 case 12:anum=LED_TAB[5];P_3=0x0b;break;
  153.                 case 13:anum=LED_TAB[6];P_3=0x0c;break;
  154.                 case 14:anum=LED_TAB[6];P_3=0x0d;break;
  155.                 case 15:anum=LED_TAB[7];P_3=0x0e;break;
  156.                 case 16:anum=LED_TAB[7];P_3=0x0f;break;
  157.                 case 17:sw=0;anum=LED_TAB[8];P_3=0x00;break;
  158.                 case 18:anum=LED_TAB[8];P_3=0x10;break;
  159.                 case 19:anum=LED_TAB[9];P_3=0x20;break;
  160.                 case 20:anum=LED_TAB[9];P_3=0x30;break;
  161.                 case 21:anum=LED_TAB[10];P_3=0x40;break;
  162.                 case 22:anum=LED_TAB[10];P_3=0x50;break;
  163.                 case 23:anum=LED_TAB[11];P_3=0x60;break;
  164.                 case 24:anum=LED_TAB[11];P_3=0x70;break;
  165.                 case 25:anum=LED_TAB[12];P_3=0x80;break;
  166.                 case 26:anum=LED_TAB[12];P_3=0x90;break;
  167.                 case 27:anum=LED_TAB[13];P_3=0xa0;break;
  168.                 case 28:anum=LED_TAB[13];P_3=0xb0;break;
  169.                 case 29:anum=LED_TAB[14];P_3=0xc0;break;
  170.                 case 30:anum=LED_TAB[14];P_3=0xd0;break;
  171.                 case 31:anum=LED_TAB[15];P_3=0xe0;break;
  172.                 case 32:anum=LED_TAB[15];P_3=0xf0;break;
  173.                     
  174.                 }

  175.            for(led=0;led<=anum;led++)                                 //遞增
  176.              { P0=LED[2*led+1];
  177.                    P2=LED[2*led];
  178.                    delay2us();
  179.                   
  180.                  }                                                                                 //遞減
  181.            for(;led>=0;led--)
  182.              { P0=LED[2*led+1];
  183.                    P2=LED[2*led];
  184.                    delay2us();
  185.                  }
  186. }
  187. //------------------------------------------------------------------------------------------------------------

  188. void Ad_Control() interrupt 1                                         //控制采樣率
  189. {
  190. ADC_CONTR = ADC_POWER | ADC_SPEEDHH| ADC_START | channel;         //開始AD采集
  191. }
  192.                                                                           
  193. //===============================================================================================================

  194. void main()
  195. {
  196.     uint8 i;
  197.          Init();
  198.         while(1)
  199.         {               
  200.                 ADC_Count=0;
  201.                 TR0=1;
  202.                 EADC=1;        //開啟定時器中斷0,開啟ADC
  203.                 while(ADC_Count<128);
  204.         for(i=0;i<128;i++)
  205.         {
  206.          Fft_Image[i]=0;
  207.         }
  208.                 FFT();//FFT運算并轉(zhuǎn)換為各頻段幅值                                                   
  209.                  
  210.         }
  211. }
復(fù)制代碼
ID:745514 發(fā)表于 2020-6-13 00:49
樓主能做一個用89c51實現(xiàn)音樂頻譜的嗎
ID:679307 發(fā)表于 2020-1-3 17:01
真是高手,學(xué)習(xí)了

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

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

快速回復(fù) 返回頂部 返回列表