电子设计实验报告_第1页
电子设计实验报告_第2页
电子设计实验报告_第3页
电子设计实验报告_第4页
电子设计实验报告_第5页
已阅读5页,还剩11页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

-z.电子系统设计实验报告姓名李浩然指导教师贾立新班级自动化0903学院信息工程学院提交日期2010/12/4一,设计题目基于SOC单片机的数字化语音存储与回放系统设计要求:〔1〕前置放大器增益可调,功率放大器输出功率≥0.5W〔2〕带通滤波器:通带为300Hz~3.4kHz。〔3〕ADC:采样频率fs=8kHz,字长8位。〔4〕语音存储时间≥60秒。〔5〕DAC:变换频率fc=8kHz,字长8位。〔6〕回放语音质量良好。〔7〕采用语音压缩算法,增加录放时间。二,方案设计语音的存储与回放系统将语音信号转化为电信号,经放大、滤波处理后通过A/D转换器转化为数字信号,然后将数字化的语音信号存放在大容量的存储器中;回放时,从存储器中取出数字化的语音信号,经D/A转化器转化为模拟信号,经滤波放大后驱动扬声器发出声音。模拟子系统设计前置放大电路设计在语音存储与回放系统中,通过麦克风将声音信号转化为电信号。麦克风内部含有一个电容元件和场效应管构成的内部前置放大器。电容随机械振动发生变化,从而产生与声波成比例的变化电压。麦克风在使用时需要通过一个电阻R1连接到电源对其进展偏置。R1的阻值决定了麦克风的输出电阻和增益,通常在1~10kΩ之间。麦克风输出的电信号比拟微弱,信号增值在1~20mV之间。前置放大器就是对麦克风输出的语音信号进展放大一边对其进一步处理。前置放大电路有两种设计方案。一种方案是针对双麦克风设计的前置放大器,由一级差分放大器和一级增益可调反向放大器组成的设计方案。本次系统设计中,为了是器材简单,使用了后一种,电路图如下所示带通滤波器设计语音存储与回放系统中,模拟量输入通道和输出通道均需要带通滤波器。带通滤波器的通带范围为300Hz~3。4kHz,主要实现的功能如下:保证300Hz~3。4kHz的语音信号不失真的通过滤波器。滤除带通外的低频信号,减少工频等分量的干扰,减小噪声影响。滤除带通外的告辞谐波信号,减少因8kHz采样率引起的混叠失真,根据实际情况,该上限频率在2。7kHz左右。带通滤波器按品质因数Q的大笑分为窄带滤波器〔Q〉10〕和宽带滤波器〔Q〈10〕两种。在本系统中,上线频率fH400Hz,下线频率fL=300Hz,带通滤波器的中心频率f0与品质因数Q分别为显然,Q〈10。过带通滤波器为宽带带通滤波器,宽带带通滤波器一般采用高筒滤波器和低通滤波器级联构成。以下给出4阶低通滤波器和4阶高筒滤波器设计过程。四阶低通滤波器由两个二阶低通滤波器串联而成,二阶低通滤波器如下列图:计算二阶四阶低通滤波器参数值前一个低通滤波器Q1=0.541,后一个低通滤波器Q2=1.306根据对电路的交流分析,传递函数为将上式与原理图中的二阶低通滤波器传递函数QUOTE,比拟得QUOTEQ=设QUOTE得到滤波器中各项参数的计算公式为解的参数值为Q=0.541假设C2=2200pF,基准电阻R0=1/2QUOTEfHC2,R0=21.29KQUOTEC1=4Q^2(1+A0)C2=5151pF.R7=R0/(2QA0)=19.67KQUOTER8=A0*R1=19.67kQUOTER9=R0/[(2Q(1+A0))=9.83KQUOTEQ=1.306假设C2=2200pF,基准电阻R0=1/2QUOTEfcC2,R0=24.11KQUOTEC1=4Q^2(1+A0)C2=0.0313uFR10=R0/(2QA0)=8.15KQUOTER11=A0*R1=8.2KQUOTER12=R0/[(2Q(1+A0))=4.07KQUOTE四阶高通滤波器由两个二阶高通滤波器串联而成,二阶低通滤波器如下列图:其中C1,R1构成高通级,通过R2的正反应对Q进展控制。利用前面公式,可以计算出如下解Q=0.541C1=C2=C0=0.033uFR0=1/2QUOTEfLC0=16.08KQUOTEC3=C0/A0=0.033uFR13=R0/[Q(2+1/A0)]=11.88KQUOTER14=R0[Q(1+2A0)]=21.75KQUOTEQ=1.306C1=C2=C0=0.033uFC3=C0/A0=0.033uFR15=R0/[Q(2+1/A0)]=4.10KQUOTER16=R0[Q(1+2A0)]=62.98KQUOTE利用以上参数,可以得到最后的电路图为下列图:〔2〕数字子系统设计键盘接口设计:键盘采用4*4矩阵式键盘,Y0~Y3为四根列扫描信号输出线,轮流将每一列置为低电平。*0~*3为四根行输入线,但没有键按下时,*0~*3被上拉电阻拉成高电平。KEYCLK为键盘接口的时钟信号,可由单片机IO引脚提供,也可由外部有源晶体振荡器或RC振荡器提供。DAV为键值有效信号,当按键有效时,DAV产生由高到低的跳变,向单片机发出外部中断请求信号,单片机通过中断效劳程序从键盘接口读取四位键值。顶层原理图如下LCD12864模块并行接口设计:LCD12864作为单片机的外部设备,单片机通过MOV*指令对LCD12864内部存放器进展读写。C8051F360的P1端口先送出低8位地址,然后/WR或/RD信号有效,因此可用低8为地址线中的A1,A0作为LCD12864的RW与RS。E信号为高电平有效,时序上滞后于RS,RW信号,因此可以利用/WR与/RD信号通过一与非门得到E信号,为了防止单片机在访问其他外设时对LCD12864产生误操作,E信号的产生同时还应加一片选信号LCDCS。顶层原理图如下C8051F360与FPGA接口:C8051F360单片机通过一个外部数据存储器接口来寻址片外的数据存储器与外部设备。在设计中,把EMIF设置成引脚复用模式。选择不带块选择的分片模式。把外部数据接口引脚设置为推拉式输出。在ALE高电平期间,P1口先送出低8位地址,在ALE下降沿时刻,P1口的低8位地址处于稳定状态,因此可用一地址锁存器在ALE下降沿时刻将地址锁存。随后,读写数据出现在P1口上,同时/RD与/WR信号有效。在/RD或/WR信号的上升沿前,数据被读入单片机或被写入殉职的数据存储单元。顶层原理图如下系统软件设计语音存储回放系统软件的根本功能是通过按键控制系统实现录音和放音。录音时,采集语音信号并将采集的数据存入M25P16中,放音时,从M25P16中读取数据送入DAC,系统分为以下几个框架人机接口的功能设计M25P16的读写方案设计A/D和D/A转换器的控制C8051F360单片机内部资源的使用主程序流程图如下键盘中断效劳程序流程图A/D中断效劳程序流程图定时器T2中断效劳程序流程图三,系统调试单片机局部的调试单片机局部的调试主要是对系统局部进展调试,将EC5仿真器将单片机最小系统与PC机相连,采用C8051F单片机的集成开发环境SiliconLaboratoryIDE进展调试,主要步骤如下调试键盘显示程序测试单片机对M25P16读写是否正常测试C8051F360单片机的A/D和D/A转换器模拟局部的调试麦克风和前置放大器的调试带通滤波器的调试音频功放电路的调试四,实验总结通过这次试验,对C8051F360和FPGA有了深刻的理解,通过整个系统的设计,发现,容易出错的地方往往不是程序代码语法或者输入错误,而是系统逻辑问题,因此在以后的系统设计中,要重视逻辑的建立,在做系统之前,首先要画出没有挑剔的程序流程图,因为这是系统的思想路径,只有有了明确正确的路径,才能踏踏实实的编写程序,同时也会发现,以前恐惧的几百行代码已经变得多么易于理解了。还有,再写好代码后,最重要的就是调试,很多时候,实际和自己的理论判断并不是相靠拢的,这时我们要相信实际,逐步的调试,最终实现系统的完美设计。五,程序代码//voicesampleandplay//designangdonebyhaoranleein2011/12/4#defineucharunsignedchar#defineWDATADDR0*C009#defineRDATADDR0*C00B#defineWCOMADDR0*C008#defineRCOMADDR0*C00A#defineKEYCS0*C00C;ucharcodehanzi[]="语音存储回放";voidCheckLcd(){uchartemp=0*00;uchar*data*addr; //*datameansthedataistheoutsidememorywhile(1){addr=RCOMADDR;temp=*addr;temp&=0*80; //ifbusyif(temp==0*00)break;}}//Initialoutmemoryvoid*ramInit(void){SFRPAGE=0*0F;EMI0CN=0*00;//visit*ram 0000-00FFEMI0CF=0*07;//ALEboradis3system,seekforaddressdonotneedblock//EMI0TC=SFRPAGE=0*00;return;}//writedatatothelcdvoidWriteData(ucharm){uchar*data*addr;CheckLcd();addr=WDATADDR;*addr=m;}//writecommandtothelcdvoidWriteCom(ucharn){ uchar*data*addr; CheckLcd(); addr=WCOMADDR; *addr=n;}//LcdinitialvoidInsitiLcd(){WriteCom(0*30); //setasbasiccommandWriteCom(0*01);//clearthescreenWriteCom(0*0c);//openthealldisplay}//OSCinititalvoidOscInit(void){SFRPAGE=0*0F;OSCICL=OSCICL+4; //setthefrequency24MHzOSCICN=0*C2; //themaintimeclockfrequentyis12MCLKSEL=0*00; //outputassystemFrequencySFRPAGE=0*00;return;}//showvoidDispHan(ucharcode*a,ucharm,uchark){uchardat,i,j,length; length=k/2; WriteCom(m); for(i=0;i<length;i++) { j=2*i; dat=a[j]; WriteData(dat); dat=a[j+1]; WriteData(dat); }}voidDispTime(uchar*a,ucharm,uchark){uchardat,i,j,length; length=k/2; WriteCom(m); for(i=0;i<length;i++) { j=2*i; dat=a[j]; WriteData(dat); dat=a[j+1]; WriteData(dat); }}//initialtheI/OvoidPort_IO_Init(){ SFRPAGE=0*0F; P0MDIN=0*E7;//P0.0pulldragoutputP0MDOUT=0*83;P0SKIP=0*FF;P1MDIN=0*FF;//setasmathinputP1MDOUT=0*FF;//setaspushpulloutputP1SKIP=0*FF;//setp1wasskipP2MDIN=0*FE; //P2.1,P2.2,P2.3,P2.4wassetedasmathinputp2.0asanaloginputP2MDOUT=0*FE; //P2.1,P2.2,P2.3,P2.4wassetedasdragandpushoutputP2SKIP=0*E1; //P2.1,P2.2,P2.3,P2.4wassetedasskipP3MDIN=0*FF;P3MDOUT=0*FF;P3SKIP=0*FF;P4MDOUT=0*FF;*BR0=0*02; //SPIbusattachtoI/O*BR1=0*C0;SFRPAGE=0*00;return;}voidPcaInit(void){PCA0CN=0*40;//enablethepcatimerPCA0MD=0*00; //don'tallowwdt;return;}//initialinterruptvoidInterruptsInit(void){E*0=1;//enableintoP*0=1;//sethighpriporyET0=0;//disabkeableT0interruptET2=1;//enableT2interruptEIE1=0*08;//disableT3interruptEA=1;//opentheallinterrupt//EADC0=1;//enableadinterruptreturn;}voidInt0Init(void){IT01CF=0*65;//P0.5asinto,P0.6asint1,lowvalueworkIT0=1; //intowaehappenifdownIT1=1; //intowaehappenifdownE*0=1;//ableintointerruptE*1=0;//disableint1interruptreturn;}//initialthePci0voidSpi0Init(){SPI0CFG=0*70;//setasmasterSPI0CN=0*0D;//setas4wiremode,enableSpiSPI0CKR=0*02;//setFsck=2MHZ}//initialtheAD-DAvoidAD_DAInit(){REF0CN=0*08;//settheVDDassourceAM*0P=0*08;//choseP2.0asADinputAM*0N=0*1F;//chocetheGNDasanotherinputADC0CF=0*2C;//settheClKsar=12MADC0CN=0*C5;//enableADC0,whentime3overfow,aftet3CLKsar,starttheADconvert//IDA0CN=0*A2;//enableDA,timer2overflowcausetheinterrupt,2.0msasfulloutput}voidTimerInit(void){TMOD=0*11; //T0,T1,work1CKCON=0*00; //12divfreTL0=0*78; //set10msTH0=0*EC;TL1=0*0C; //set0.5msTH1=0*FE;TMR2CN=0*00; //i16bitautoreload,systemdiv12,disabletheTime2runTMR2RLL=0*83;//set0.125msTMR2RLH=0*FF;TMR3CN=0*00;//16bitautoreloadTMR3RLL=0*83;TMR3RLH=0*FF;//set0.125msreturn;}//voicesampleandplay system#include<C8051F360.h>#include<play.h>ucharKEYSIGN=0; //thesignofpresskeyucharKeyValue; //thevalueofkeyucharVEDINSIGN=0;#defineuintunsignedintunsignedlongintADDR=0*00000000;sbitP27=P2^7;unsignedlongADDR1=0*00000000;ucharcodeKeyTran[]={'0','1','2','3','4','5','6','7','8','9','A','B','C','D','E','F'};ucharvalue=0;intSum;uchar*dataData_byte[256];//ucharAS[64];//intFFF;ucharTime[]={0*30,0*30,0*30};ucharSecond=0;//ucharSam=0;voidTime_init(){uchari=3;for(i=0;i<3;i++){Time[i]=0*30;}}voidCheck_Busy(){ucharmem_status=0*01;NSSMD0=0;SPI0DAT=0*05;//readtheconditionwhile(SPIF!=1){}SPIF=0;while(mem_status==0*01){SPI0DAT=0*FF;while(SPIF!=1){}SPIF=0;mem_status=SPI0DAT&0*01;//checkifbusy}NSSMD0=1;//closem25p16}//erasethem25p16voidErase_All(){NSSMD0=0;SPI0DAT=0*06; //allowwritewhile(SPIF!=1){}SPIF=0;NSSMD0=1; //actthecommandNSSMD0=0;SPI0DAT=0*C7;//reaseallm25p16while(SPIF!=1){}SPIF=0;NSSMD0=1; //alloweraseCheck_Busy(); //writefortheerase}voidInitDevice(void){Port_IO_Init();OscInit();*ramInit();Int0Init();TimerInit();InterruptsInit();Spi0Init();//M25p16Init();PcaInit();AD_DAInit();}voidM25p16Init(){NSSMD0=0;SPI0DAT=0*06;while(SPIF!=1){}SPIF=0;NSSMD0=1;NSSMD0=0;SPI0DAT=0*01;//writeconditionwhile(SPIF!=1){}SPIF=0;SPI0DAT=0*00;//setBP2-BP0as0,allowallflashcanearsewhile(SPIF!=1){}SPIF=0;NSSMD0=1;//allowthecommandactCheck_Busy();}//erasethem25p16voidDel(){InsitiLcd();DispHan("delete..",0*92,0*08);Erase_All();VEDINSIGN=0;//InitDevice();InsitiLcd();DispHan(hanzi,0*81,0*0C);DispHan("按K0清空",0*92,0*08);DispHan("按K1录音",0*8A,0*08);DispHan("按K2播放",0*9A,0*08);}voidVelinit(){Second=0;VEDINSIGN=1;InsitiLcd();Time_init();TMR2CN=0*00; //stopthetime2DispHan("Vedioing",0*92,0*08);TMR3CN=0*04;//startthecountSum=0;ADDR=0*00000000;ADDR=ADDR&0*0001FFFF;ADDR1=ADDR;TMR3CN=0*04;DispTime(Time,0*8A,0*04);}//pageprogramvoidPage_Program(unsignedlongADDR){unsignedinti;unsignedchartemp[3];NSSMD0=0;//openthem25p16SPI0DAT=0*06;//giveenablecommandwhile(SPIF!=1){}SPIF=0;NSSMD0=1;//enablecommandactNSSMD0=0;SPI0DAT=0*02;//givepageprogramwhile(SPIF!=1){}SPIF=0;for(i=0;i<3;i++){temp[i]=ADDR>>(8*(2-i));SPI0DAT=temp[i];while(SPIF!=1){}SPIF=0;}for(i=0;i<256;i++){SPI0DAT=Data_byte[i];while(SPIF!=1){}SPIF=0;}NSSMD0=1;//actthecommand //Check_Busy();}//readtheflashvoidRead_Flash(unsignedlongADDR){unsignedinti;unsignedchartemp[3];NSSMD0=0;SPI0DAT=0*06;while(SPIF!=1){}SPIF=0;NSSMD0=1;NSSMD0=0;SPI0DAT=0*03;while(SPIF!=1){}SPIF=0;//NSSMD0=1;// NSSMD0=0;for(i=0;i<3;i++){temp[i]=ADDR>>(8*(2-i));SPI0DAT=temp[i];while(SPIF!=1){}SPIF=0;}for(i=0;i<256;i++){SPI0DAT=0*FF;while(SPIF!=1){}SPIF=0;Data_byte[i]=SPI0DAT;}NSSMD0=1;}//vediothevoicevoidVel(){if(Sum>255) { Page_Program(ADDR); ADDR+=0*0000000100; ADDR=ADDR&0*0001FFFF; Sum=0; Second++; if(Second==32) { Second=0; Time[2]+=1; if(Time[2]==0*3A) { Time[1]+=1; Time[2]=0*30; if(Time[1]==0*3A) { Time[1]=0*30; Time[0]+=1; } } } } DispTime(Time,0*8A,0*04);}voidPlayInit() //playinital{IDA0CN=0*F2;Second=0;VEDINSIGN=2;InsitiLcd();Time_init();TMR3CN=0*00;//stopthecount//Data_init();//ADDR1=ADDR;ADDR=0*00000000;ADDR=ADDR&0*0001FFFF;Sum=0;Read_Flash(ADDR);TMR2CN=0*04;//startthecountDispHan("PLAY",0*92,0*08);}voidPlay(){if(Sum>200) { ADDR+=0*0000000100; ADDR=ADDR&0*0001FFFF; Read_Flash(ADDR); Sum=0; Second++; if(Second==32) { Second=0; Time[2]+=1; if(T

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论