




已阅读5页,还剩2页未读, 继续免费阅读
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
#include#define uchar unsigned char#define uint unsigned int #define channel 0x01 /设置AD通道为 P1.1/-sbit SDA_R=P12;sbit SDA_R_TOP=P13;sbit SDA_G=P14;sbit SDA_G_TOP=P15; sbit STCP=P16;sbit SHCP=P17;/-/-/放大128倍后的sin整数表(128)code char SIN_TAB128 = 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_TAB128 = 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_TAB128 = 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_Real128; int xdata Fft_Image128; / fft的虚部 uchar xdata LED_TAB264;/记录 漂浮物 是否需要 停顿一下uchar xdata LED_TAB64;/记录红色柱状 uchar xdata LED_TAB164;/记录 漂浮点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; k7) + (Fft_Imagek+b*SIN_TABp)7); Fft_Imagek = Fft_Imagek - (Fft_Realk+b*SIN_TABp)7) + (Fft_Imagek+b*COS_TABp)7); Fft_Realk+b = Temp_Real - (Fft_Realk+b*COS_TABp)7) - (Fft_Imagek+b*SIN_TABp)7); Fft_Imagek+b = Temp_Imag + (temp*SIN_TABp)7) - (Fft_Imagek+b*COS_TABp)7); / 移位.防止溢出. 结果已经是本值的 1/64 Fft_Realk = 1; Fft_Imagek = 1; Fft_Realk+b = 1; Fft_Imagek+b = 1; /X=(Fft_Real1* Fft_Real1)+(Fft_Image1*Fft_Image1)7); Fft_Real0=Fft_Image0=0; /去掉直流分量/ Fft_Real63=Fft_Image63=0;for(j=0;j1);/求功率if(TEMP11)TEMP1-;else TEMP1=0;if(TEMP131)TEMP1=31; if(TEMP1(LED_TABj)LED_TABj=TEMP1;if(TEMP1(LED_TAB1j) LED_TAB1j=TEMP1;LED_TAB2j=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_RealLIST_TABADC_Count=(int)(ADC_RES)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;G64;G+) /往点阵屏填充 一行的 数据if(LED_TABG=LINE+16)SDA_R_TOP=1;else SDA_R_TOP=0; if(LED_TABG0)LINE-;else LINE=15; / if(LED_TABCOUNT0)LED_TABCOUNT-; /柱状递减, COUNT+; if(LED_TABCOUNT0)LED_TABCOUNT-; COUNT+; if(LED_TABCOUNT0)LED_TABCOUNT-; COUNT+; if(LED_TABCOUNT0)LED_TABCOUNT-; COUNT+; if(LED_TABCOUNT0)LED_TABCOUNT-; /柱状递减, COUNT+; if(LED_TABCOUNT0)LED_TABCOUNT-; COUNT+; if(LED_TABCOUNT0)LED_TABCOUNT-; COUNT+; if(LED_TABCOUNT0)LED_TABCOUNT-; COUNT+; if(COUNT=64)COUNT=0; /漂浮物递减 if(LED_TAB2COUNT1=0)/判断是否需要停顿 if(LED_TAB1COUNT1LED_TABCOUNT1)LED_TAB1COUNT1-;/大于柱状则递减(保持漂浮物在柱状之上) else LED_TAB2COUNT1-; COUNT1+; if(LED_TAB2COUNT1=0) if(LED_TAB1COUNT1LED_TABCOUNT1)LED_TAB1COUNT1-; else LED_TAB2COUNT1-; COUNT1+; if(LED_TAB2COUNT1=0)/判断是否需要停顿 if(LED_TAB1COUNT1LED_TABCOUNT1)LED_TAB1COUNT1-;/大于柱状则递减(保持漂浮物在柱状之上) else LED_TAB2COUNT1-; COUNT1+; if(LED_TAB2COUNT1=0) if(LED_TAB1COUNT1LED_TABCOUNT1)LED_TAB1COUNT1-; else LED_TAB2COUNT1-; COUNT1+; if(C
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 2025北京首都医科大学附属北京朝阳医院招聘18人(第三次)模拟试卷有完整答案详解
- 2025年温岭市公开选调公务员32人模拟试卷及答案详解(必刷)
- 2025年4月重庆医科大学附属第三医院招聘医师、医技、护理、行政、其他岗位模拟试卷附答案详解(黄金题型)
- 2025江西九江市武宁县医疗卫生单位招聘劳务派遣人员3人模拟试卷含答案详解
- 2025广东水利电力职业技术学院招聘32人考前自测高频考点模拟试题及1套参考答案详解
- 2025河南投资集团工程管理有限公司社招1人考前自测高频考点模拟试题及参考答案详解一套
- 2025年商洛丹源电力(集团)有限责任公司招聘(2人)考前自测高频考点模拟试题及答案详解(名校卷)
- 2025年黑龙江省交通投资集团有限公司招聘95人考前自测高频考点模拟试题及完整答案详解1套
- 2025年泉州安溪县部分公办学校专项招聘编制内新任教师(三)模拟试卷及答案详解(全优)
- 2025广西钦州市北部湾大学招聘高层次人才53人模拟试卷及答案详解(夺冠)
- 华为干部管理
- 《新员工进车间培训》课件
- 2025年国家电网有限公司招聘笔试参考题库含答案解析
- DB61T-地热能利用碳减排计算与能效评价
- 推进产业工人队伍建设改革的实践与思考
- 钢板桩施工记录表1
- 蜜蜂:绿色农业的推动者
- 【《城市文化与城市可持续发展探究:以S市为例》10000字(论文)】
- 烤烟房租赁合同模板
- 《宣讲有道:晚清宣讲小说的伦理叙事》随笔
- 信创的基础知识培训课件
评论
0/150
提交评论