1、浙江海洋学院设计题目 用8051+1601LCD设计的整型计算器 摘 要当今时代,是一个新技术层出不穷的年代。单片机具有体积小、质量轻、价格便宜、为学习、应用和开发提供了便利条件。单片机由运算器、控制器、存储器、输入输出设备构成,相当于一个微型的计算机(最小系统),和计算机相比,单片机缺少了外围设备等。概括的讲:一块芯片就成了一台计算机。单片微型计算机简称单片机,是典型的嵌入式微控制器,常用英文字母的缩写MCU表示单片机,单片机又称单片微控制器,它不是完成某一个逻辑功能的芯片,而是把一个计算机系统集成到一个芯片上。它所给人带来的方便不可否认,本设计是由单片机实现的模拟计算器它不仅能实现数据的加
2、减乘除运算而且还能使数据及其计算结果在LCD管上显示出来能够实现0-256的数字四则运算。本设计是用单片机AT89C52来控制采用共阳极数码显示软件部分是由C语言来编写的。为了满足计算器的基本要求,可以基本的运算(加减乘除),数据归零和出错警告提示,我们采用基于单片机设计计算器,并用LCD 液晶显示数据,4*4 的矩阵键盘实现数据输入,程序语言我们使用c语言。设计任务:利用键盘和数码管设计一个简单的数学计算器可以完成简单的如加减乘除的四则运算并将运算结果在数码管上显示出来。关键词:加减乘除运算;单片机AT89C52;LCD 液晶显示;4*4 的矩阵键盘实现数据输入目 录1.引言.52.方案论证
3、与设计.52.1 要求与内容.52.2 设计方案.53.硬件设计.63.1 单片机最小系统.63.2 LCD显示模块.73.3 输入模块.84. 软件设计.94.1 输入程序流程图设计.95. 实验结果与讨论.115.1 仿真实验.115.2 结果讨论.146.心得体会.147.附 录A; 源程序.148.参考文献.19用8051+1601LCD设计的整型计算器1. 引 言不同于通用计算机应用程序设计,单片机C语言程序设计必须针对具体的微控制器及外围电路来进行。现代的电子计算器能进行数学运算的手持电子机器,拥有集成电路芯片,但结构简单,比电脑结构简单得多,可以说是第一代的电子计算机(电脑),且
4、功能也较弱,但较为方便与廉价,可广泛运用于商业交易中,是必备的办公用品之一。随着社会需求,计算器也从原有的单一的数字加减计算演变为复杂的多种运算。计算器为人们的日常生活省去了大量的时间和精力,成为现代社会最普遍的计算工具。老师交给我们这个课题,我觉得非常有实践价值。作为学习电气专业的大学生,就应该更贴近生活,做一些有学习价值的小东西。这么做可以通过自己的实践,更好的把实践和理论相结合,全方面提高自己的专业文化水平。本课程设计主要在运算过程中,如果通过计算器来完成,就会减少计算量,该程序可以在简单计算器键面下进行简单运算。2. 方案设计2.1. 设计要求用单片机AT89C51来控制采用共阳极数码
5、显示软件部分是由C语言来编写的。为了满足计算器的基本要求,可以基本的运算(加减乘除),数据归零和出错警告提示,我们采用基于单片机设计计算器,并用LCD 液晶显示数据,4*4 的矩阵键盘实现数据输入,程序语言我们使用c语言。2.2. 设计方案2.1.1 单片机芯片的选择根据功能和指标要求,本系统选用MCS-51系列单片机AT89C51为主控机。通过扩展必要的外围接 口电路,实现对计算器的设计。计算器电路包括三个部分:显示电路、4*4键扫描电路、单片机微控制电路。用七段数码管作为显示电路,矩阵键盘作为输入电路。模块图如下1.1。图1.13. 硬件设计3.1. 单片机最小系统单片机最小系统选用AT8
6、9C52 提供以下标准功能:8字节FLASH闪速存储器,256字竹内部RAM , 32个I/O口线,3个16 位定时计数器,一个6向量两级中断结构,一个全双工串行通信口,片内振荡器及时钟电路。同时,AT89c52可降至OHz的静态逻辑操作,并支持两种软件可选的节电上作模式。空闲方式停止CPU 的工作,但允许RAM,定时计数器串行通信口及中断系统继续工作。掉电方式保存RAM 中的内容,但振荡器停止工作并禁止其它所有部件工作直到下一个硬件复位.如图3.1图3.13.2.LCD显示模块1601采用标准的14脚接口,其管脚功能介绍如下: 1:VSS为电源地 2:VDD接5V电源正极 3:VEE为液晶显
7、示器对比度调整端,接正电源时对比度最弱,接地电源时对比度最高。 4:RS为寄存器选择,高电平1时选择数据寄存器、低电平0时选择指令寄存器。 5:RW为读写信号线,高电平(1)时进行读操作,低电平(0)时进行写操作。 6:E(或EN)端为使能(enable)端。714:D0D7为8位双向数据。具体看图3.2 图3.2 3.3. 输入模块计算器输入数字和其他功能按键要用到很多按键,如果采用独立按键的方式,在这种情况下,编程会很简单,但是会占用大量的I/O 口资源,因此在很多情况下都不采用这种方式。为此,引入了矩阵键盘的应用,采用四条I/O 线作为行线,四条I/O 线作为列线组成键盘。在行线和列线的
8、每个交叉点上设置一个按键。这样键盘上按键的个数就为44个。这种行列式键盘结构能有效地提高单片机系统中I/O 口的利用率图3.34. 软件设计4.1输入程序流程图设计该计算器系统的软件设计分为以下几个模块:(1)主程序模块,(2) 读键输入程序流程图,(3)显示程序 (4)计算程序。(1)运算主程序设计 首先初始化参数,送LED低位显示“0”,高位不显示。然后扫描键盘看是否有键输入,若有,读取键码。判断键码是数字键、清零键还是功能键(“+”“-”“*”“/”“=” ),是数值键则送LED显示并保存数值,是清零键则做清零处理,是功能键则又判断是“=”还是运算键,若是“=”则计算最后结果并送LED显
9、示,若是运算键则保存相对运算程序的首地址。运算主程序框图如图4.1(具体程序看附件:源程序)图4.1(2)读键输入程序流程图 为了实现键盘的数据输入功能和命令处理功能,每个键都有其处理子程序,为此每个键都对应一个码键码。为了得到被按键的键码,现使用行扫描法识别按键。列扫描信号进行读入行的信号判断该列是否有列的输出是则进行按照行列计算键盘的值,查表取得键码并返回若否则进行再次扫描。其程序框图4.2如下:图4.2(3)显示程序本电路采用的是 LCD 液晶显示输出数据,在流程图中应包括对LCD液晶显示器初始化,取要显示的数据,要是有两位数据需要显示,则在显示完第一位数据后需要进行延迟来显示第二位数据
10、,则根据以上要求,显示模块的流程图如图4.3(具体程序看附件:源程序)图4.3总程序框图如图4.4图4.45. 实验结果与讨论5.1. 实验仿真依据各功能模块的功能要求和工作过程画出程序的流程图,然后根据流程图和系统的硬件连接写出详细的程序,接着对各个子程序进行编译,调试,运行,看看是否能达到其功能,然后再将整个程序糅合在一起进行整体软件调试。在整体调试中,需注意寄存器组不能重复,在进入中断时,哪些寄存器内容和参数需入栈保护,以及调用子程序时各参数必须统一,在编译通过时,最好能把整个程序再单步执行一遍。单步执行时看看每步执行完后数据各个特殊功能寄存器中数据的变化,这样才能确保整个程序按照系统的工作过程和功能要求执行。仿真结果如图5.1所示。图5.1图5.2为1+1=2的调试结果;图5.3为21=1的调试结果;图5.4为2*2=4的调试结果;图5.5为6/2=3的调试结果。图5.2图5.3图5.4图5.55.2. 结果讨论本设计以AT89C52单片机为系统的控制核心,采用proteus仿真软件进行测试。Proteus是一款比较常用的单片机仿真
copyright@ 2008-2022 冰豆网网站版权所有
经营许可证编号:鄂ICP备2022015515号-1