基于AT89C52单片机的函数信号发生器的测量.docx

上传人:b****3 文档编号:4803741 上传时间:2023-05-07 格式:DOCX 页数:22 大小:492.58KB
下载 相关 举报
基于AT89C52单片机的函数信号发生器的测量.docx_第1页
第1页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第2页
第2页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第3页
第3页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第4页
第4页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第5页
第5页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第6页
第6页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第7页
第7页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第8页
第8页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第9页
第9页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第10页
第10页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第11页
第11页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第12页
第12页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第13页
第13页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第14页
第14页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第15页
第15页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第16页
第16页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第17页
第17页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第18页
第18页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第19页
第19页 / 共22页
基于AT89C52单片机的函数信号发生器的测量.docx_第20页
第20页 / 共22页
亲,该文档总共22页,到这儿已超出免费预览范围,如果喜欢就下载吧!
下载资源
资源描述

基于AT89C52单片机的函数信号发生器的测量.docx

《基于AT89C52单片机的函数信号发生器的测量.docx》由会员分享,可在线阅读,更多相关《基于AT89C52单片机的函数信号发生器的测量.docx(22页珍藏版)》请在冰点文库上搜索。

基于AT89C52单片机的函数信号发生器的测量.docx

基于AT89C52单片机的函数信号发生器的测量

 

 

JIANGSUTEACHERSUNIVERSITYOFTECHNOLOGY

测控系统综合训练课程设计

 

基于AT89C52单片机的函数信号发生器的测量

 

学院名称:

电气信息工程学院

专业:

测控技术与仪器

班级:

姓名:

学号:

指导教师:

 

2011年12月

摘要

本系统利用单片机AT89C52采用程序设计方法产生锯齿波、正弦波、矩形波三种波形,再通过D/A转换器DAC0832将数字信号转换成模拟信号,滤波放大,最终由示波器显示出来,能产1Hz—3kHz的波形。

通过按钮来控制三种波形的类型选择、频率变化,并通过液晶屏1602显示其各自的类型以及数值,系统大致包括信号发生部分、数/模转换部分以及液晶显示部分三部分,其中尤其对数/模转换部分和波形产生和变化部分进行详细论述。

关键词:

单片机AT89C52、DAC0832、液晶1602

 

目录

1.系统设计……………………………………………4

1.1设计要求………………………………………………4

1.2方案设计与论证………………………………………4

1.2.1信号发生电路方案论证…………………………4

1.2.2单片机的选择论证………………………………5

1.2.3显示方案论证……………………………………5

1.3总体系统设计…………………………………………6

1.4硬件实现及单元电路设计…………………………6

1.4.1单片机最小系统的设计…………………………6

1.4.2波形产生模块设计………………………………7

1.4.3显示模块的设计…………………………………8

1.5软件设计流程…………………………………………8

1.6源程序…………………………………………………9

2.输出波形的种类与频率的测试………………………………20

2.1测试仪器及测试说明……………………………………21

2.2测试结果…………………………………………………23

3.设计体会………………………………………………………24

4参考文献………………………………………………………24

5.附录……………………………………………………………24

5.1附图5.2元器件清单………………………………25

1、系统设计

利用AT89C52单片机采用程序设计方法产生锯齿波、正弦波、矩形波三种波形,再通过D/A转换器DAC0832将数字信号转换成模拟信号,滤波放大,最终由示波器显示出来,通过按钮开关来控制三种波形的类型选择、频率变化,最终输出显示其各自的类型以及数值。

1.1、设计要求

1)利用单片机采用软件设计方法产生三种波形

2)三种波形可通过按钮来选择

3)波形频率可调

4)需显示波形的种类及其平率

1.2方案设计与论证

1.2.1信号发生电路方案论证

方案一:

采用单片函数发生器(如8038),8038可同时产生正弦波﹑方波﹑锯齿波等,而且方法简单易行,用D/A转换器的输出来改变调制电压,也可以实现数控调整频率,但产生信号的频率稳定度不高。

方案二:

采用锁相式频率合成器,利用锁相环,将压控振荡器的输出频率锁定在所需频率上,该方案性能良好,但难以达到输出频率覆盖系数的要求,且电路复杂。

方案三:

通过单片机控制D/A,输出三种波形。

此方案输出的波形不够稳定,抗干扰能力弱,不易调节。

但此方案电路简单、成本低。

以上三种方案综合考虑,选择方案三。

1.2.2单片机的选择论证

方案一:

AT89C52单片机是一种高性能8位单片微型计算机。

它把构成计算机的中央处理器CPU、存储器、寄存器、I/O接口制作在一块集成电路芯片中,从而构成较为完整的计算机、而且其价格便宜。

  方案二:

C8051F005单片机是完全集成的混合信号系统级芯片,具有与8051兼容的微控制器内核,与MCS-51指令集完全兼容。

除了具有标准8052的数字外设部件,片内还集成了数据采集和控制系统中常用的模拟部件和其他数字外设及功能部件,而且执行速度快。

但其价格较贵

 以上两种方案综合考虑,选择方案一

1.2.3显示方案论证

方案一:

采用LED数码管。

LED数码管由8个发光二极管组成,每只数码管轮流显示各自的字符。

由于人眼具有视觉暂留特性,当每只数码管显示的时间间隔小于1/16s时人眼感觉不到闪动,看到的是每只数码管常亮。

使用数码管显示编程较易,但要显示内容多,而且数码管不能显示字母。

 方案二:

采用LCD液晶显示器1602。

其功率小,效果明显,显示编程容易控制,可以显示字母。

    以上两种方案综合考虑,选择方案二。

1.3总体系统设计

该系统采用单片机作为数据处理及控制核心,由单片机完成人机界面、系统控制、信号的采集分析以及信号的处理和变换,采用按键输入,利用液晶显示电路输出数字显示的方案。

将设计任务分解为按键电路、液晶显示电路等模块。

(1)为系统的总体框图

显示

主控芯片

AT89C52

DAC0832

放大

←←→

输出

 

(1)总体方框图

1.4硬件实现及单元电路设计

1.4.1单片机最小系统的设计

89C52是片内有ROM/EPROM的单片机,因此,这种芯片构成的最小系统简单﹑可靠。

用80C52单片机构成最小应用系统时,只要将单片机接上时钟电路和复位电路即可,如图

(2)89C52单片机最小系统所示。

由于集成度的限制,最小应用系统只能用作一些小型的控制单元。

其应用特点:

(1)有可供用户使用的大量I/O口线。

(2)内部存储器容量有限。

(3)应用系统开发具有特殊性。

(2)89C51单片机最小系统

 1.4.2波形产生模块设计

由单片机采用编程方法产生三种波形、通过DA转换模块DAC0832在进过滤波放大之后输出。

其电路图如下:

图(3)波形产生电路

如上图所示,单片机的P0口连接DAC0832的八位数据输入端,DAC0832的输出端接放大器,经过放大后输出所要的波形。

1.4.3显示模块的设计

通过液晶1602显示输出的波形、频率,其电路图如下:

图(4)液晶显示

如上图所示,1602的八位数据端接单片机的P1口,其三个使能端RS、RW、E分别接单片机的P3.2—P3.4。

通过软件控制液晶屏可以显示波形的种类以及波形的频率。

1.5软件设计流程

本系统采用AT89C52单片机,用编程的方法来产生三种波形,并通过编程来切换三种波形以及波形频率的改变。

具体功能有:

(1)各个波形的切换;

(2)各种参数的设定;(3)频率增减等。

软件调通后,通过编程器下载到AT89C52芯片中,然后插到系统中即可独立完成所有的控制。

软件的流程图如下:

图(5)程序流程图

1.6源程序

#include

#defineucharunsignedchar

#defineuintunsignedint

sbitlcdrw=P3^3;

sbitlcdrs=P3^2;

sbitlcde=P3^4;

sbitd=P2^7;

sbits1=P2^0;

sbits2=P2^1;

sbits3=P2^2;

sbitcs=P3^5;

sbitwr=P3^6;

uchars1num,a,ys,j;

uintfre;

ucharcodetosin[256]={

0x80,0x83,0x86,0x89,0x8d,0x90,0x93,0x96,0x99,0x9c,0x9f,0xa2,

0xa5,0xa8,0xab,0xae,0xb1,0xb4,0xb7,0xba,0xbc,0xbf,0xc2,0xc5,

0xc7,0xca,0xcc,0xcf,0xd1,0xd4,0xd6,0xd8,0xda,0xdd,0xdf,0xe1,

0xe3,0xe5,0xe7,0xe9,0xea,0xec,0xee,0xef,0xf1,0xf2,0xf4,0xf5,

0xf6,0xf7,0xf8,0xf9,0xfa,0xfb,0xfc,0xfd,0xfd,0xfe,0xff,0xff,

0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xff,0xfe,0xfd,

0xfd,0xfc,0xfb,0xfa,0xf9,0xf8,0xf7,0xf6,0xf5,0xf4,0xf2,0xf1,

0xef,0xee,0xec,0xea,0xe9,0xe7,0xe5,0xe3,0xe1,0xde,0xdd,0xda,

0xd8,0xd6,0xd4,0xd1,0xcf,0xcc,0xca,0xc7,0xc5,0xc2,0xbf,0xbc,

0xba,0xb7,0xb4,0xb1,0xae,0xab,0xa8,0xa5,0xa2,0x9f,0x9c,0x99,

0x96,0x93,0x90,0x8d,0x89,0x86,0x83,0x80,0x80,0x7c,0x79,0x76,

0x72,0x6f,0x6c,0x69,0x66,0x63,0x60,0x5d,0x5a,0x57,0x55,0x51,

0x4e,0x4c,0x48,0x45,0x43,0x40,0x3d,0x3a,0x38,0x35,0x33,0x30,

0x2e,0x2b,0x29,0x27,0x25,0x22,0x20,0x1e,0x1c,0x1a,0x18,0x16,

0x15,0x13,0x11,0x10,0x0e,0x0d,0x0b,0x0a,0x09,0x08,0x07,0x06,

0x05,0x04,0x03,0x02,0x02,0x01,0x00,0x00,0x00,0x00,0x00,0x00,

0x00,0x00,0x00,0x00,0x00,0x00,0x01,0x02,0x02,0x03,0x04,0x05,

0x06,0x07,0x08,0x09,0x0a,0x0b,0x0d,0x0e,0x10,0x11,0x13,0x15,

0x16,0x18,0x1a,0x1c,0x1e,0x20,0x22,0x25,0x27,0x29,0x2b,0x2e,

0x30,0x33,0x35,0x38,0x3a,0x3d,0x40,0x43,0x45,0x48,0x4c,0x4e,

0x51,0x55,0x57,0x5a,0x5d,0x60,0x63,0x66,0x69,0x6c,0x6f,0x72,

0x76,0x79,0x7c,0x80};/*正弦波码*/

voiddelay(uintz)//延时子程序

{

uchari,j;

for(i=z;i>0;i--)

for(j=110;j>0;j--);

}

voiddelay1(uinty)

{

uinti;

for(i=y;i>0;i--);

}

voidwrite_com(ucharcom)//1602写指令

{

lcdrs=0;

P1=com;

delay(5);

lcde=1;

delay(5);

lcde=0;

}

voidwrite_data(uchardate)//1602数据

{

lcdrs=1;

P1=date;

delay(5);

lcde=1;

delay(5);

lcde=0;

}

voidinit()//初始化

{

lcdrw=0;

lcde=0;

wr=0;

cs=0;

write_com(0x38);

write_com(0x0c);

write_com(0x06);

write_com(0x01);

write_com(0x80+0x00);

write_data(0x77);//写wave:

write_data(0x61);

write_data(0x76);

write_data(0x65);

write_data(0x3a);

write_com(0x80+0x40);//写f:

write_data(0x66);

write_data(0x3a);

}

voidwrite_f(uintdate)//写频率

{

ucharqian,bai,shi,ge;

qian=date/1000;

bai=date/100%10;

shi=date/10%10;

ge=date%10;

write_com(0x80+0x42);

write_data(0x30+qian);

write_data(0x30+bai);

write_data(0x30+shi);

write_data(0x30+ge);

write_data(0x48);

write_data(0x5a);

}

voidxsf()//显示频率

{

if(s1num==1)

{

fre=(1000/(9+3*ys));

write_f(fre);

}

if(s1num==2)

{

fre=(100000/(3*ys));

write_f(fre);

}

if(s1num==3)

{

fre=(1000/(15+3*ys));

write_f(fre);

}

}

voidkeyscanf()

{

d=0;

if(s1==0)

{

delay(5);

if(s1==0)

{

while(!

s1);

s1num++;

if(s1num==1)

{

ys=0;

write_com(0x80+0x05);

write_data(0x73);//写sine:

write_data(0x69);

write_data(0x6e);

write_data(0x65);

write_data(0x20);

write_data(0x20);

}

if(s1num==2)

{

ys=10;

write_com(0x80+0x05);

write_data(0x73);//写squrae

write_data(0x71);

write_data(0x75);

write_data(0x61);

write_data(0x72);

write_data(0x65);

}

if(s1num==3)

{

ys=0;

write_com(0x80+0x05);//train

write_data(0x74);

write_data(0x72);

write_data(0x61);

write_data(0x69);

write_data(0x6e);

write_data(0x20);

}

if(s1num==4)

{

s1num=0;

P1=0;

write_com(0x80+0x05);

write_data(0x20);

write_data(0x20);

write_data(0x20);

write_data(0x20);

write_data(0x20);

write_data(0x20);

write_com(0x80+0x42);

write_data(0x20);

write_data(0x20);

write_data(0x20);

write_data(0x20);

write_data(0x20);

write_data(0x20);

}

}

}

if(s2==0)

{

delay(5);

if(s2==0)

{

while(!

s2);

ys++;

}

}

if(s3==0)

{

delay(5);

if(s3==0)

{

while(!

s3);

ys--;

}

}

}

voidmain()

{

init();

while

(1)

{

keyscanf();

if(s1num==1)//正弦波//

{

for(j=0;j<255;j++)

{

P0=tosin[j];

delay1(ys);

}

}

if(s1num==2)//方波//

{

P0=0xff;

delay1(ys);

P0=0;

delay1(ys);

}

if(s1num==3)//三角波//

{

if(a<128)

{

P0=a;

delay1(ys);

}

else

{

P0=255-a;

delay1(ys);

}

a++;

}

if(!

(s1&s2&s3))

{

xsf();

}

}

}

2、输出波形的种类与频率的测试

2.1测量仪器及测试说明

测量说明:

正弦波、矩形波、三角波信号的输出,通过对独立按钮来实现不同波形的输出以及其频率的改变。

2.2测试过程

当程序下进去时经过初始化,液晶屏的上只显示“wave:

”和“f:

“,当开关三按一下是此时输出波形为正弦波,按两下时输出为方波,按三下时输出为三角波。

另外两个开关可以调节频率,三种波形的频率可调范围不同,分别如下:

正弦波:

1—180HZ

方波:

1——3.3KHZ

三角波:

1——180HZ

三种波形的仿真波形图如下:

图(7)正弦波图形

图(8)方波图形

图(9)三角波图行

2.3、测试结果

  各项指标均达到要求。

测试数据如下:

1)产生正弦波、方波、三角波基本实现

2)三种波形的频率都可调,但不能步进的调节,其中方波的可调范围最广为1—3.3KHZ,其他两种波形的频率范围不大1—180HZ

3)显示部分基本实现

3、设计心的及体会

此次课程设计我感慨颇多,从选题到定稿,从理论到实践,在好几个星期的日子里,可以说是苦多于甜,但是可以学到很多的东西,,同时不仅可以巩固了以前所学的知识,而且学到了很多在书本上说没见到过的知识。

通过这次课程设计使我懂得了理论与实际相结合是很重要的,只有理论知识是远远不够的,只有把所学的理论知识与实践相结合起来,从理论中得出结论,才能真正为社会服务,从而提高自己的实际动手能力和独立思考的能力,在设计的过程中遇到问题,可以说的是困难重重,会遇到各种各样的问题,同时在设计的过程中发现了自己的不足之外,对以前所学的知识理解得不够深刻,掌握得不够牢固,比如说不懂一些元器件的使用方法,对单片机C语言掌握得不好…通过这次课程设计之后,一定把以前所学过得知识重新温故。

4参考文献

[1]戴仙金主编52单片机及其C语言汇编程序开发实例清华大学出版社,2008

[2]程全.基于AT89C52实现的多种波形发生器的设计【J】.周口师范学院学报,2005.22(5):

57~58.

[3]童5诗白.模拟电路技术基础【M】.北京:

高等教育出版社,2000.171~202

[4]蒋辉平主编单片机原理与应用设计北京航空航天大学出版社2007

5、附录

5.1附图

图(11)总体原理设计图

 

 

5.2元器件清单

元器件名称

数量

AT89C52

1

D/AC0832

1

TL084

2

30pf

3

7.5K

1

15k

1

10k

3

1.1k

1

10uf

1

12MHZ晶振

1

液晶显示1602

1

按钮开关

4

插针

若干

排阻

1

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

当前位置:首页 > PPT模板 > 商务科技

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

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