ImageVerifierCode 换一换
格式:DOCX , 页数:15 ,大小:39KB ,
资源ID:2302464      下载积分:3 金币
快捷下载
登录下载
邮箱/手机:
温馨提示:
快捷下载时,用户名和密码都是您填写的邮箱或者手机号,方便查询和重复下载(系统自动生成)。 如填写123,账号就是123,密码也是123。
特别说明:
请自助下载,系统不会自动发送文件的哦; 如果您已付费,想二次下载,请登录后访问:我的下载记录
支付方式: 支付宝    微信支付   
验证码:   换一换

加入VIP,免费下载
 

温馨提示:由于个人手机设置不同,如果发现不能下载,请复制以下地址【https://www.bingdoc.com/d-2302464.html】到电脑端继续下载(重复下载不扣费)。

已注册用户请登录:
账号:
密码:
验证码:   换一换
  忘记密码?
三方登录: 微信登录   QQ登录  

下载须知

1: 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。
2: 试题试卷类文档,如果标题没有明确说明有答案则都视为没有答案,请知晓。
3: 文件的所有权益归上传用户所有。
4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
5. 本站仅提供交流平台,并不能对任何下载内容负责。
6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

版权提示 | 免责声明

本文(基于51单片机的信号发生器完整电路程序.docx)为本站会员(b****2)主动上传,冰点文库仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对上载内容本身不做任何修改或编辑。 若此文所含内容侵犯了您的版权或隐私,请立即通知冰点文库(发送邮件至service@bingdoc.com或直接QQ联系客服),我们立即给予删除!

基于51单片机的信号发生器完整电路程序.docx

1、基于51单片机的信号发生器完整电路程序摘要之巴公井开创作创作时间:贰零贰壹年柒月贰叁拾日本文以STC89C51单片机为核心设计了一个低频函数信号发生器。信号发生器采取数字波形合成技术,通过硬件电路和软件程序相结合,可输出自定义波形,如正弦波、方波、三角波、三角波、梯形涉及其他任意波形,波形的频率和幅度在一定范围内可任意改变。波形和频率的改变通过软件控制,幅度的改变通过硬件实现。介绍了波形的生成原理、硬件电路和软件部分的设计原理。本系统可以发生最高频率798.6HZ的波形。该信号发生器具有体积小、价格低、性能稳定、功能齐全的优点。关键词:低频信号发生器;单片机;D /A转换;1设计选题及任务设计

2、题目:基于单片机的信号发生器的设计与实现 任务与要求:设计一个由单片机控制的信号发生器。运用单片机系统控制发生多种波形,这些波形包含方波、三角波、锯齿波、正弦波等。信号发生器所发生的波形的频率、幅度均可调节。并可通过软件任意改变信号的波形。基本要求:1. 发生三种以上波形。如正弦波、三角波、矩形波等。 2.最大频率不低于 500Hz。而且频率可按一定规律调节,如周期按1T,2T,3T,4T或1T,2T,4T,8T变更。 3.幅度可调,峰峰值在05V之间变更。 扩展要求:发生更多的频率和波形。 2系统概述211总体方案:方案一:采取模拟电路搭建函数信号发生器,它可以同时发生方波、三角波、正弦波。

3、但是这种模块发生的不克不及发生任意的波形(例如梯形波),而且频率调节很不方便。方案二:采取锁相式频率合成器,利用锁相环,将压控振荡器(VCO)的输出频率锁定在所需频率上,该方案性能良好,但难以达到输出频率覆盖系数的要求,且电路复杂。方案三:使用集成信号发生器发生芯片,例如AD9854,它可以生成最高几十MHZ的波形。但是该方案也不克不及发生任意波形(例如梯形波),而且价格昂贵。方案四:采取AT89C51单片机和DAC0832数模转换器生成波形,加上一个低通滤波器,生成的波形比较纯净。它的特点是可发生任意波形,频率容易调节,频率能达到设计的500HZ以上。性能高,在低频范围内稳定性好、操纵方便、

4、体积小、耗电少。经比较,方案四既可满足课程设计的基本要求又能充分发挥其优势,电路简单,易控制,性价比高,所以采取该方案.212改变幅度方案:方案一:可以将送给DA的数字量乘以一个系数,这样就可以改变DA输出电流的幅度,从而改变输出电压;但是这样做有很严重的问题,单片机在做乘法运算时需要很长的时间,这样的话输出波形的频率就会很低,达不到至少500HZ的要求;而且该方案的输出电压做不到连续可调,当DA的输入数字量比较小时,输出的波形失真就会比较严重。方案二:将输出电压通过一个运算放大器的放大。这样还有个优点是幅度连续可调。经比较,方案二既可满足课程设计的基本要求,而且电路也挺简单。数字信号可以通过

5、数/模转换器转换成模拟信号,因此可通过发生数字信号再转换成模拟信号的方法来获得所需要的波形。89C51单片机自己就是一个完整的微型计算机,具有组成微型计算机的各部分部件:中央处理器CPU、随机存取存储器RAM、只读存储器ROM、I/O接口电路、定时器/计数器以及串行通讯接口等,只要将89C51再配置键盘及、数模转换及波形输出、放大电路等部分,即可构成所需的波形发生器,其信号发生器构成系统框图如下图所示。系统框图89C51是整个波形发生器的核心部分,通过程序的编写和执行,发生各种各样的信号,并从键盘接收数据,进行各种功能的转换和信号幅度的调节。当数字信号电路到达转换电路,将其转换成模拟信号也就是

6、所需要的输出波形。波形ROM表是将信号一个周期等间距地分离成64个点,储存在单片机得RON内。具体ROM表是通过MATLAB生成的,例如正弦表,MATLAB生成的程序如下:x=0:2*pi/64:2*pi; y=round(sin(x)*127)+1283单元电路设计与分析设计中主要采取STC89C51型单片机,它具有如下优点:(1)拥有完善的外部扩展总线,通过这些总线可方便地扩展外围单元、外围接口等。(2)该单片机内部拥有4K字节的FLASH ROM程序存储器空间和256字节的RAM数据存储空间,完全可以满足程序的要求。由于该芯片可电擦写,故可重复使用。如果更改程序内容,可将芯片拿下重新烧写

7、。(3)该单片机与工业尺度的MCS51型机的指令集和输出引脚兼容。中断系统是使处理器具有对外界异步事件的处理能力而设置的。当中央处理器CPU正在处理某件事的时候外界发生了紧急事件,要求CPU暂停当前的工作,转而去处理这个紧急事件。在波形发生器中,用两个开光直接与外部中断0和外部中断1的管脚相连,其中S1开光用来改变波形,S2开光用来改变频率。在程序主函数中,我们写了个死循环一直输出一个默认的波形,当S1或S2按下又抬起时,程序会暂时跳出死循环,进入中断处理程序,从而对波形和频率进行改变。时钟电路。由于频率较大时,三角波、正弦波、方波等波中每一点延时时间为几微秒,故延时时间还要加上指令时间即可得

8、到指定频率的波形,该电路用11.0592MHz晶振。主控电路图3.1.2 数/模转换电路由于单片机发生的是数字信号,要想得到所需要的波形,就要把数字信号转换成模拟信号,所以该文选用价格低廉、接口简单、转换控制容易并具有8位分辨率的数模转换器DAC0832。DAC0832主要由8位输入寄存器、8位DAC寄存器、8位D/A转换器以及输入控制电路四部分组成。但实际上,DAC0832输出的电量也不是真正能连续可调,而是以其绝对分辨率为单位增减,是准模拟量的输出。DAC0832是电流型输出,在应用时外接运放使之成为电压型输出。根据对DAC0832的数据锁存器和DAC寄存器的分歧的控制方式,DAC0832

9、有三种工作方式:直通方式、单缓冲方式和双缓冲方式。本设计选用直通方式。DAC0832的数据口和单片机的P0口相连。CSDA:片选信号输入线(选通数据锁存器),低电平有效;WR:数据锁存器写选通输入线,负脉冲(脉宽应大于500ns)有效。由ILE、CS、WR1的逻辑组合发生LE1,当LE1为高电平时,数据锁存器状态随输入数据线变换,LE1的负跳变时将输入数据锁存;数模转换电路LM324的5管脚与DAC0832的(IOUT2)12管脚相连,LM324的6管脚与DAC0832的(IOUT1)11管脚相连,LM324的7管脚与DAC0832的REF(9)管脚相连.第一级运算放大器的作用是将DAC083

10、2输出的电流信号转化为电压信号V1,第二级运算放大器的作用是将V1通过反向放大电路-(R2/R1)倍。题目要求输出的电压在0-5V可调,而V1的电压大约是5V,所以R1选择5K的电阻,R2选择10K的电位器,这样最大的输出电压为5*(10/2)=10,最小电压为0,可以实现题目要求的0-5V。在第二个运算放大器的输出端连了一个低通滤波器。如果不加低通滤波器,也能够生成波形,但是发生的信号中毛刺很多,加一个低通滤波器不但起到的滤波的作用,还起到了平滑的作用。低通滤波器的截止频率F=1/(2*pi*R3*C6),这里我们选择R3 为100欧姆电阻,C6为104电容,截止频率F=16KHZ。实验标明

11、,此时的输出波形效果不错。3.1.4 串口通信电路通用异步收发器(UART)是一种串行接口,一般微处理器中都包含这种外设接口。异步串行接口提供了一种简单的途径,使两个器件无需共享同一个时钟信号就能进行通信。如果再加入一个合适的电平转换器MAX232,串口就能能用在RS232和RS485等网络中实现通信,或者与计算机的COM端口连接。串口只需两根信号线(RX和TX)即可实现,而且只要两端器件都采取同样的位格式和波特率,那么它们无需其它任何对方的信息就可以成功传输数据。 串口通信电路图软件设计上,根据功能分了几个模块编程。模块主要有:主程序模块、外部中断0模块,外部中断1模块。主程序: 主程序先是

12、进行一些初始化的工作,然后根据波形标记a,b,c,d,e的值进入相应的while 循环。这样写的好处是输出的波形频率可以790多HZ。在while循环中,单片机根据地址标记位不断低查表,然后把查得的值赋给DAC0832的数据口,然后地址标记位加一,并判断地址标记位是否等于64,如果是就置0再往下执行,如果不是直接往下执行。然后根据频率标记位进行相应的延时。主程序流程图中断服务程序:本程序中两个外部中断分别起到了控制波形和频率的作用。在程序中还加入了消抖部分。4装置调试及丈量数据分析4.1调试过程;1 欠亨电,用万用表根据电路图仔细检查各线路连接是否正常。2 首先是调试单片机部分,DA和运算放大

13、器芯片不接。用STC_ISP_V483软件通过串口下程序。看是否可以正常下程序。3当可以正常下程序时,给51单片机下一个让所有I/0口一会儿输入0,延时,再输出1,以此类推。用万用表丈量各I/O口得电压是不是一会儿高,一会儿低。4安上DA和运算放大器芯片,给单片机下一个输出正弦波的测试程序,通过示波器看输出是否正常。5 给单片机下一个完整的程序,分别按下S1,看波形是否改变。按下S2,看频率是否改变。4.2频率的丈量数据: 单位:HZ周期T2T3T4T5T6T7T8T理论值实际值4.3出现的问题与解决的方法:1.调试单片机的串口时,发现不克不及正常的下程序。我想可能是单片机坏了借了一块学习板测

14、试了一下单片机芯片,发现可以正常下载。这说明很可能是MAX232的电路出了问题。我仔细检查了电路图,又上网查了下其他的MAX232的电路图,发现我的电路图和他人的纷歧样。我是依照郭天翔的那本新概念51单片机C语言教程 入门、提高、开发、拓展全第130页的串口电路画的图,电路图中MAX232的TIOU1接串口的第3脚。而其他书上有些电路图却是MAX232的TIOU1接到了串口的第2脚。于是我将MAX232的TIOU1接串口的第2脚,再下程序,终于可以正常下载了。2刚开始写的测试程序输出的波形失真很大。我想可能是波形的ROM内外的数据值过小,导致DA输出的误差很大。因而卧将波形的ROM内外的数据值

15、调大,在测试时发现波形变得好多了。3.调试波形的时候我发现矩形波的失真比较大。我想到可能是低通滤波器的截止频率太低了,因而我将RC低通滤波器的电阻由1K换成了100欧姆,效果好了很多。4.4系统仿真波形:矩形波锯齿波正弦波4.5效果分析:由4.2的频率理论值与实际值,可知频率在T,2T,3T,4T,5T,6T,7T,8T上频率误差很小。最终的波形输出效果也很不错。示波器 直流稳压电源万用表5结束语基于单片机的信号发生器设计,这个信号发生器的设计中涉及到一个典型的控制过程。通过单片机控制一个模数转换器DAC0832发生所需要的电流,然后使用运算放大器LM324可以将其电流输出线性地转换成电压输出

16、,再将电压经过运算放大器的放大,可以得到足够幅度的信号。通过程序的控制,可以发生一系列有规律的波形。这样一个信号发生装置在控制领域有相当广泛的应用范围。最终做出来的信号发生器满足了题目中的所有要求:1.发生五种波形。正弦波、三角波、矩形波、梯形波,锯齿波。 2.最大频率为798.6HZ。而且频率可按按1T,2T,3T,4T,5T,6T,7T,8T变更。3.幅度可调,峰峰值在05V之间变更。 当然还是存在缺乏的地方,比方不克不及实现频率的按一个小的步进调整。而且当频率太小时矩形波会有些失真。信号发生器可以生成更多的波形,只需要再加些波形表即可。在这里得感谢学校为我们提供个这样一个实践的机会,当然

17、还得感谢实验室指导老师们的细心指导。参考文献:2 童诗白.模拟电路技术基础M.北京:高等教育出版社,2000.171202.附录1:总电路图附录2:源程序#include#define uchar unsigned char#define uint unsigned intsbit csda=P22;sbit wr=P21;sbit s1=P32;sbit s2=P33;uchar k=0,p=0,delay=0;uchar bxxz=0;pinglv=0;uchar a=1,b=0,c=0,d=0,e=0;uchar code sin64=135,145,158,167,176,188,19

18、9,209,218,226,234,240,245,249,252,254,254,253,251,247,243,237,230,222,213,204,193,182,170,158,146,133,121,108,96,84,72,61,50,41,32,24,17,11,7,3,1,0,0,2,5,9,14,20,28,36,45,55,66,78,90,102,114,128;uchar code juxing64=255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,255,2

19、55,255,255,255,255,255,255,255,255,255,255,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0;uchar code juchi64=0,4,8,12,16,20,24,28,32,36,40,45,49,53,57,61,65,69,73,77,81,85,89,93,97,101,105,109,113,117,121,125,130,134,138,142,146,150,154,158,162,166,170,174,178,182,186,190,194,198,20

20、2,206,210,215,219,223,227,231,235,239,243,247,251,255;uchar code tixing64=0,13,26,39,52,65,78,91,104,117,130,143,156,169,182,195,208,221,234,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,247,242,229,216,203,190,177,164,151,138,125,112,99,86,73,60

21、,47,34,21,8;uchar code sanjiao64=0,8,16,24,32,40,48,56,64,72,80,88,96,104,112,120,128,136,144,152,160,168,176,184,192,200,208,216,224,232,240,248,248,240,232,224,216,208,200,192,184,176,168,160,152,144,136,128,120,112,104,96,88,80,72,64,56,48,40,32,24,16,8,0;void delay1() int a,b; for(a=1;a0;a-) for

22、(b=122;b0;b-);void int0() interrupt 0 EX0=0; delay1(); if(s1=0) bxxz+; if(bxxz=5) bxxz=0; switch(bxxz) case 0 : a=1,b=0,c=0,d=0,e=0; break; case 1 : a=0,b=1,c=0,d=0,e=0; break; case 2 : a=1,b=0,c=1,d=0,e=0; break; case 3 : a=0,b=0,c=0,d=1,e=0; break; case 4 : a=0,b=0,c=0,d=0,e=1; break; delay1(); wh

23、ile(!s1); while(!s1); EX0=1;void int1() interrupt 2 EX1=0; delay1(); if(s2=0) p+; if(p=8) p=0; switch(p) case 1 : pinglv=3; break; case 2 : pinglv=6; break; case 3 : pinglv=9; break; case 4 : pinglv=12; break; case 5 : pinglv=15; break; case 6 : pinglv=18; break; case 7 : pinglv=21; break; default :

24、 pinglv=0; break; delay1(); while(!s2); while(!s2); EX1=1;void main() csda=0; wr=0; EA=1; IT0=1; EX0=1; IT1=1; EX1=1; while(1) while(a) delay=pinglv; P0=sink; k+; if(k=64) k=0; while(delay) delay-; while(b) delay=pinglv; P0=juxingk; k+; if(k=64) k=0; while(delay) delay-; while(c) delay=pinglv; P0=juchik; k+; if(k=64) k=0; while(delay) delay-; while(d) delay=pinglv; P0=tixingk; k+; if(k=64) k=0; while(delay) delay-; while(e) delay=pinglv; P0=sanjiaok; k+; if(k=64) k=0; while(delay) delay-; 创作时间:贰零贰壹年柒月贰叁拾日

copyright@ 2008-2023 冰点文库 网站版权所有

经营许可证编号:鄂ICP备19020893号-2