- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
单片机计算器课程设计报告
基于单片机的简易计算器设计
基于单片机的简易计算器设计
一、设计任务和性能指标
1.1设计任务
利用单片机及外围接口电路(键盘接口和显示接口电路)设计制作一个计算器,用四位一体数码管显示计算数值及结果。要求用Protel 画出系统的电路原理图(要求以最少组件,实现系统设计所要求的功能),绘出程序流程图,并给出程序清单(要 求思路清晰,尽量简洁,主程序和子程序分开,使程序有较强的可读性)。
1.2性能指标
1加法:能够计算四位以内的数的加法。
2减法:能计算四位数以内的减法。
3乘法:能够计算两位数以内的乘法。
4除法:能够计算四位数的乘法
5有清零功能,能随时对运算结果和数字输入进行清零。
二、系统设计方案
按照系统设计的功能的要求,初步确定设计系统由单片机主控模块、四位一体数码管显示模块、键扫描接口电路共三个主要模块组成。主控芯片使用51系列AT89C51单片机,采用高性能的静态80C51设计,它由先进工艺制造,并带有非易失性Flash程序存储器。它是一种高性能、低功耗的8位COMS微处理芯片,市场应用最多。
键盘电路采用4*4矩阵键盘电路。
显示模块采用四位一体共阳极数码管和SN74LS244锁存芯片构成等器件构成。
三、硬件系统设计
1.单片机最小系统
单片机最小系统就是支持主芯片正常工作的最小电路部分,包括主控芯片、复位电路和晶振电路。
主控芯片选取STC89C51RC芯片,因其具有良好的性能及稳定性,价格便宜应用方便。
晶振选取11.0592MHz,晶振旁电容选取30pF。
采用按键复位电路,电阻分别选取100Ω和10K,电容选取10μF。
单片机最小系统硬件电路图如图(1)所示。
图(1) 单片机最小系统
2.键盘接口电路
计算器所需按键有:
数字键:’1’,’2’,’3’,’4’,’5’,’6’,’7’,’8’,’9’,’0’
功能键:’+’, ’-‘ , ’*’, ’/ ’ , ’ = ’, ’ C( 清零)’
共计16个按键,采用4*4矩阵键盘,键盘的行和列之间都有公共端相连,四行采用端口P0.0~P0.3,四列采用端口P3.0~P3.3,通过8个端口的的高低电平完成对矩阵键盘的控制。通过对16个按键进行编码,从而得到键盘的口地址,对比P1口德扫描结果和各按键的地址,我们就可以得到是哪个键按下,从而完成键盘的功能。
3.数码管显示电路
采用4位一体的数码管对计算数据和结果进行显示,这里选取共阳数码管,利用NPN三极管对数码管进行驱动,为了节省I/O资源,采取动态显示的方法来显示计算数据及结果。
利用SN74LS244N锁存器来实现数码管的动态显示,P1口输出显示值,P2.0~P2.3为位选端口。通过锁存器对段选信号的锁存,最终得到对数码管输入数据的控制。
以下为数码显示电路的硬件电路图,左图为数码管驱动电路,右图为段选信号锁存电路。
四.软件设计部分
根据选题要求,系统编程如下所示:
#include reg51.h
sbit P3_0=P3^0;
sbit P3_1=P3^1;
sbit P3_2=P3^2;
sbit P3_3=P3^3;
sbit P3_4=P3^4;
sbit P3_5=P3^5;
sbit P3_6=P3^6;
sbit P3_7=P3^7;
unsigned char sz[11],xs1[4],xs2[4],sj;
int i,cs,bb,t1,t2,fh,s1,s2;
void chushihua()
{
bb=1;
xs1[0]=10;xs1[1]=10;xs1[2]=10;xs1[3]=10;
xs2[0]=10;xs2[1]=10;xs2[2]=10;xs2[3]=10;
t1=0;t2=0;s1=s2=0;
fh=0;
cs=1;
}
void xianshi(unsigned char xs[4])
{
int i,j;
unsigned char zy;
zy=0x08;
for (i=0;i4;i++)
{
P2=(0xff-zy);
P1=sz[xs[i]];
zy=(zy1);
for (j=0;j100;j++) ;
}
// for (i=0;i100;i++);
return;
}
unsigned char saomiao()
{
int i,j;
unsigned char pp;
for (i=0;i1000;i++);
P0=0xfe;
P3=0x0f;
pp=P3;
if (P3_0==0) {P3=0x0f;pp=P3;while (P3_0==0);for (i=0;
文档评论(0)