单片机正文函数信号发生器.doc
《单片机正文函数信号发生器.doc》由会员分享,可在线阅读,更多相关《单片机正文函数信号发生器.doc(22页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、. . . . 编号:单片机综合实训 (论文)说明书题 目: 函数信号发生器 院 (系): 信息与通信学院 专 业: 电子信息工程 学生:学 号:指导教师:2012年 12月 24 日4 / 22摘 要本文介绍一种用AT89C51单片机构成的波形发生器,可产生方波、三角波、正弦波、锯齿波等多种波形,波形的周期可用程序改变,并可根据需要选择单极性输出或双极性输出,具有线路简单、结构紧凑、性能优越等特点。文章给出了源代码,通过仿真测试,其性能指标达到了设计要求。关键词:单片机;DAC;信号发生器AbstractThis paper introduces a AT89C51 single chip
2、waveform generator, can produce square wave, triangle wave, sine wave, sawtooth wave and other wave, waveform cycle can be used to change procedures, and in accordance with the need to select the output unipolar or bipolar output, has simple circuit, compact structure, superior performance character
3、istics. The article gives the source code, through simulation test, the performance indexes have reached the design requirements.Key words: single chip microcomputer; DAC; signal generator。目录目录31 绪论41.1单片机与TLC5615概述41.2信号发生器的分类41.3 研究容42 方案的设计与选择52.1 方案的比较52.2 设计原理52.3 设计功能63 硬件设计73.1 硬件原理框图73.2 系统P
4、CB板的设计73.3 主控电路73.4数/模转换电路83.5 按键接口电路103.6 时钟电路103.7 显示电路104 软件设计124.1 程序流程图124.2 软件与联机调试134.3 主控程序调试145 实训心得体会1参考文献1附录12电路原理图与PCB图2附录2 源程序31 绪论1.1单片机与TLC5615概述随着大规模集成电路技术的发展,中央处理器(CPU)、随机存取存储器(RAM)、只读存储器(ROM)、(I/O)接口、定时器/计数器和串行通信接口,以与其他一些计算机外围电路等均可集成在一块芯片上构成单片微型计算机,简称为单片机。单片机具有体积小、成本低,性能稳定、使用寿命长等特点
5、。其最明显的优势就是可以嵌入到各种仪器、设备中,这是其他计算机和网络都无法做到的。TLC5615为美国仪器1999年推出的产品,是具有串行接口的数模转换器,其输出为电压型,最大输出电压是基准电压值的两倍。带有上电复位功能,即把DAC寄存器复位至全零。TLC5615性价比高,目前在国市场很方便购买。1.2信号发生器的分类信号发生器应用广泛,种类繁多,性能各异,分类也不尽一致。按照频率围分类可以分为:超低频信号发生器、低频信号发生器、视频信号发生器、高频波形发生器、甚高频波形发生器和超高频信号发生器。按照输出波形分类可以分为:正弦信号发生器和非正弦信号发生器,非正弦信号发生器又包括:脉冲信号发生器
6、,函数信号发生器、扫频信号发生器、数字序列波形发生器、图形信号发生器、噪声信号发生器等。按照信号发生器性能指标可以分为一般信号发生器和标准信号发生器。前者指对输出信号的频率、幅度的准确度和稳定度以与波形失真等要求不高的一类信号发生器。后者是指其输出信号的频率、幅度、调制系数等在一定围连续可调,并且读数准确、稳定、屏蔽良好的中、高档信号发生器。1.3 研究容本文是做基于单片机的信号发生器的设计,将采用编程的方法来实现三角波、锯齿波、矩形波、正弦波的发生。根据设计的要求,对各种波形的频率和幅度进行程序的编写,并将所写程序装入单片机的程序存储器中。在程序运行中,当接收到来自外界的命令,需要输出某种波
7、形时再调用相应的中断服务子程序和波形发生程序,经电路的数/模转换器和运算放大器处理后,从信号发生器的输出端口输出。2 方案的设计与选择2.1 方案的比较方案一:采用单片函数发生器(如8038),8038可同时产生正弦波、方波等,而且方法简单易行,用D/A转换器的输出来改变调制电压,也可以实现数控调整频率,但产生信号的频率稳定度不高。方案二:采用锁相式频率合成器,利用锁相环,将压控振荡器(VCO)的输出频率锁定在所需频率上,该方案性能良好,但难以达到输出频率覆盖系数的要求,且电路复杂。方案三:采用单片机编程的方法来实现。该方法可以通过编程的方法来控制信号波形的频率和幅度,而且在硬件电路不变的情况
8、下,通过改变程序来实现频率的变换。此外,由于通过编程方法产生的是数字信号,所以信号的精度可以做的很高。鉴于方案一的信号频率不够稳定和方案二的电路复杂,频率覆盖系数难以达标等缺点,所以决定采用方案三的设计方法。它不仅采用软硬件结合,软件控制硬件的方法来实现,使得信号频率的稳定性和精度的准确性得以保证,而且它使用的几种元器件都是常用的元器件,容易得到,且价格便宜,使得硬件的开销达到最省。2.2 设计原理数字信号可以通过数/模转换器转换成模拟信号,因此可通过产生数字信号再转换成模拟信号的方法来获得所需要的波形。89C51单片机本身就是一个完整的微型计算机,具有组成微型计算机的各部分部件:中央处理器C
9、PU、随机存取存储器RAM、只读存储器ROM、I/O接口电路、定时器/计数器以与串行通讯接口等,只要将89C51再配置键盘与其接口、显示器与其接口、数模转换与波形输出、指示灯与其接口等四部分,即可构成所需的波形发生器,其信号发生器构成原理框图如图2.1所示。 输出AT89C51单片机滤波放大D/A转换器接口电路图2.1 信号发生器原理框图AT89C51是整个波形发生器的核心部分,通过程序的编写和执行,产生各种各样的信号,并从键盘接收数据,进行各种功能的转换和信号幅度的调节。当数字信号经过接口电路到达转换电路,将其转换成模拟信号也就是所需要的输出波形。2.3 设计功能(1)本方案利用8155扩展
10、8个独立式按键,6个LED显示器。其中“S0”号键代表方波输出,“S1”号键代表正弦波输出,“S2”号键代表三角波输出,“S3” 号键代表锯齿波输出。(2)“S4”号键为10Hz的频率信号,“S5”号键为100Hz的频率信号,“S6”号键为500Hz的频率信号,“S7”号键为1KHz的频率信号,6个LED显示器输出信号的频率值,选用共阳极LED。(3)利用两片DAC0832实现幅度可调的信号源,(其中一片用来调节幅度,另外一片用来实现信号源的输出)。(4)频率围:101000Hz。(5)输出波形幅度为05V。3 硬件设计3.1 硬件原理框图硬件原理方框图如图3.1所示。波形输出放大电路复位电路
11、显示电路数/模转换电路键盘电路单片机图3.1 硬件原理框图3.2 系统PCB板的设计PCB即印刷电路板,是电子电路的承载体。在现代电子产品中,几乎都要使用PCB。PCB板的设计是电路设计的最后一个环节,也是对原理电路的再设计。因此PCB板的设计是理论设计到实际应用一个十分重要的容。印制电路板(PCB)是电子产品中电路元件和器件的支撑件它提供电路元件和器件之间的电气连接。PCB设计的好坏对抗干扰能力影响很大因此,在进行PCB设计时必须遵守印制电路板设计原则和抗干扰措施的一般原则,并应符合抗干扰设计的要求。本次设计采用Altium公司PROTEL系列设计完成SCH到PCB的设计,并且手工完成电路焊
12、接以与整机的装配。3.3 主控电路AT89C51单处机部设置两个16位可编程的定时器/计数器T0和T1,它们具有计数器方式和定时器方式两种工作方式与4种工作模式。在波形发生器中,将其作定时器使用,用它来精确地确定波形的两个采样点输出之间的延迟时间。模式1采用的是16位计数器,当T0或T1被允许计数后,从初值开始加计数,最高位产生溢出时向CPU请求中断。中断系统是使处理器具有对外界异步事件的处理能力而设置的。当中央处理器CPU正在处理某件事的时候外界发生了紧急事件,要求CPU暂停当前的工作,转而去处理这个紧急事件。在波形发生器中,只用到片定时器计数器溢出时产生的中断请求,即是在AT89C51输出
13、一个波形采样点信号后,接着启动定时器,在定时器未产生中断之前,AT89C51等待,直到定时器计时结束,产生中断请求,AT89C51响应中断,接着输出下一个采样点信号,如此循环产生所需要的信号波形6。如图3.2所示,AT89C51从P0口接收来自键盘的信号,并通过P2口输出一些控制信号,将其输入到8155的信号控制端,用于控制其信号的输入、输出。如果有键按下,则在读控制端会产生一个读信号,使单片机读入信号。如果有信号输出,则在写控制端产生一个写信号,并将所要输出的信号通过8155的PB口输出,并在数码管上显示出来。图3.2 主控电路图3.4数/模转换电路由于单片机产生的是数字信号,要想得到所需要
14、的波形,就要把数字信号转换成模拟信号,所以该文选用价格低廉、接口简单、转换控制容易TLC5615。TLC5615由10 位 DAC 电路;一个 16 位移位寄存器, 接受串行移入的二进制数,并且有一个级联的数据输出端DOUT;并行输入输出的 10 位 DAC 寄存器, 为 10 位 DAC 电路提供待转换的二进制数据;电压跟随器为参考电压端REFIN提供很高的输入阻抗,大约10M;2 电路提供最大值为 2 倍于 REFIN 的输出;上电复位电路和控制电路组成。由于TLC5615电压型输出,所以不用外接运放,使之在使用时更为方便TLC5615各引脚与其功能如下:DIN: 串行数据输入端; SCL
15、K: 串行时钟输入端; /CS: 芯片选用通端,低电平有效; DOUT: 用于级联时的串行数据输出端; AGND: 模拟地; REFIN:基准电压输入端, 2V (VDD - 2); OUT: DAC 模拟电压输出端; VDD: 正电源端,4.55.5V ,通常取 5V。图3.3.1TLC引脚图TLC5615的工作方式有两种: 第一种方式由图3.3可以看出16 位移位寄存器分为高 4 位虚拟位、低两位填充位以与 10位有效位。在单片 TLC5615 工作时,只需要向 16 位移位寄存器按先后输入 10位有效位和低 2 位填充位, 2 位填充位数据任意,这是第一种方式,即 12 位数据序列。第二
16、种方式为级联方式, 即 16 位数据列,可以将本片的 DOU T 接到下一片的 DIN , 需要向 16 位移位寄存器按先后输入高 4 位虚拟位、10 位有效位和低 2 位填充位, 由于增加了高 4 位虚拟位, 所以需要 16 个时钟脉冲。图3.3.2TLC5615功能框图3.5 按键接口电路图3.4为键盘接口电路的原理图,图中键盘和8155的PA口相连,AT89C51的P0口和8155的D0口相连,AT89C51不断的扫描键盘,看是否有键按下,如有,则根据相应按键作出反应。其中“S0”号键代表方波输出,“S1”号键代表正弦波输出,“S2”号键代表三角波输出。 “S3”号键代表锯齿波输出,“S
17、4”号键为10Hz的频率信号,“S5”号键为100Hz的频率信号,“S6”号键为500Hz的频率信号,“S7”号键为1KHz的频率信号3。 图3.4 按键接口3.6 时钟电路8051单片机有两个引脚(XTAL1,XTAL2)用于外接石英晶体和微调电容,从而构成时钟电路,其电路图如图3.5所示。电容C1、C2对振荡频率有稳定作用,其容量的选择为30pf,振荡器选择频率为12MHz的石英晶体。由于频率较大时,三角波、正弦波、锯齿波中每一点的延时时间为几微秒,故延时时间还要加上指令时间才能获得较大的频率波形9。 图3.5 时钟电路3.7 显示电路显示电路是用来显示波形信号的频率,使得整个系统更加合理
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 单片机 正文 函数 信号发生器
限制150内