基于51单片机的波形发生器的设计说明.docx
- 文档编号:5727628
- 上传时间:2022-12-31
- 格式:DOCX
- 页数:14
- 大小:245.70KB
基于51单片机的波形发生器的设计说明.docx
《基于51单片机的波形发生器的设计说明.docx》由会员分享,可在线阅读,更多相关《基于51单片机的波形发生器的设计说明.docx(14页珍藏版)》请在冰豆网上搜索。
基于51单片机的波形发生器的设计说明
1设计要求
(1)系统具有产生正弦波、三角波、方波三种周期性波形的功能。
(2)用键盘控制上述三种波形(同周期)的生成,以及由基波和它的谐波(5次以下)线性组合的波形。
(3)系统具有存储波形功能。
(4)系统输出波形的频率范围为1Hz~1MHz,重复频率可调,频率步进间隔≤100Hz,非正弦波的频率按照10次谐波来计算。
(5)系统输出波形幅度范围0~5V。
(6)系统具有显示输出波形的类型、重复频率和幅度的功能。
2波形发生器系统设计方案
设计并制作一个波形信号发生器,能够产生正弦波、方波、三角波的波形,其中不使用DDS和一些专用的波形产生芯片。
并让系统的频率范围在1Hz~1MHZ可调节,在频率范围在1HZ~10KHz时,步进小于或等于10Hz,在频率范围在10KHz~1MHz时,步进小于或等于100Hz,并且电压在0~5V范围,能够实时的显示波形的类型、频率和幅值。
2.1方案的设计思路
以AT89C51单片机作为系统的控制核心,其中P0口接DAC0832作为信号输入同时进行数模转换,P1口用来接键盘,P2口接LED显示器,由程序来控制P0口产生的波形,再由按键和按键次数控制波形的种类、频率和幅值的大小,并且能够通过按键来控制波形频率值和幅度值。
由运算放大器DAC0832来实现输出电流到电压的转换,即实现数字信号到模拟信号的转换。
另外在LED上显示实时的频率值和幅度值,产生的波形在示波器显示。
并且通过按键来决定波形数据的存储方式,在按键按下后,就把当时的波形所对应的幅度值、频率值等参数存储下来。
波形的合成:
在波形的合成时,通过外部中断高低电平的延时的时间来进行解码,在采样的时,对正弦波,三角波,方波都只取了20个采样点,因为采样点越少,其频率能够达到的值就会越大,合成时就是对幅值点进行一个叠加来输出一组波形。
2.2设计框图及系统介绍
系统主要部分设计框图如下图所示:
图2:
框图设计
2.3选择合适的设计方案
方案一:
采用模拟分立元件或单片函数发生器就可以产生正弦波、方波、三角波,方法简单。
通过调整外部元件也可以实现输出频率的改变,但采用模拟元器件造成元件分散性太大,从而产生的频率稳定性较差、抗干扰能力低、灵活性较差、而且精度低,不能实现任意波形转换和波形运算输出等方面自主控制功能。
方案二:
采用专业的锁相式频率合成方案,这种锁相式频率合成是一种高稳定度和高精确度的大量离散技术,他能够准确的产生波形,可以很好的解决频率稳定精确的情况下又要求频率在较大的范围内可调的问题。
但是频率受VCO可变频率范围上的影响,高低频率比无法做到很高,还有其只能产生正弦波或方波,不能满足产生三角波的要求。
方案三:
采用AT89C51单片机和数模转换器DAC0832实现波形的产生。
波形的产生方法是用AT89C51单片机执行波形程序,向DAC0832转换器的输入端输入相应的数据,从而在DA转换电路输出端再通过运放电路转换得到相应的电压波形。
在AT89C51的P1口接按键控制波形的种类和波形的频率,每种波形对应一种按键方式。
此方案原理简单,同时适合操作,实现起来也相对较容易。
经比较,方案三的设计能够更好的实现和完成题目的要求,产生的三种波形和频率可由按键控制,并通过按键改变来转换不同的波形,也能够在示波器上显示出所要求的波形。
波形的频率步进也可以实现调节,具有线路简单、可行性高、符合设计要求等优点。
在本设计的基础上,加上LED数码显示管,从而能够在LED上显示出频率值、幅度值信息。
输出的波形也较稳定,精度较高,通过滤波电路使得系统的抗干扰性增强,电路简单,性价比高。
综上所述,我们选择了第三种方案。
3主要硬件电路及器件介绍
3.180C51单片机
图3:
8051引脚图
80C51单片机按功能划分,由8个部件组成:
微处理器(CPU)、数据存储器(RAM)、程序存储器(ROM/EPROM)、四个I/O口(P0口、P1口、P2口、P3口)、串行口、定时器/计数器、中断系统及特殊功能寄存器(SFR)的集中控制方式[1]。
各功能部件的介绍:
(1)数据存储器(RAM):
片内为128个字节单元,片外最多可扩展至64K字节。
用以存放数据,我们称之为片内数据存储器。
(2)程序存储器(ROM/EPROM):
片内ROM为4K,片外最多可扩展至64K字节。
(3)中断系统:
具有5级中断的中断系统,2级中断优先权。
(4)定时器/计数器:
2个16位的定时器/计数器,具有四种工作方式。
(5)串行口:
1个全双工的串行通信接口,具有四种工作方式。
(6)特殊功能寄存器(SFR)共有21个,每个寄存器占一个存储单元。
(7)微处理器:
为8位CPU,内部具有一个8位CPU(位处理器),不仅可处理字节数据,还可以进行位变量的处理。
另外还有四个8位双向并行的输入/输出(I/O)端口,每个端口都有八条引线和一个输出驱动器和一个输入缓冲器。
这四个端口的功能不完全相同。
P0口既可作一般I/O端口使用,又可作地址/数据总线使用;P1口是一个准双向并行口,作通用并行I/O口使用;P2口除了可作为通用I/O使用外,还可在CPU访问外部存储器时作高八位地址线使用;P3口是一个多功能口除具有准双向I/O功能外,还具有第二功能。
控制引脚介绍:
(1)电源:
单片机使用的是5V电源,其中40引脚接电源正级,20引脚接地。
(2)时钟引脚XTAL1、XTAL2时钟引脚外接晶体与片内反相放大器构成了振荡器,产生片内CPU时钟控制信号。
此引脚也可外接晶体振荡器。
(3)RST:
当时钟电路开始工作时,在此引脚上出现24个时钟周期以上的高电平能够使单片机复位。
另外我们在此引脚与VCC之间连接一个24兆欧的下拉电阻,在外接电路之间连接二个36微法的电容,可以保证有效的复位。
在单片机正常工作时,此引脚应为≤0.5V低电平。
(4)ALE:
当访问外部程序存储器时ALE(地址锁存允许)输出脉冲用于16位地址中的低8位的锁存信号,以便P0口实现地址/数据复用。
当不去访问外部锁存器时,ALE端将输出一个1/6的时钟频率正脉冲信号输出,此频率约为时钟振荡器的1/6。
但是每当访问外部数据存储器时,在两个机器周期中ALE只出现一次,即ALE会跳过一个脉冲。
因此,严格来说,用户不能用ALE做时钟源或定时。
ALE端可以驱动8个TTL负载
(5)/PSEN(29脚):
此引脚是单片机访问片外ROM存储器的读选通信号。
在执行访问片外ROM的MOVC指令期间,每个机器周期PSEN上产生一个负脉冲,用于对于片外ROM数据存储器选通,这两次有效的/PSEN信号不出现。
其他情况下,/PSEN线均为高电平封锁状态。
(6)/EA/VPP(31脚):
当EA端保持高电平时并且程序地址小于4KB时,读取内部存储器指令,但在PC值超过4KB程序地址时则执行外部存储器内的程序;当/EA保持低电平时,不管地址大小则只访问外部程序存储器,一律读取外部程序存储器指令。
3.2DAC0832
图4:
DAC0832引脚图
DAC0832是8分辨率的D/A转换芯片,集成电路内有两级输入寄存器。
由8位输入锁存器、8位DAC寄存器、8位D/A转换器及转换控制电路四部分构成。
8位输入锁存器用于存放主机送来的数字量,使输入数字得到缓冲和锁存,并加以控制。
DAC0832输出的是电流,一般要求输出是电压,所以还必须经过一个外接的运算放大器转换成电压[3]。
DAC0832芯片具备双缓冲、单缓冲和直通三种输入方式,以便适于各种电路的需要(如要求多路D/A异步输入、同步转换等)。
DAC0832的引脚功能如下:
(1)D0~D7:
数字信号输入端。
(2)ILE:
输入寄存器允许,高电平有效。
(3)CS:
片选信号,低电平有效。
(4)WR1:
写信号1,低电平有效。
(5)XFER:
传送控制信号,低电平有效。
(6)WR2:
写信号2,低电平有效。
(7)IOUT1、IOUT2:
DAC电流输出端。
(8)RFB:
是集成在片内的外接运放的反馈电阻。
(9)VREF:
基准电压(-10~10V)。
(10)Vcc:
是源电压(+5~+15V)。
(11)AGND:
模拟地NGND:
数字地,可与AGND接在一起使用。
3.3数码显示管
通过控制7个笔画段的亮或暗,和控制一个小数点的亮和暗来实现数码管显示。
LED显示器有共阴极和共阳极2种形式。
共阳极显示器是发光二极管的阳极连接在一起,当需要显示某字符时,只需要将共阳极端接高电平,根据显示需要让a-h中某些位置接低电平。
共阴极显示器是发光二极管的阴极连接在一起,当需要显示某字符时,只需要将共阴极端接低电平,a-h中某些位接高电平即可。
显示器的工作方式分为静态显示方式和动态显示方式两种:
(1)静态显示方式就是显示器在显示一个字符时,相应的发光二极管恒定的导通或截止,例如a、b、c、d、e、f导通,g截止时显示“0”,这种使显示器显示字符的字形数据常称为段数据。
静态显示方式的每一个七段显示器,需要由一个8位并行口控制。
优点是显示稳定,提高了工作效率,缺点是位数较多时显示口随之增加。
(2)动态显示方式是一位一位的轮流点亮各位显示器,对于每一位显示器来说,每隔一段时间点亮一次。
显示器的亮度既与导通电流有关,也与点亮时间和间隔时间的比例有关。
调整电流和时间参数可以实现亮度较高较稳定的显示,如显示器的位数不大于8位,则控制显示器公共极的电位只需要一个8位口(位数据口),控制字形也需要一个8位口(段数据口)。
要使显示管显示不同的数字或者字符,需要使端口输出相应的字型码。
4系统的硬件设计
4.1硬件原理框图
对于该波形发生器的设计,我们采用了以AT89C51单片机芯片作为核心处理器,编程实现各种不同类型信号的产生,最后通过D/A转换输出到示波器。
结构简单,思路井井有条。
根据设计的基本要求,我们又把其细分为不同的功能模块,各个功能模块相互联系,相互协调,通过单片机程序构成一个统一的整体。
其整体电路原理框图如图5所示:
键盘输入
时钟复位
单片机
89C51
LED显示
DA转换
放大电路
波形显示
图5:
电路原理框图
4.289C51系统设计
89C51单片机是该波形发生器的核心,具有2个定时器,32个并行I/O口,1个串行I/O口,5个中断源[4]。
由于本设计功能简单,数据处理容易,数据存储空间也足够,因为我们采用了片选法选择芯片,进行芯片的选择和地址的译码。
在单片机最小系统中,单片机从P1口接收来自键盘的信号,并通过P0口输出控制信号,通过DA转换芯片最终由示波器显示输出波形,P2控制显示器段选码,P3口中的P3.4-P3.6通过74LS138译码器控制位选码,输出显示信息。
如果有键盘按下,则在控制器端产生一个读信号,使单片机读入信号,如果有信号输出,则在写控制端产生一个写信号,并通过示波器和显示器显示相应的信息。
单片机引脚分配如下:
RST:
用于复位电路;
XTAL1,XTAL2:
外接晶振,产生时钟信号;
P0口:
键盘输出信号。
P1口:
8位数字信号输出,外接DAC0832;具体为:
P1.0、P1.1波形选择;P1.2、P1.3、P1.4频率个位,十位,百位调节;P1.5频率加减控制;P1.6跳出循环。
P2口:
LED显示器段选码;
P3口:
P3.0锁存器74HC573片选信号;P3.2中断控制;P3.4-P3.6为74LS138输入信号,译码控制LED显示器位选。
P3.7为74LS138片选码。
4.3时钟电路
单片机的时钟信号通常用两种电路形式得到:
内部振荡和外部振荡方式。
在引脚XTAL1和XTAL2外接晶体振荡器,构成了内部振荡方式。
由于单片机内部有一个高增益的反相放大器,当外接晶振后,就构成了自激振荡,并产生振动时钟脉冲。
晶振通常选用6MHZ、12MHZ、24MHZ。
我们选择了24MHZ和晶振分别接引脚XTAL1和XTAL2,电容C1,C2均选择为30pF,对振荡器的频率有稳定作用,当频率较大时,正弦波方波、三角波中每一点的延时时间为几微秒,故延时时间还要加上指令时间才能获得较大的频率波形。
图6:
时钟电路
4.4复位电路
复位引脚RST通过一个施密特触发器与复位电路相连,施密特触发器用来抑制噪声。
复位电路通常采用上电自动复位和按钮复位两种方式。
在每个机器周期的S5P2,施密特触发器的输出电平由复位电路采样一次,然后才能得到内部复位操作所需要的信号。
本设计选择了按键复位如图7,在系统运行时,按一下开关,就在RST断出现一段高电平,使图6时钟电路图器件复位。
此时ALE、PSEN、P0、P1、P2、P4输出高电平,在RST上输入返回低电平以后,就退出复位状态开始工作。
图7:
按键复位
4.5键盘接口电路
常用的键盘电路一般为矩阵式,但是对于此设计,为了方便程序的简单化,我们采用了一般的键盘接口输出信号。
具体实现方法:
P1.0、P1.1用来作为波形选择,其中当P1.0=0,P1.1=0输出正弦波,当P1.0=0,P1.1=1输出三角波,当P1.0=1,P1.1=1输出方波。
P1.2、P1.3、P1.4用来作为频率个位,十位,百位调节;P1.5控制频率加减;P1.6跳出循环。
图8:
键盘接口电路
4.6数模转换器
由于单片机输出的是数字信号,因为要得到模拟信号的波形就必须对其进行数模换。
我们采用了DAC0832数模转换器,该芯片由8位输入锁存器、8位DAC寄存器、8位D/A转换器及转换控制电路四部分构成。
由于其输出为电流输出,因为外加运算放大器OP07使之装换为电压输出。
最后通过示波器显示输出的波形。
开始
显示
初始化系统
按键是否按下
计算相关函数
定时中断
送端口显示
查询选择波型
波形输出
LED显示
图10:
D/A转换电路
5系统软件设计
5.1流程图:
图11:
流程图
5.2产生波形图
本设计将各种波形的数据通过P1.0口和P1.1口选择,送往在单片机的程序储存器里,通过改变信号的频率的个位,十位,百位来改变这个频率,然后计算其技术初值,开启中断,通过改变D/A转换器输出波形。
5.2.1正弦波
图12:
仿真正弦波
正弦波程序如下:
voidzhengxuanbo()
{
uintk=0;
while
(1)
{
P0=table[k++];
delay(t);
xianshiqi(t);
if(k==182)
{
k=0;
}
if(s5==0)
{
t=t+1;
}
if(s6==0)
{
t=t-1;
}
}
}
5.2.2三角波
产生三角波的原理:
三角波产生是通过P0口将00H送入寄存器A中,DAC0832输出A中的内容,通过A中数值的加1递升,同时延时,当A中的内容为0FF时,A中的内容减1递减,从而循环产生三角波[5]。
图13:
仿真三角波
三角波程序:
voidsanjiaobo()
{
uintj=0;
while
(1)
{
P0=j;
delay(t);
j=j+1;
P0=j;
delay(t);
xianshiqi(t);
if(j==256)
{
if(j!
=0)
{
j=j-1;
P0=j;
delay(t);
xianshiqi(t);
if(s5==0)
{
t=t+1;
}
if(s6==0)
{
t=t-1;
}
}
}
if(s5==0)
{
t=t+1;
}
if(s6==0)
{
t=t-1;
}
}
}
5.2.3方波
产生方波的原理:
方波产生是通过P0口将00H输出给DAC0808,输出对应模拟量,然后读取P2口的状态,取反后作为延时常量,延时时间到,将FFH输出时,同样输出对应模拟量,再延时,从而得到方波。
图14:
仿真方波
方波程序:
voidfangbo()
{
while
(1)
{
P0=256;
delay(t);
P0=0;
delay(t);
xianshiqi(t);
if(s5==0)
{
t=t+1;
}
if(s6==0)
{
t=t-1;
}
}
}
6结论
灵活运用,以书本知识为基础灵活的扩展,学习前人的经验,向高层次迈进。
当然还是存在不足的地方,例如当频率过小的时候矩形波会有些失真,转换器转换时可以加一个锁存器,放大电路设计上还有待进一步改进,使其具有更强的输出能力等。
主要参考文献:
[1]张鑫.单片机原理及应用[M].北京:
电子工业出版社,2005.8.
[2]梅丽凤,王艳秋,王毓铎.单片机原理及其接口技术[M].北京:
清华大学出版社,2006.8.
[3]张毅刚,彭喜源,谭晓昀,曲春波.MCS-51单片机应用设计[M].哈尔滨:
哈尔滨工业大学出版社,1997.
[4]张洪润,易涛.单片机应用技术教程[M].北京:
清华大学出版社,2006.10.
[5]丁向荣,谢俊,王彩申.单片机C语言编程与实践[M].北京:
电子工业出版社,2009.8.
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 基于 51 单片机 波形 发生器 设计 说明
![提示](https://static.bdocx.com/images/bang_tan.gif)