新聞中心

        EEPW首頁(yè) > 嵌入式系統(tǒng) > 設(shè)計(jì)應(yīng)用 > 用51單片機(jī)實(shí)現(xiàn)音頻信號(hào)的頻譜顯示

        用51單片機(jī)實(shí)現(xiàn)音頻信號(hào)的頻譜顯示

        作者: 時(shí)間:2016-12-02 來源:網(wǎng)絡(luò) 收藏
        思路:外來音頻信號(hào)經(jīng)過51單片機(jī),在單片機(jī)中進(jìn)行頻譜分析,并將結(jié)果顯示在LCD(12864或1602)上

        要求:頻譜顯示如同千千靜聽播放音樂時(shí)的頻譜顯示

        本文引用地址:http://www.104case.com/article/201612/324695.htm

        希望各位高手能給出詳細(xì)的解決方案,感激。。。。。。
        51做FFT有些困難,可以使用增強(qiáng)型(RAM)的51機(jī)子進(jìn)行

        參考程序:

        #include
        #define uchar unsigned char
        #define uint unsigned int
        #define channel 0x01 //設(shè)置AD通道為 P1.1
        //---------------------------------------------------------------------

        sbit SDA_R=P1^2;
        sbit SDA_R_TOP=P1^3;
        sbit SDA_G=P1^4;
        sbit SDA_G_TOP=P1^5;
        sbit STCP=P1^6;
        sbit SHCP=P1^7;
        //---------------------------------------------------------------------
        //----------------------------------------------------------------------------------------------------------------------
        //放大128倍后的sin整數(shù)表(128)
        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,

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

        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,

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

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

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

        //放大128倍后的cos整數(shù)表(128)
        code char COS_TAB[128] = { 127, 126, 126, 125, 124, 123, 121, 119, 117, 114, 112, 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, -36, -42, -48, -54, -59,

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

        126, -126, -126, -126, -125, -124, -123, -121, -119, -117, -114, -112, -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, 36, 42, 48, 54, 59, 65, 70,

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

        //采樣存儲(chǔ)序列表
        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,
        12, 76, 44, 108, 28, 92, 60, 124,
        2, 66, 34, 98, 18, 82, 50, 114,
        10, 74, 42, 106, 26, 90, 58, 122,
        6, 70, 38, 102, 22, 86, 54, 118,
        14, 78, 46, 110, 30, 94, 62, 126,
        1, 65, 33, 97, 17, 81, 49, 113,
        9, 73, 41, 105, 25, 89, 57, 121,
        5, 69, 37, 101, 21, 85, 53, 117,
        13, 77, 45, 109, 29, 93, 61, 125,
        3, 67, 35, 99, 19, 83, 51, 115,
        11, 75, 43, 107, 27, 91, 59, 123,
        7, 71, 39, 103, 23, 87, 55, 119,
        15, 79, 47, 111, 31, 95, 63, 127
        };


        uchar COUNT=0,COUNT1=0,ADC_Count=0,LINE=15,G,T;
        uchar i,j,k,b,p;
        int Temp_Real,Temp_Imag,temp; // 中間臨時(shí)變量
        uint TEMP1;
        int xdata Fft_Real[128];
        int xdata Fft_Image[128]; // fft的虛部
        uchar xdata LED_TAB2[64]; //記錄 漂浮物 是否需要 停頓一下
        uchar xdata LED_TAB[64]; //記錄紅色柱狀
        uchar xdata LED_TAB1[64]; //記錄 漂浮點(diǎn)


        void Delay(uint a)
        {
        while(a--);
        }

        void FFT()
        { //uchar X;
        for( i=1; i<=7; i++) /* for(1) */
        {
        b=1;
        b <<=(i-1); //碟式運(yùn)算,用于計(jì)算 隔多少行計(jì)算 例如 第一極 1和2行計(jì)算,,第二級(jí)
        for( j=0; j<=b-1; j++) /* for (2) */
        {
        p=1;
        p <<= (7-i);
        p = p*j;
        for( k=j; k<128; k=k+2*b) /* for (3) 基二fft */
        {
        Temp_Real = Fft_Real[k]; Temp_Imag = Fft_Image[k]; temp = Fft_Real[k+b];
        Fft_Real[k] = Fft_Real[k] + ((Fft_Real[k+b]*COS_TAB[p])>>7) + ((Fft_Image[k+b]*SIN_TAB[p])>>7);
        Fft_Image[k] = Fft_Image[k] - ((Fft_Real[k+b]*SIN_TAB[p])>>7) + ((Fft_Image[k+b]*COS_TAB[p])>>7);
        Fft_Real[k+b] = Temp_Real - ((Fft_Real[k+b]*COS_TAB[p])>>7) - ((Fft_Image[k+b]*SIN_TAB[p])>>7);
        Fft_Image[k+b] = Temp_Imag + ((temp*SIN_TAB[p])>>7) - ((Fft_Image[k+b]*COS_TAB[p])>>7);
        // 移位.防止溢出. 結(jié)果已經(jīng)是本值的 1/64
        Fft_Real[k] >>= 1;
        Fft_Image[k] >>= 1;
        Fft_Real[k+b] >>= 1;
        Fft_Image[k+b] >>= 1;

        }
        }
        }
        // X=((((Fft_Real[1]* Fft_Real[1]))+((Fft_Image[1]*Fft_Image[1])))>>7);
        Fft_Real[0]=Fft_Image[0]=0; //去掉直流分量
        // Fft_Real[63]=Fft_Image[63]=0;
        for(j=0;j<64;j++)
        {
        TEMP1=((((Fft_Real[j]* Fft_Real[j]))+((Fft_Image[j]*Fft_Image[j])))>>1);//求功率
        if(TEMP1>1)TEMP1--;
        else TEMP1=0;
        if(TEMP1>31)TEMP1=31;
        if(TEMP1>(LED_TAB[j]))LED_TAB[j]=TEMP1;
        if(TEMP1>(LED_TAB1[j]))
        { LED_TAB1[j]=TEMP1;
        LED_TAB2[j]=18; //提頓速度=12
        }
        }
        }


        上一頁(yè) 1 2 下一頁(yè)

        評(píng)論


        技術(shù)專區(qū)

        關(guān)閉
        主站蜘蛛池模板: 五常市| 乐东| 葫芦岛市| 朝阳市| 呼伦贝尔市| 岢岚县| 临潭县| 津市市| 拜城县| 济宁市| 富蕴县| 淄博市| 桃源县| 达州市| 独山县| 赫章县| 安龙县| 义马市| 漳州市| 化州市| 青神县| 广昌县| 辽宁省| 浑源县| 西城区| 垫江县| 武陟县| 武强县| 彭山县| 昌邑市| 额济纳旗| 西安市| 泗洪县| 富川| 富顺县| 平罗县| 鄂托克前旗| 察哈| 河西区| 繁昌县| 钟祥市|