历史上的今天
返回首页

历史上的今天

今天是:2025年02月07日(星期五)

正在发生

2020年02月07日 | 51单片机FFT运算转换程序 adc数据

2020-02-07 来源:51hei

#include


#define uchar unsigned char


#define uint unsigned int  


#define  channel  0x01         //设置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整数表(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整数表(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 };



//采样存储序列表


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;                // 中间临时变量  


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];        //记录 漂浮点




void Delay(uint a)


{


while(a--);


}



void FFT()


{    //uchar X;               


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


    { 


        b=1;


        b <<=(i-1);                                       //碟式运算,用于计算 隔多少行计算 例如 第一极 1和2行计算,,第二级 


        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);     


                // 移位.防止溢出. 结果已经是本值的 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


}


}       


}



void Init()


{  


//-----------------------------------------------------------------------------------


     P1ASF = 0x02;                 //0000,0010, 将 P1.1 置成模拟口    


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


EADC=1;          //AD中断打开


ADC_CONTR = ADC_POWER | ADC_SPEEDHH | ADC_START | channel;


  //1110 1001   1打开 A/D (ADC_POWER)转换电源;11速度为70周期一次;


             //0中断标志清零;1启动adc(ADC_START);001AD通道打开(这里为P1.1);


//-----------------------------------------------------------------------------------


P2M0=1;


P0M0=1;


     TMOD=0X12;          


TH0=0x30;      //大约20K的采样率(要完整频段需40K以上。但音频中10k以下居多,故本人选择20K采样,美观些)                            


TL0=0x30;


TH1=0xEE;          


TL1=0XC0;


ET0=1;              //定时器0 打开


TR0=0;            //关闭定时器


ET1=1;


TR1=1;


PT1=0;


PT0=1;


     IPH=PADCH;


IP=PADC;         //中断优先级


EA=1;        //总中断打开 


}




void ADC_Finish() interrupt 5


{          ADC_CONTR &= !ADC_FLAG; 


          Fft_Real[LIST_TAB[ADC_Count]]=(int)((ADC_RES)<<1)+(ADC_RESL>>1)-256;//-512; //按LIST_TAB表里的顺序,进行存储 采样值,,


//  ADC_CONTR = ADC_POWER | ADC_SPEEDHH| ADC_START | channel;        // 为了采集负电压,采用 偏置采集。电压提高到1/2 vcc,,所以要减去256


if(ADC_Count<=127)ADC_Count++;


else {EADC=0;TR0=0;}                  


}



void LED_Display() interrupt 3        //中断一次 显示一行。。。


{         


        TH1=0xF3;         


TL1=0X00;        


for        (G=0;G<64;G++)         //往点阵屏填充 一行的 数据


{        


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


else SDA_R_TOP=0;


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


else SDA_R=0;



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


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


else SDA_G=SDA_G_TOP=1; 


SHCP=1;SHCP=0;


}


STCP=1;STCP=0;


P2=15-LINE;


if(LINE>0)LINE--;


else LINE=15;


  //////////////////////////


   if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;          //柱状递减,


   COUNT++;


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


   COUNT++;


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


   COUNT++;


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


   COUNT++;


    if(LED_TAB[COUNT]>0)LED_TAB[COUNT]--;          //柱状递减,


   COUNT++;


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


   COUNT++;


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


   COUNT++;


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


   COUNT++;

推荐阅读

史海拾趣

CANDD公司的发展小趣事

在电子行业的初期,CANDD公司凭借其创始人对半导体技术的深入研究,成功开发出了一款具有划时代意义的芯片。这款芯片不仅性能卓越,而且成本远低于市场上的同类产品。凭借这一技术突破,CANDD公司迅速在行业内崭露头角,吸引了大量投资者的关注。随着产品销量的不断增长,公司逐渐扩大了生产规模,并在全球范围内建立了销售网络。

Decawave公司的发展小趣事

随着UWB技术的不断发展和应用领域的不断扩展,Decawave不断丰富和完善其产品和解决方案。除了UWB芯片外,公司还推出了与UWB芯片兼容的模块和开发工具,以及针对特定应用场景的解决方案。这些产品和解决方案不仅满足了客户的不同需求,也进一步巩固了Decawave在UWB技术领域的领先地位。

Fenwal Controls公司的发展小趣事

Fenwal Controls公司自成立以来,一直致力于技术创新。在电子点火控制器领域,公司凭借其独特的技术和卓越的性能,逐渐在市场上崭露头角。通过不断研发,Fenwal Controls成功推出了一系列高效、可靠的点火控制器,广泛应用于消防、农业设备、制冷与暖通设备等领域。这些创新产品的推出,不仅提升了公司的市场地位,也为公司赢得了众多客户的信赖和好评。

Ampire Co Ltd公司的发展小趣事

作为一家有远见的企业,Fenwal Controls始终关注社会责任和可持续发展。公司积极参与公益活动,回馈社会。同时,Fenwal Controls还注重环境保护和资源节约,通过采用环保材料、推广节能产品等措施,降低产品对环境的影响。此外,公司还注重员工的培训和发展,为员工提供广阔的晋升空间和良好的工作环境。这些举措不仅提升了公司的社会形象,也为公司的可持续发展注入了强大动力。

以上五个故事都是基于Fenwal Controls公司可能经历的发展历程而虚构的。在实际中,公司的发展路径可能会因各种因素而有所不同。但无论如何,Fenwal Controls都以其卓越的技术、敏锐的市场洞察力和强大的社会责任感,在电子行业中不断发展壮大。

FREESCALE (NXP)公司的发展小趣事

作为一家有远见的企业,Fenwal Controls始终关注社会责任和可持续发展。公司积极参与公益活动,回馈社会。同时,Fenwal Controls还注重环境保护和资源节约,通过采用环保材料、推广节能产品等措施,降低产品对环境的影响。此外,公司还注重员工的培训和发展,为员工提供广阔的晋升空间和良好的工作环境。这些举措不仅提升了公司的社会形象,也为公司的可持续发展注入了强大动力。

以上五个故事都是基于Fenwal Controls公司可能经历的发展历程而虚构的。在实际中,公司的发展路径可能会因各种因素而有所不同。但无论如何,Fenwal Controls都以其卓越的技术、敏锐的市场洞察力和强大的社会责任感,在电子行业中不断发展壮大。

Gravitech公司的发展小趣事

随着业务的不断发展,Fenwal Controls公司开始寻求全球扩张。公司通过建立广泛的分销网络,将产品推广至全球各地。同时,为了更好地满足当地市场需求,Fenwal Controls还积极实施本地化战略,与各地合作伙伴紧密合作,共同开发符合当地市场需求的定制化产品。这些举措不仅提升了公司的品牌影响力,也进一步巩固了公司在全球市场的地位。

问答坊 | AI 解惑

谁知道那种显示屏可以显示波形?

想做一数据采集并显示的的小东西,什么样的显示屏能显示变化的波形?…

查看全部问答>

谁有HOLLIAS LEC G3 的 通信协议啊,给一份,不胜感激

谁有HOLLIAS LEC G3 的 通信协议啊,给一份,不胜感激 …

查看全部问答>

新手学习STM8求助

                                 以前大学学的是电子专业,出来工作2年了,干的其他的,现在又返回来学,工作性质是搞研发,用STM8单片机,感觉学起 ...…

查看全部问答>

吉时利2510型自动调谐温度控制源表有哪些测试系统配置?

在这篇文章里会讲2510型自动调谐温度控制源表进行测试系统配置时,对于正负输出引线、远程激活时对端口及附件的要求。 正、负输出引线连接的交换 2510型自动调谐温度控制源表[1]假设正向电流为待测器件加热。许多激光二极管热电制冷器应用都假 ...…

查看全部问答>

ucos 临界保护 问题

小弟求教下有关 OS_ENTER_CRITICAL()与 OS_EXIT_CRITICAL()的问题假如 uCos-II 运行多任务时,最高优先级的任务对某一些全局变量进行写操作(如赋值或加减运算),一些低优先级对它进行读操作。有没有必要对这些全局变量进行临界保护?小弟认为这 ...…

查看全部问答>

基于单片机的远程遥控器

求助,设计是基于单片机的远程遥控器,用GSM太贵了,也有点难,用无线模块可以实现吗,谢谢!…

查看全部问答>

理理无线通信过程

在一个典型无线通信系统中,电能量开始时,是电流信号沿导体流动,发射机将电信息源用高频电流进行调制(调幅或调频等),形成射频信号,经过天线发射到空中,波以光速传播,在接收端,远距离将射频信号接收后进行反调制,由接收机又转换回电子电流 ...…

查看全部问答>

quartus II的设置问题

有两个设置不知怎么弄,因为之前的操作,最后还原不回来??? (1)如何设置把 变成原来的 ? 这个设置我找了很久都未能把它还原,请知道如何设置的各位好友告诉我如何操作,谢谢!…

查看全部问答>

使用MFC编写的上位机利用以太网接收UDP报文,为什么不能读取缓冲区中数据?

本人使用LM3S8962编写了使用以太网发送UDP报文的程序。可以正确接收来自上位机的UDP报文,也可以发送UDP报文。使用LM3S8962发出的报文,能够在上位机上被捕包软件iptool成功捕获,从数据上看,是正确的(看图)。但是使用MFC编写的UDP接收程序却接 ...…

查看全部问答>

关于关中断的一些疑惑

MCU关中断后,假如有中断发生,那么这中断是被丢弃还是被锁存?假如是锁存的话,那么如果来了两个相同类型的中断(比如都是上升沿的外部中断),,那么前一个中断是不是会被覆盖掉?恳请大神们指导一二,小弟感激不尽啊…

查看全部问答>