单片机技术课程设计说明书智能信号发生器.doc

上传人:仙人指路1688 文档编号:4142934 上传时间:2023-04-07 格式:DOC 页数:29 大小:780KB
返回 下载 相关 举报
单片机技术课程设计说明书智能信号发生器.doc_第1页
第1页 / 共29页
单片机技术课程设计说明书智能信号发生器.doc_第2页
第2页 / 共29页
单片机技术课程设计说明书智能信号发生器.doc_第3页
第3页 / 共29页
单片机技术课程设计说明书智能信号发生器.doc_第4页
第4页 / 共29页
单片机技术课程设计说明书智能信号发生器.doc_第5页
第5页 / 共29页
点击查看更多>>
资源描述

《单片机技术课程设计说明书智能信号发生器.doc》由会员分享,可在线阅读,更多相关《单片机技术课程设计说明书智能信号发生器.doc(29页珍藏版)》请在三一办公上搜索。

1、单片机技术课程设计说明书智能信号发生器专业电气工程及自动化学生姓名周建班级BMZ电气081学号0861402115指导教师周云龙完成日期2011年 6月 9 日目 录绪论第一章 系统设计1.1 系统方案1.2 控制芯片的选择第二章 系统硬件设计2.1 基本原理2.2 单片机介绍及资源分配2.2.1 单片机的介绍2.2.2 资源分配2.3 各部分电路原理2.3.1 DAC0832芯片原理2.3.2 NE4558工作原理2.3.3 键盘电路原理2.3.4 LED显示电路原理第三章 系统软件设计3.1主程序流程图3.2子程序流程图第四章 测试结果第五章 结论参考文献附录A电路原理图附录B 程序清单绪

2、论波形发生器亦称函数发生器,作为实验用信号源,是现今各种电子电路实验设计应用中必不可少的仪器设备之一。目前,市场上常见的波形发生器多为纯硬件的搭接而成,且波形种类有限,多为锯齿、正弦、方波、三角等波形。这里介绍一种采用AT89S52单片机和一片DAC0832数模转换器做成的数字式低频信号发生器,它的特点是价格低、性能高,在低频范围稳定性好、操作方便、体积小、耗电少等。信号发生器与其它相比还具有如下优点:较分立元件信号发生器而言,具有频率高,工作稳定,容易调试等特性;较专用DDS芯片的信号发生器而言,具有结构简单,成本低等特性。第一章 系统设计1.1 系统方案 采用单片机和DAC0832数模转换

3、器生成波形,由于是软件滤波,所以不会有寄生的高次谐波分量,生成的波形比较纯净。它的特点是价格低、性能高,在低频范围内稳定性好、操作方便、体积小、耗电少。可充分发挥其优势,电路简单,易控制,性价比较高,所以采用该方案。1.2 控制芯片的选择AT89S52单片机是一种高性能8位单片微型计算机。它把构成计算机的中央处理器CPU、存储器、寄存器、I/O接口制作在一块集成电路芯片中,从而构成较为完整的计算机。第二章 系统硬件设计2.1 基本原理系统框图如图2.1所示波形指示按键单片机数模转换电流、电压转换输出电源图2.1低频信号发生器系统框图低频信号发生器系统主要由CPU、D/A转换电路、基准电压电路、

4、电流/电压转换电路、按键和波形指示电路、电源等电路组成。其工作原理为当分别按下四个按键中的任一个按键就会分别出现方波、锯齿波、三角波、正弦波,并且有四个发光二极管分别作为不同的波形指示灯。2.2 单片机介绍及资源分配2.2.1 单片机的介绍(1)AT89S52的引脚图如图2.2所示图2.2 AT89S52引脚图(2)管脚说明 低频信号发生器采用AT89S52单片机作为控制核心,其内部组成包括:一个8位的微处理器CPU及片内振荡器和时钟产生电路,但石英晶体和微调电容需要外接;片内数据存储器RAM低128字节,存放读/写数据;高128字节被特殊功能寄存器占用;片内程序存储器4KB ROM;四个8位

5、并行I/O(输入/输出)接口P3 -P0,每个口可以用作输入,也可以用作输出;两个定时/计数器,每个定时/计数器都可以设置成计数方式,用以对外部事件进行计数,也可以设置成定时方式,并可以根据计数或定时的结果实现计算机控制;五个中断源的中断控制系统;一个全双工UART(通用异步接收发送器)的串行I/O口。VCC:供电电压。GND:接地。RST:复位输入。当振荡器复位器件时,要保持RST脚两个机器周期的高电平时间。ALE/PROG:当访问外部存储器时,地址锁存允许的输出电平用于锁存地址的地位字节。在FLASH编程期间,此引脚用于输入编程脉冲。在平时,ALE端以不变的频率周期输出正脉冲信号,此频率为

6、振荡器频率的1/6。因此它可用作对外部输出的脉冲或用于定时目的。然而要注意的是:每当用作外部数据存储器时,将跳过一个ALE脉冲。如想禁止ALE的输出可在SFR8EH地址上置0。此时, ALE只有在执行MOVX,MOVC指令是ALE才起作用。另外,该引脚被略微拉高。如果微处理器在外部执行状态ALE禁止,置位无效。/PSEN:外部程序存储器的选通信号。在由外部程序存储器取指期间,每个机器周期两次/PSEN有效。但在访问外部数据存储器时,这两次有效的/PSEN信号将不出现。/EA/VPP:当/EA保持低电平时,则在此期间外部程序存储器(0000H-FFFFH),不管是否有内部程序存储器。注意加密方式

7、1时,/EA将内部锁定为RESET;当/EA端保持高电平时,此间内部程序存储器。在FLASH编程期间,此引脚也用于施加12V编程电源(VPP)。XTAL1:反向振荡放大器的输入及内部时钟工作电路的输入。XTAL2:来自反向振荡器的输出。89S52 单片机外部有32个端口可供用户使用,其功能如下:表2.1 89S52并行I/O接口端口引脚位置第一功能第二功能 符号 功能符号功能P039-32P0.0-P0.7通用I/0口AD0-AD7地址数据总线P11-8P1.0-P1.7通用I/0口P221-28P2.0-P2.7通用I/0口A8-A15地址总线(高位)P310P3.0通用I/0口RXD串行通

8、信发送口11P3.1TXD串行通信接收口12P3.2INT0外部中断013P3.3INT1外部中断114P3.4T0计数器0输入端口15P3.5T1计数器1输入端口16P3.6WR外部存储器写功能17P3.7RD外部存储器读功能P0口:P0口为一个8位漏级开路双向I/O口,每脚可吸收8TTL门电流。当P1口的管脚第一次写1时,被定义为高阻输入。P0能够用于外部程序数据存储器,它可以被定义为数据/地址的第八位。在FIASH编程时,P0 口作为原码输入口,当FIASH进行校验时,P0输出原码,此时P0外部必须被拉高。P1口:P1口是一个内部提供上拉电阻的8位双向I/O口,P1口缓冲器能接收输出4T

9、TL门电流。P1口管脚写入1后,被内部上拉为高,可用作输入,P1口被外部下拉为低电平时,将输出电流,这是由于内部上拉的缘故。在FLASH编程和校验时,P1口作为第八位地址接收。P2口:P2口为一个内部上拉电阻的8位双向I/O口,P2口缓冲器可接收,输出4个TTL门电流,当P2口被写“1”时,其管脚被内部上拉电阻拉高,且作为输入。并因此作为输入时,P2口的管脚被外部拉低,将输出电流。这是由于内部上拉的缘故。P2口当用于外部程序存储器或16位地址外部数据存储器进行存取时,P2口输出地址的高八位。在给出地址“1”时,它利用内部上拉优势,当对外部八位地址数据存储器进行读写时,P2口输出其特殊功能寄存器

10、的内容。P2口在FLASH编程和校验时接收高八位地址信号和控制信号。P3口:P3口管脚是8个带内部上拉电阻的双向I/O口,可接收输出4个TTL门电流。当P3口写入“1”后,它们被内部上拉为高电平,并用作输入。作为输入,由于外部下拉为低电平,P3口将输出电流(ILL)这是由于上拉的缘故。P3口也可作为AT89C51的一些特殊功能口,如下所示: 口管脚 备选功能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

11、.7 /RD(外部数据存储器读选通)(3)AT89S52的晶振及其连接方法 CPU工作时都必须有一个时钟脉冲。有两种方式可以向89S52提供时钟脉冲:一是外部时钟方式,即使用外部电路向89S52提供时钟脉冲,见图2.3(a);二是内部时钟方式,即使用晶振由89S52内部电路产生时钟脉冲。一般常用第二种方法,其电路见图2.3(b)。89S52XTAL2XTAL189S52XTAL2XTAL1悬空外部时钟信号C1C2J(a)外部时钟方式(b)内部时钟方式图2.3 89S52的时钟脉冲J一般为石英晶体,其频率由系统需要和器件决定,在频率稳定度要求不高时也可以使用陶瓷滤波器。一般来说,使用石英晶体时,

12、C1=C2=30pF。使用陶瓷滤波器时,C1=C2=47pF。(4)AT89S52的复位 复位是单片机的初始化操作,其主要的作用是把PC初始化为0000H,使单片机从0000H单元开始执行程序。除了进入系统的正常初始化之外,当由于程序运行出错或操作失误使系统处于死锁状态时,为摆脱困境,也需要按复位键以重新启动。除使PC归零外,复位操作还对其他一些专用寄存器有影响,它们的复位状态如表2.2所示。表2.2 复位后的内部寄存器状态寄存器复位状态寄存器复位状态 PC 0000H TMOD00HACC00HTCON00HB00HTH000HPSW00HTL000HSP07HTH100HDPTR0000H

13、TL100HP0-P30FFHSCON00HIP(xxx00000)SBUF(xxxxxxxx)IE(0xx00000)PCON(0xxx0000)另外,复位操作还对单片机的个别引脚有影响,例如会把ALE和/PSEN变成无效状态,即使ALE=0,/PSEN=1.RST变成低电平后,退出复位状态,CPU从初始状态开始工作。89S52复位操作有3种方式:上电复位、上电按钮复位和系统复位。上电复位电路如图2.4所示。对于CMOS型单片机因RST引脚的内部有一个拉低电阻,故电阻R可不接。单片机在上电瞬间,RC电路充电,RST引脚端出现正脉冲,只要RST端保持两个机器周期以上的高电平,就能使单片机有效地

14、复位。当晶体振荡频率为12MHz时,RC的典型值为C=10uF,R=8.2K欧姆。简单复位电路中,干扰信号易串入复位端,可能会引起内部某些寄存器错误复位,这时可在RST引脚上接一去耦电容。通常因为系统运行等的需要,常常需要人工按钮复位,复位电路如图2.5所示,其中R2R1,只需将一个常开按钮开关并联于上电复位电路,按下开关一定时间就能使RST引脚端为高电平,从而使单片机复位。RST 89S52RST 89S52+5VCR+5VR1R2C图2.4 上电复位电路 图2.5 上电按钮复位电路2.2.2 资源分配晶振采用12MHZ。P1口的P1.0-P1.3分别与四个按键连接,分别控制锯齿波、三角波、

15、正弦波和方波,P1.4-P1.7与四个发光二极管相连,按键一对应发光二极管一,依次类推,发光二极管四对应按键四,实现输出一个波形对应亮一个灯。P0口与DAC0832的D0-D7数据输入端相连。P2口用来控制DAC0832的输入寄存器选择信号/CS和数据传送信号/XFER。2.3 各部分电路原理2.3.1 DAC0832芯片原理管脚功能介绍(如图2.6所示)图2.6 DAC0832管脚图DI7DI0:8位的数据输入端,DI7为最高位。ILE:数据锁存允许控制信号输入线,高电平有效。/CS:选片信号输入线(选通数据锁存器),低电平有效。/WR1:数据锁存器写选选通输入线,负脉冲有效,由ILE、/C

16、S、/WR1的逻辑组合产生/LE1,当/LE1为高电平时,数据锁存器状态随输入数据线变化,/LE1的负跳变时将输入数据锁存。/XFER:数据传输控制信号输入线,低电平有效,负脉冲有效。/WR2:DAC寄存器选通输入线,负脉冲有效,由/WR2、/XFER的逻辑组合产生/LE2,当/LE2为高电平时,DAC寄存器的输出随寄存器的输入而变化,/LE2的负跳变时将数据锁存器的内容打入DAC寄存器并开始D/A转换。IOUT1:模拟电流输出端1,当DAC寄存器中数据全为1时,输出电流最大,当 DAC寄存器中数据全为0时,输出电流为0。IOUT2:模拟电流输出端2, IOUT2与IOUT1的和为一个常数,即

17、IOUT1IOUT2常数。RFB:反馈电阻引出端,DAC0832内部已经有反馈电阻,所以 RFB端可以直接接到外部运算放大器的输出端,这样相当于将一个反馈电阻接在运算放大器的输出端和输入端之间。VREF:参考电压输入端,此端可接一个正电压,也可接一个负电压,它决定0至255的数字量转化出来的模拟量电压值的幅度,VREF范围为(+10-10)V。VREF端与D/A内部T形电阻网络相连。Vcc:芯片供电电压,范围为(+5+15)V。AGND:模拟量地,即模拟电路接地端。DGND:数字量地。 当WR2和XFER同时有效时,8位DAC寄存器端为高电平“1”,此时DAC寄存器的输出端Q跟随输入端D也就是

18、输入寄存器Q端的电平变化;反之,当端为低电平“0”时,第一级8位输入寄存器Q端的状态则锁存到第二级8位DAC寄存器中,以便第三级8位DAC转换器进行D/A转换。一般情况下为了简化接口电路,可以把WR2和XFER直接接地,使第二级8位DAC寄存器的输入端到输出端直通,只有第一级8位输入寄存器置成可选通、可锁存的单缓冲输入方式。 特殊情况下可采用双缓冲输入方式,即把两个寄存器都分别接成受控方式。制作低频信号发生器有许多方案:主要有单缓冲方式,双缓冲方式和直通方式。单缓冲方式具有适用于只有一路模拟信号输出或几路模拟信号非同步输出的情形的优点,但是电路线路连接比较简单。而双缓冲方式适用于在需要同时输出

19、几路模拟信号的场合,每一路模拟量输出需一片DAC0832芯片,构成多个DAC0832同步输出电路,程序简单化,但是电路线路连接比较复杂。根据以上分析,我选择了单缓冲方式使用方便,程序简单,易操作。这里我采用DAC0832与单片机89S52的典型的单缓冲方式接口电路。ILE接高电平,/WR1和/WR2相连后接89S52的/WR,/CS和/XFER相连后接89S52的地址高位,这样就同时片选了DAC0832的数据锁存器和DAC寄存器,89S52对DAC0832执行一次写操作就把一个数据写入数据锁存器的同时也直接写入到了DAC寄存器,模拟量输出随之变化。DAC0832的输出是电流,使用运算放大器可以

20、将其电流输出线性地转换成电压输出。根据运算放大器和DAC0832的连接方法,运算放大器的输出可以分为单极性和双极性两种。如图2.7所示。图2.7 DAC0832双极性电压输出电路2.3.2 NE4558工作原理 图2.8 NE4558引脚图 图2.9 NE4558运放引脚图4558 是一片双运放,带内部补偿电路。极好的通道分离特性允许在单运放应用中使用双运放器件,从而提供了最高的封装密度。他的内部包含两组形式完全相同的运算放大器,除电源共用外,两组运放相互独立。每一组运算放大器可用图2.9所示的符号来表示,它有5个引出脚,其中“+”、“-”为两个信号输入端,“V+”、“V-”为正、负电源端,“

21、OUT”为输出端。两个信号输入端中,“-”为反相输入端,表示运放输出端OUT的信号与该输入端的为相反;“+”为同相输入端,表示运放输出端OUT的信号与输入端的相位相同。AOUT:放大信号输出(1)。 AIN-:反相信号输入(1)。AIN+:同相信号输入(1)。 GND:接地。 BIN+:同相信号输入(2)。 BIN-:反相信号输入(2)。 BOUT2:放大信号输出(2)。 Vcc:电源。4558特性有很多,2MHz单位增益带宽保证,NE4558 的电源电压为 18v,具备短路保护功能,无需频率补偿,无闩锁效应,宽广的共模和差动电压范围,低功耗。因此被广泛运用在各种电路中。2.3.3 键盘电路原

22、理在单片机应用系统中为了控制系统的工作状态,以及向系统输入数据,应用系统应设有按键或键盘,实现简单的人机会话。键盘是一组按键的组合,键通常是一种常开型按钮开关,平时键的两个出点处于断开状态,按下键时他们才闭合。从键盘的结构来分类,键盘可以分为独立式和矩阵式两类,每一类按其识别方法又都可以分为编码和未编码键盘两种。键盘上闭合键的识别由专门的硬件译码器实现并产生编号或键值的称为编码键盘,由软件识别的称未编码键盘。在由单片机组成的测控系统及智能化仪器中,用得较多的是未编码键盘,我这里也使用未编码键盘。未编码键盘又分为独立式键盘跟矩阵式键盘。(1)独立式未编码键盘结构的工作原理及接口 在单片机应用系统

23、中常常需要简单的几个键完成数据、命令的输入,此时可采用独立式键盘的结构。其接口如图2.10所示。此接口电路的工作原理很简单,无键按下时,各输入线为高电平;有键按下时,相应的输入线为低电平,CPU查询此输入口的状态就可知是哪个键闭合。采用一键一线的方法,当按键的数目增加时,将增加输入口的数量,为了减少占用输入线数,可采用矩阵式结构的键盘。+5V图2.10 独立式未编码键盘(2)矩阵式未编码键盘结构的工作原理 如图2.11所示是4*4的键盘接口,它是矩阵式的结构。图中键盘的行线(X0X3)与列线(Y0Y3)的交叉处通过一个按键来联通,行线通过电阻接+5V,当键盘上没有键闭合时所有的行线和列线都断开

24、,则行线都呈高电平。当键盘上某一个键闭合时,则该键所对应的行线和列线被短路。例如:6号键被按下闭合时,行线X1和列线Y2被短路,此时X1的电平由Y2的电位所决定。如果把行线接到单片机的输入口,列线接到单片机的输出口,则在单片机的控制下,先使列线Y0为低电平,其余三根列线Y1、Y2、Y3都为高电平,读行线状态。如果X0、X1、X2、X3、都为高电平,则Y0这一列上没有键合。如果读出的行线状态不全为高电平,则为低电平的行线和Y0相交的键处于闭合状态。如果Y0这一列上没有键合,接着使列线Y1为低电平,其余列线为高电平,用同样方法检查Y1这一列上有无键闭合。依此类推,最后使列线Y3为低电平,其余的列线

25、为高电平,检查Y3这一列上是否有键闭合。这种逐行逐列地检查键盘状态的过程称为对键盘的一次扫描。CPU对键盘扫描可以采取程序控制的随机方式,CPU空闲时扫描键盘;也可以采取定时控制方式,每隔一定时间,CPU对键盘扫描一次,CPU可随时响应键盘输入请求;还可以采用中断方式,当键盘上有键闭合时,向CPU请求中断,CPU响应键盘输入中断,对键盘扫描,以识别哪一个键处于闭合状态,并对键输入信息作出相应处理。CPU对键盘上闭合键的键号确定,可以根据行线和列线的状态计算求得,也可以根据行线和列线状态查表求得。X3X2X1X0Y0Y1Y2Y3 12840 139 5 1 14 10 6 2 15 11 7 3

26、+5V图2.11 4*4矩阵式未编码键盘结构图根据我设计的电路特点,只需要用到4个按钮来选择波形,实现的功能也比较简单,所以我采用独立式未编码键盘结构。键盘原理图如图2.12所示。图2.12 键盘原理图2.3.4 LED显示电路原理在这里使用的是发光二极管,发光二极管通常用砷化镓、磷化镓等所制成的。当这种管子通以电流时将发出光来,这是由于电子与空穴直接复合而放出的能量的结果。当PN结处加以一个适当的正电压时,此管即导通,也就会发光。这样我们就能知道我们所需要了解的信息,在此设计中发光二极管通过软件的控制显示波形种类。LED电路图如图2.13所示。图2.13 LED电路图4个LED的负极分别接P

27、1.4P1.7,当P1口高4位任意一个为低电平时,其对应的LED就会导通,从而发光,通过程序的控制可以设计波形类型的显示。第三章 系统软件设计软件设计上,根据功能分了几个模块编程。模块主要有:主程序模块、锯齿波模块、三角波模块、正弦波模块、方波模块、延时子程序模块等。显示波形模块是利用DAC0832的8位特点,把波形的数据以8位数据的形势送进CPU中,只要一按键就能显示波形。3.1主程序流程图如图3.1所示开始Key1按下了吗?输出锯齿波输出三角波输出正弦波输出方波Key2按下了吗?Key3按下了吗?Key4按下了吗?YYYYNNNN图3.1主程序流程图本软件设计过程中主要实现利用按键来控制不

28、同波形的输出,当按键1按下时,函数发生器就输出锯齿波;当按键2按下时,函数发生器就输出三角波;当按键3按下时,函数发生器就输出正弦波;当按键4按下时,函数发生器就输出方波。通过按键可以以任意循环方式输出不同波形。3.2子程序流程图锯齿波流程图如图3.2所示。A=00HA送到0832输出A=A+1开始A=FFH?YN图3.2 锯齿波流程图锯齿波产生将00H送入寄存器A中,DAC0832输出A中的内容,当A中的内容等于FFH返回开始,当A中的内容不为FFH时,A中的内容累加,从而输出波形。锯齿波产生子程序如下:SANTOO: MOV A ,#00H MOV DPTR,#7FFFHLLOOP: MO

29、VX DPTR,A INC A ; CJNE A,FFH,LLOOP RET三角波流程图如图3.3所示开始A=00HA送到0832输出A=A+1A=00H?A=A-1A送到0832输出A=00H?NYYN图3.3 三角波流程图三角波产生通过A中数值的加一递升,当A中的内容加到为0时, A中的内容减一递减,从而循环产生三角波。三角波产生子程序如下:TRIAN :MOV A ,#00H MOV DPTR,#7FFFHUP: MOVX DPTR,A INC A JNZ UP DOWN: DEC A MOVX DPTR,A JNZ DOWN RET正弦波程序流程图如图3.4所示开始A=00HA=129

30、?DPTR1=DPTR1+1A=正弦函数表数据A送到0832输出YN图3.4 正弦波程序流程图正弦波波形设计通过查表指令得出。其产生子程序如下:SINE: MOV DPTR1,#sinTab MOV DPTR,#7FFFH LOOP: CLR A MOVC A,A+DPTR1 CJNE A,#129,LOOP1 RETLOOP1: MOVX DPTR,A INC DPTR1 AJMP LOOPsinTab:DB 128,132,137,141,146,150,154,159,163,167 DB 171,176,180,184,188,191,195,199,203,206 DB 210,21

31、3,216,219,222,225,228,231,233,236 DB 238,240,242,244,246,247,249,250,251,252 DB 253,254,254,255,255,255,255,255,254,254 DB 253,252,251,250,249,247,246,244,242,240 DB 238,236,233,231,228,225,222,219,216,213 DB 210,206,203,198,195,192,188,184,180,176 DB 172,167,163,159,155,150,146,141,137,133 DB 128,1

32、24,119,115,111,106,102,97,93,89,85 DB 81,77,73,69,65,61,57,54,50,47,43,40,37 DB 34,31,28,25,23,20,18,16,14,12,10,9,7 DB 6,5,4,3,2,2,1,1,1,1,1,2,2,3,4,5,6 DB 7,9,10,12,14,16,18,20,23,25,28,30,33,36 DB 40,43,46,50,53,57,60,64,68,72,76,80,84 DB 88,93,97,101,106,110,114,119,123,128,129方波程序流程图如图3.5所示开始A=

33、00HA送到0832输出延时A=FFHA送到0832输出延时图3.5 方波程序流程图方波产生是当A中的内容为0时,输出对应模拟量,然后延时,当A中的内容为0FFH时,同样输出对应模拟量,再延时,从而得到方波。方波产生子程序如下:SQUN:MOV DPTR,#7FFFH MOV A ,#0FFH MOVX DPTR,A LCALL Delay MOV A ,#00HMOVX DPTR,A LCALL Delay RET 延时子程序如下:Delay: MOV R7,#10HDLY0: MOV R6,#0EDH NOPDLY1: DJNZ R6,DLY1 DJNZ R7,DLY0 RET方波的上限和

34、下限的延时时间为:7msS=1+(1+1+2237+2)16+1=7648us第四章 测试结果在确定编程思路以后将各部分的程序及各子程序编好,使用keil进行编译,根据提示的错误对程序进行修改。除了语法差错和逻辑差错外,当确认程序没问题时,通过直接加载到protues软件电路中进行仿真。当按键1拨下时,波形为锯齿波,同时指示灯1发光。仿真图如图4.1所示。 图4.1 锯齿波仿真图当按键2拨下时,波形为三角波,同时指示灯2发光。仿真图如图4.2所示。图4.2 三角波仿真图当按键3拨下时,波形为正弦波,同时指示灯3发光。仿真图如图4.3所示。图4.3 正弦波仿真图当按键4拨下时,波行为方波,同时指

35、示灯4发光。仿真图如图4.4所示。图4.4 方波仿真图在对系统进行波形仿真时可以在虚拟示波器上观察到锯齿波、三角波、正弦波和方波的波形。其中锯齿波、三角波以及正弦波的输出误差较大,方波波形较为理想。这一方面与电路设置的参数有关,另一方面也与使用的仿真软件有关。对于上述问题的解决办法是:改变仿真电路的参数或着换用版本较高的仿真软件。当然一般产生这种情况的原因多由于电路的参数设计不合理所制。当仿真时,由于存在一定的系统误差,波形效果不是很好。第五章 结论基于单片机的智能信号发生器设计,该课题的设计目的是充分运用大学期间所学的专业知识,考察现在正在使用的信号发生器的基本功能,完成一个基本的实际系统的

36、设计全过程。关键是这个实际系统设计的过程,在整个过程中我可以充分发挥单片机知识。特别是这个信号发生器的设计中涉及到一个典型的控制过程。通过单片机控制一个模数转换器DAC0832产生所需要的电流,然后使用运算放大器NE4558可以将其电流输出线性地转换成电压输出,通过程序的控制,可以产生一系列有规律的波形。这样一个信号发生装置在控制领域有相当广泛的应用范围。此设计方案硬件较为简单,主要是由单片机跟DAC08322个芯片构成,连线也较简便。键盘电路用的独立未编码结构,一个键控制一个波形。显示电路主要是由发光二极管构成,利用发光二极管的导通即发光的特性来显示是哪个波形的输出,简单易懂。软件程序方面较

37、为复杂一点,此方案主要是靠程序的控制,主要由4个波形产生的子程序加上有承上启下作用的主程序构成,程序思路还是比较清晰。其中正弦波的程序较为繁琐,因为是通过查表指令产生的,所以要列出个含有较多字符的表格。当然还是存在不足的地方,比如不能实现频率与幅度的可调,显示电路跟键盘电路有待进一步改进。参考文献1杨恢先,黄辉先.单片机原理及应用M.人民邮电出版社,2006.2曾一江.单片机微机原理与接口技术M.科学出版社,2006.3王新强.基于AT89S52的智能信号发生器J.河南机电高等专科学校学报,2006,14(3):37-39.附录A 电路原理图附录B程序清单KEY1 BIT P1.0KEY2 B

38、IT P1.1KEY3 BIT P1.2KEY4 BIT P1.3;按键KEY1:锯齿波 按键KEY2:三角波 按键KEY3: 正弦波 ;按键KEY4: 方波; ORG 0000H LJMP MAIN ORG 0030HMAIN:MOV SP,#50HSCAN_KEY1:MOV A,P1 ANL A,#0FH CJNE A,#0EH,SCAN_KEY2 LJMP B1SCAN_KEY2:MOV A,P1 ANl A,#0FH CJNE A,#0DH,SCAN_KEY3 LJMP B2SCAN_KEY3:MOV A,P1 ANl A,#0FH CJNE A,#0BH,SCAN_KEY4 LJMP

39、 B3SCAN_KEY4:MOV A,P1 ANl A,#0FH CJNE A,#07H,SCAN_KEY1 LJMP B4;利用dac0832产生锯齿波;B1:CLR P1.4 SETB P1.5 SETB P1.6 SETB P1.7SANTOO:MOV A ,#00H MOV DPTR,#7FFFHLLOOP:MOVX DPTR,A INC A ; CJNE A,FFH,LLOOP LJMP SCAN_KEY1;利用dac0832产生三角波;B2: CLR P1.5 SETB P1.4 SETB P1.6 SETB P1.7TRIAN :MOV A ,#00H MOV DPTR,#7FF

40、FHUP: MOVX DPTR,A INC A JNZ UP DOWN: DEC A MOVX DPTR,A JNZ DOWN LJMP SCAN_KEY2;利用dac0832产生正弦波;在表格里取数送到指定地址B3: CLR P1.6 SETB P1.4 SETB P1.5 SETB P1.7SINE: MOV DPTR1,#sinTab MOV DPTR,#7FFFH LOOP: CLR A MOVC A,A+DPTR1 CJNE A,#129,LOOP1 RETLOOP1: MOVX DPTR,A INC DPTR1 AJMP LOOPsinTab:DB 128,132,137,141,

41、146,150,154,159,163,167 DB 171,176,180,184,188,191,195,199,203,206 DB 210,213,216,219,222,225,228,231,233,236 DB 238,240,242,244,246,247,249,250,251,252 DB 253,254,254,255,255,255,255,255,254,254 DB 253,252,251,250,249,247,246,244,242,240 DB 238,236,233,231,228,225,222,219,216,213 DB 210,206,203,198

42、,195,192,188,184,180,176 DB 172,167,163,159,155,150,146,141,137,133 DB 128,124,119,115,111,106,102,97,93,89,85 DB 81,77,73,69,65,61,57,54,50,47,43,40,37 DB 34,31,28,25,23,20,18,16,14,12,10,9,7 DB 6,5,4,3,2,2,1,1,1,1,1,2,2,3,4,5,6 DB 7,9,10,12,14,16,18,20,23,25,28,30,33,36 DB 40,43,46,50,53,57,60,64,68,72,76,80,84 DB 88,93,97,101,106,110,114,119,123,128,129LJMP SCAN_KEY3;利用dac0832产生方波;B4: CLR P1.7 SETB P1.4 SETB P1.6 SETB P1.5SQUN:MOV DPTR,#7FFFH MOV A ,#0FFH MOVX DPTR,A LCALL Delay MOV A ,#00HMOVX DPTR,A LCAL

展开阅读全文
相关资源
猜你喜欢
相关搜索
资源标签

当前位置:首页 > 办公文档 > 其他范文


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号