智能留言电路设计 毕业论文正文.doc
毕业论文(设计)第一章 绪论1.1设计概述本设计是在指导老师给定课题的基础上经过思考创新而设计出来的基于单片机控制的语音录放器设计。内容丰富,运用灵活。课题运用ISD1420语音芯片,LM386音频功放,以及曾经学习过的AT89S51单片机芯片设计而成的经典电路。1.2 设计背景ISD1420 系列芯片是较为常用了语音录放集成电路,一般多用于语音电话,留言机等设备。更可于单片机实现接口,进行语音分段录放音的功能,可用于自动报时器,汽车自动报站器等设备,如果采用具有语音处理的16 位或32 位处理器实现同样的功能将会增大开发的周期和成本,会使本来简单的系统更加的复杂。1.3 设计要求1熟悉电路的工作原理;2掌握该电路中元器件的识别方法;3掌握电路的调试方法;4熟悉电路简单的故障分析方法;5论文符合其格式、字数的基本要求,内容要求充实、作图严谨规范等。1.4 设计意义1. 增加产品销售量;2. 提高公共服务档次,符合建设国际城市的目标;3. 可免除生意人口干舌燥的叫喊,非常实用等。21毕业论文(设计)第二章 系统方案设计与研究2.1设计过程整个电路设计可分为以下几个单元电路:按键指令输入电路、录音电路、语音处理电路、音频放大电路、数码管显示电路等。2.2方案设计方案一:采用基本的硬件电路,主芯片ISD1420直接控制整个语音电路,用LM386作为音频放大芯片,电路结构简单,一般较为常用。主要运用与简单语音报警器,温度报警器等等。方案二:在原来课题设计的基础上,利用单片机作为控制芯片实现分段录放功能,利用单片机控制的ISD1420芯片将会彻底发挥其优势,可以选择录放的起始段,清除等功能,是目前广泛爱好者语音电路的首选方案。2.3方案选定本设计采用方案二,处理器选择AT89S51单片机,语音芯片选择ISD1420,放大芯片为LM386,用微处理器对ISD 芯片的分段录放音控制时,才算是发挥了芯片的优势。第三章 AT89S51概述观图3-1 单片机(at89s51)外观3.1 AT89S51AT89S51(如图3-1)是一个低功耗,高性能CMOS 8位单片机,片内含4k Bytes ISP(In-system programmable)的可反复擦写1000次的Flash只读程序存储器,器件采用ATMEL公司的高密度、非易失性存储技术制造,兼容标准MCS-51指令系统及80C51引脚结构,芯片内集成了通用8位中央处理器和ISP Flash存储单元,功能强大的微型计算机的AT89S51可为许多嵌入式控制应用系统提供高性价比的解决方案。 3.2AT89S51的特点特点:40个引脚,4k Bytes Flash片内程序存储器; 128 bytes的随机存取数据存储器(RAM); 32个外部双向输入/输出(I/O)口; 5个中断优先级2层中断嵌套中断; 2个16位可编程定时计数器; 2个全双工串行通信口,看门狗(WDT)电路,片内时钟振荡器。 此外,AT89S51设计和配置了振荡频率可为0Hz并可通过软件设置省电模式。空闲模式下,CPU暂停工作,而RAM定时计数器,串行口,外中断系统可继续工作,掉电模式冻结振荡器而保存RAM的数据,停止芯片其它功能直至外中断激活或硬件复位。同时该芯片还具有PDIP、TQFP和PLCC等三种封装形式,以适应不同产品的需求。 3.3主要特性 8031 CPU与MCS-51 兼容 4K字节可编程FLASH存储器(寿命:1000写/擦循环) 全静态工作:0Hz-33MHz 三级程序存储器保密锁定 128*8位内部RAM 32条可编程I/O线 两个16位定时器/计数器 6个中断源 可编程串行通道 低功耗的闲置和掉电模式 片内振荡器和时钟电路 3.4 管脚说明如图3-2所示: 图3-2 单片机2AT89S51原理图 VCC:供电电压。 GND:接地。 P0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。 P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4TTL门电流。P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。 P2口:P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。 P3口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。P3.0 RXD(串行输入口) P3.1 TXD(串行输出口)P3.2 /INT0(外部中断0)P3.3 /INT1(外部中断1)P3.4 T0(记时器0外部输入)P3.5 T1(记时器1外部输入)P3.6 /WR(外部数据存储器写选通)P3.7 /RD(外部数据存储器读选通)P3口同时为闪烁编程和编程校验接收一些控制信号。I/O口作为输入口时有两种工作方式,即所谓的读端口与读引脚。读端口时实际上并不从外部读入数据,而是把端口锁存器的内容读入到内部总线,经过某种运算或变换后再写回到端口锁存器。只有读端口时才真正地把外部的数据读入到内部总线。上面图中的两个三角形表示的就是输入缓冲器CPU将根据不同的指令分别发出读端口或读引脚信号以完成不同的操作。这是由硬件自动完成的,不需要我们操心,1然后再实行读引脚操作,否则就可能读入出错,为什么看上面的图,如果不对端口置1端口锁存器原来的状态有可能为0Q端为0Q为1加到场效应管栅极的信号为1,该场效应管就导通对地呈现低阻抗,此时即使引脚上输入的信号为1,也会因端口的低阻抗而使信号变低使得外加的1信号读入后不一定是1。若先执行置1操作,则可以使场效应管截止引脚信号直接加到三态缓冲器中实现正确的读入,由于在输入操作时还必须附加一个准备动作,所以这类I/O口被称为准双向口。89C51的P0/P1/P2/P3口作为输入时都是准双向口。接下来让我们再看另一个问题,从图中可以看出这四个端口还有一个差别,除了P1口外P0P2P3口都还有其他的功能。 RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。 ALE/PROG:当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ALE脉冲。如想禁止ALE的输出可在SFR8EH地址上置0。此时, ALE只有在执行MOVX,MOVC指令是ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置位无效。 /PSEN:外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。 /EA/VPP:当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式1时,/EA将内部锁定为RESET;当/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源(VPP)。 XTAL1:反向振荡放大器的输入及内部时钟工作电路的输入。 XTAL2:来自反向振荡器的输出。第四章 ISD1420芯片4.1概述ISD1420 系列芯片是较为常用了语音录放集成电路,一般多用于语音电话、留言机等设备。更可于单片机实现接口,进行语音分段录放音的功能,可用于自动报时器,汽车自动报站器等设备,如果采用具有语音处理的16 位或32 位处理器实现同样的功能将会增大开发的周期和成本,会使本来简单的系统更加的复杂。开发简单的语音录放系统时,ISD 的芯片将成为开发工程师的不二选择。4.2了解ISD1420ISD1420 为美国ISD 公司出品的优质单片语音录放集成电路,由振荡器、语音存储单元、前置放大器、自动增益控制电路、抗干扰滤波器、输出放大器组成。一个最小的录放系统仅由一个麦克风、一个喇叭、两个按钮、一个电源、少数电阻电容组成。录音内容存入永久存储单元,提供零功率信息存储,这个独一无二的方法是借助于美国ISD 公司的专利直接模拟存储技术(DAST TM)实现的。利用它,语音和音频信号被直接存储,以其原本的模拟形式进入EEPROM存储器。直接模拟存储允许使用一种单片固体电路方法完成其原本语音的再现。不仅语音质量优胜,而且断电语音保护。目前,ISD1400 系列有下列型号:ISD1408、ISD1410、ISD1412、ISD1416、ISD1420。录放时间分别为:8秒、10秒、12秒、16秒、20 秒。(ISD14XX其中型号的后两位表示其录音的时间长度,单位是秒)4.3 芯片特点所需外围元件少,电路简单,操作方便。采用直接模拟量存贮技术DAST(Direct Analog Strorage Technology),再现优质原声。零功率信息存贮,省掉备用电源。信息可保存10 年以上,可反复录放达10万次之多。语音固化无需专用编程或开发装置。较强的选址能力,可把存储器分成160段来进行管理。具有自动省电模式,此时仅需0.5A 的保持电流。单一电源供电。4.4电气特性如图4-1工作电压VDD:5V.静态电流ISTB:典型值0.85A,最大值为2A.工作电流IOP:典型值15mA,最大值30mA.A0A7:地址输入端;VCCD:数字电路电源;VCCA:模拟电路电源;VSSD:数字地;VSSA:模拟地;SP+:喇叭(+);SP-:喇叭(-);SCLK:外接时钟(可选);ANA IN:模拟量输入;ANA OUT:模拟量输出;AGC:自动增益控制;MIC:驻极体话筒输入;MIC REF:驻极体话筒参考输入;PLAYE:边沿触发放音;图4-1 ISD1420芯片原理图PLAYL:电平触发放音;REC:录音触发;RECLED:发光二极管接口;NC:空脚4.5 ISD1420经典电路ISD1400芯片可以和少量的外围元件构成一个最小化的录放音电路。下面是经典的最小化录放音电路图(如图4-2)图4-2 电路图 这个最小化系统有一个LED指示灯、三个微动开关,可以对芯片的录音、播放、停止进行控制。S3(RECORD)为录音键,按住它时LED灯点亮,此时为录音状态,当录放达到最大时间值或中途放开S3 录音按键即停止录音。S2(PLAYL)为放音键,按一下它就可以播放录音,当放音达到录音的尾声时或中途按下了S1停止键则停止放音。S1为停止键,当放音过程中按下S1停止键停止放音。如果有待机时按住S1 则开始放音,放音直到录音的尾声或中途放开S1 键。当芯片处于录音状态时LED点亮,当芯片放音结束时LED会闪亮一下。只要按电路图接好电路,一般不用调试就可以使用。毕业论文(设计)第五章 硬件电路模块设计5.1 设计原理输出ISD1420语音芯片LM386音频放大AT89S51单片机图5-1 设计原理图 5.2 最小系统设计单片机最小系统,或者称为最小应用系统,是指用最少的元件组成的单片机可以工作的系统。对51系列单片机来说,最小系统一般应该包括:单片机、晶振电路、复位电路。下面给出一个51单片机的最小系统电路图(如图5-2) 图5-2 最小系统电路图在智能化仪器仪表中,控制核心均为微处理器,而单片机以高性能、高速度、体积小、价格低廉、稳定可靠而得到广泛应用,是设计智能化仪器仪表的首选微控制器。单片机结合简单的晶体振荡电路和复位电路即可构成单片机最小系统,它是智能化仪器仪表的基础,也是测控、监控的重要组成部分。5.3 复位电路如图5-3。复位电路和时钟电路是维持单片机最小系统运行的基本模块。复位电路通常分为两种:上电复位和手动复位。 上电复位 手动复位图5-3 复位电路图有时系统在运行过程中出现程序跑飞的情况,在程序开发过程中,经常需要手动复位。所以本次设计选用手动复位。5.4 时钟电路高频率的时钟有利于程序更快的运行,也有可以实现更高的信号采样率,从而实现更多的功能。但是告诉对系统要求较高,而且功耗大,运行环境苛刻。考虑到单片机本身用在控制,并非高速信号采样处理,所以选取合适的频率即可。图5-4 时钟电路图合适频率的晶振对于选频信号强度准确度都有好处,本次设计选取12.000M无源晶振接入XTAL1和XTAL2引脚。并联2个30pF陶瓷电容帮助起振(如图5-4)5.5 按键电路 图5-5 按键电路图1查询工作方式这种方式是直接在主程序中插入键盘检测子程序,主程序每执行一次,则键盘检测子程序就对键盘进行检测一次。如果没有键按下,则跳过键识别,直接执行其他程序;如果有键按下,则通过键盘扫描子程序识别按键,得到按键的编码值。然后根据编码值进行相应的处理,处理完后再回到主程序执行。键盘扫描子程序流程如图5-6所示 。 图5-6 键盘扫描流程图2.中断工作方式 如图5-7所示,就是中断工作方式,当有中断的时候,就去执行扫描程序,没有中断的时候,CPU可以去做其他的事情。这样可以提高CPU的效率。图5-7 键盘中断工作方式5.6显示电路如图5-8两位数码管分别与单片机的P1口和P3口连接实现静态显示。图5-8 显示电路图5.7音频放大电路如图5-9将语音信号经过ISD1420后送到LM386音频放大,之后输出。图5-9 音频放大电路图毕业论文(设计)第六章 软件设计6.1程序起始;-程序入口ORG 0000HJMP ISD_STARTORG 000BHJMP TT0ORG 0030H;-程序开始ISD_START:MOV R1,#8MOV R0,#WRAMRAM1:MOV R0,#0INC R0DJNZ R1,RAM1SETB ISDPLAYLSETB ISDREDSETB ISDPLAYSSETB KEYSETMOV R2,#3MOV TMOD,#01H ;定时计数器工作方式MOV TH0,#9EH ;初值(9E58H-25MS)MOV TL0,#58H ;SETB ET0 ;开T0允许SETB EA ;开总中断6.2录音程序LOOP: ;录音部分JB KEYRED,N1CALL DL20MSJB KEYRED,N1MOV ISDDAT,WRAMMOV WBIT1,WRAMMOV WBIT3,WRAMCLR ISDREDSETB TR0 ;启动定时器M0:JNB P1.6,M1 ;地址极限值保护JNB P1.7,M1JMP M2M1:JNB KEYRED,M0M2:SETB ISDREDCLR TR06.3放音程序在录音板上按一下录音键,并录入第一个段音。完成后LED上显示了第二段的起始地址,按重放键放音,感觉满意后记下这个数据,开始下一段录音。如果感觉不满意则按清除键回到上次的地址位重新录音。录好后,在放音时只要给出放音的起始地址即可放音,当放音结束后RECLED 将输出一个低电平脉冲。程序查寻此脉冲并停止放音或开始另一段放音。程序如下:PLAY EQU P3.3 ;语音播放_STOPIN EQU P3.0 ;语音停止信号输入_MOV SPDAT,#00H;放入放音地址CLR PLAY ;开始放音JB STOPIN,$;查寻停止反馈SETB PLAY;有停止信号,停止放音CALL DL20MS;延时等待芯片恢复MOV SPDAT,#27H;放入第二段放音地址CLR PLAYJB STOPIN,$SETB PLAYCALL DL20MS参考文献1. 电子技术基础.西安交通大学,2008.8 40-552. PIC单片机原理与应用.机械工业出版社2010.1 19-393. 51单片机及其C语言程序开发实例.清华大学出版社.2008.12 (完整)4. 李平、李亚荣、关天民.ISD1420的高响度语音电路设计.大连交通大学,2005.15. 唐明道.杨林武.ISD1420单片语音录放电路应用.电子技术杂志1998附录1 元件清单元件名称型号数量J1Connector2脚插槽1J2Connector4脚插槽1J4Connector7脚插槽1C16、C17、C18、C19、C20、C220.1UF6C154.7UF1R95.1K1R7、R12、R1010K3C12、C13、C1430P3R11 100K1C1、C3、C4100uF3C2、C51042R11、R122002C21 220UF1R13301R8470K1U378051U1AT89S511U4LM3861Y1 CRYSTAL12M1D5、D6IN41482U2ISD14201D7 LED1MICROPHONE2扬声器1SPEAKER话筒1数码管共阳极2按键四脚弹簧5附录2 电路原理图 附录3 源程序程序名: ISD1402 语音芯片分段录放音调试编写人: 李典初写时间: 2010年6月程序功能: 实现对ISD1420 语音芯片的分段录放音实现方法: 用定时器产生最小125MS的录音长度值CPU说明: 89S51 24-PC 12MHZ晶振修改日志:NO.1-2010.6.10 增加了地址极限保护功能,防止录音出错。-*/;-初定义ISDDAT EQU P1 ;语音地址线KEYRED EQU P3.3 ;录音按键ISDRED EQU P3.0 ;录音使能(低有效)KEYPLAYL EQU P3.4 ;长放音键ISDPLAYL EQU P3.2 ;长放音使能KEYPLAYS EQU P3.5 ;短放音按键ISDPLAYS EQU P3.1 ;短放音使能KEYSET EQU P3.6 ;XX EQU P1.7 ;调试用灯STOPIN EQU P3.7 ;放音停止脉冲输入LED1 EQU P0 ;静态数码管第一位 ;数码管显示第一位(十位)LED2 EQU P2 ;静态数码管第二位 ;数码管显示第二位(个位)WRAM EQU 20H ;录音地址寄存器 ;数码管显示值寄存器WBIT1 EQU 21H ;放弃此次录音寄存器;WW EQU 22H ;WBIT3 EQU 23H ;-程序入口ORG 0000HJMP ISD_STARTORG 000BHJMP TT0ORG 0030H;-程序开始ISD_START:MOV R1,#8MOV R0,#WRAMRAM1:MOV R0,#0INC R0DJNZ R1,RAM1SETB ISDPLAYLSETB ISDREDSETB ISDPLAYSSETB KEYSETMOV R2,#3MOV TMOD,#01H ;定时计数器工作方式MOV TH0,#9EH ;初值(9E58H-25MS)MOV TL0,#58H ;SETB ET0 ;开T0允许SETB EA ;开总中断MOV ISDDAT,#0FFHMOV WRAM,#00HCALL DISPLAYMOV WBIT1,#0LOOP: ;录音部分JB KEYRED,N1CALL DL20MSJB KEYRED,N1MOV ISDDAT,WRAMMOV WBIT1,WRAMMOV WBIT3,WRAMCLR ISDREDSETB TR0 ;启动定时器M0:JNB P1.6,M1 ;地址极限值保护JNB P1.7,M1JMP M2M1:JNB KEYRED,M0M2:SETB ISDREDCLR TR0N1: ;回放刚才录音JB KEYPLAYL,N2CALL DL20MSJB KEYPLAYL,N2MOV ISDDAT,WBIT1CLR ISDPLAYSCALL DL60MSSETB ISDPLAYSN2: ;加地址功能,设定放音地址JB KEYPLAYS,N3CALL DL20MSJB KEYPLAYS,N3INC WBIT1MOV ISDDAT,WBIT1CALL DISPLAY2CALL DL60MSN3: ;清除刚才录音JB KEYSET,N4CALL DL20MSJB KEYSET,N4MOV ISDDAT,WBIT3MOV WRAM,WBIT3MOV WBIT1,WBIT3CALL DISPLAYN4:JMP LOOP;-数码管显示程序DISPLAY:MOV WW,WRAMJMP GODISPLAY2:MOV WW,WBIT1GO:MOV A,WW ;静态数码管显示MOV DPTR,#TAB1ANL A,#0F0HSWAP AMOVC A,A+DPTRMOV LED1,AMOV A,WWANL A,#0FHMOVC A,A+DPTRMOV LED2,ARET;-LED数码管显示表(0-F) TAB1TAB1: DB 0C0H,0F9H,0A4H,0B0H,99H,92H,82H,0F8H,80H,90HDB 88H,83H,0A7H,0A1H,86H,8EH;-T0中断TT0:MOV TH0,#9EH ;重装初值(25MS)MOV TL0,#58H ;DJNZ R2,TT0EXIT ;1位的录音时长(125MS)MOV R2,#3 ;INC WRAMCALL DISPLAYTT0EXIT:RETI ;T0中断结束;-延时子程序DL20MS: ;20毫秒延时,主要用于去抖动。(100,100)MOV R6,#100DL20MS_1:MOV R7,#100DJNZ R7,$DJNZ R6,DL20MS_1RETDL60MS: ;60 毫秒延时CALL DL20MSCALL DL20MSCALL DL20MSRETDL05S: ;1秒延时,用在了开始等待。(50)MOV R5,#50DL05S_1:CALL DL20MSDJNZ R5,DL05S_1RET;-结束END