电工电子实习创新设计.docx
- 文档编号:16657674
- 上传时间:2023-07-16
- 格式:DOCX
- 页数:20
- 大小:150.73KB
电工电子实习创新设计.docx
《电工电子实习创新设计.docx》由会员分享,可在线阅读,更多相关《电工电子实习创新设计.docx(20页珍藏版)》请在冰点文库上搜索。
电工电子实习创新设计
项目名称
基于51单片机的自行车测速器
项目简介
本项目以51单片机为基础,通过光电传感器进行采样,将信号引入单片机外部中断口,51单片机经过每秒钟中断次数计算自行车的速度,我们用LCD1602液晶屏显示时间,行驶速度,行驶距离。
本项目设计简单,方便用户使用。
设计方案
硬件设计
我们以51单片机系统为基础,在P3.0,P3.1,P3.3三个口接三个按键,用来设定时间,分别是调时间移位键,+键,-键。
P3.2口是外部中断口,用来接光电测速传感器。
软件设计
按键调时程序
voidkeyscan()
{
rd=0;
if(s1==0)
{
delay(5);
if(s1==0)
{s1num++;
while(!
s1);
if(s1num==1)
{
TR0=0;
write_com(0x80+0x40+7);
write_com(0x0f);
}
}
if(s1num==2)
{
write_com(0x80+0x40+4);
}
if(s1num==3)
{
write_com(0x80+0x40+1);
}
if(s1num==4)
{
s1num=0;
write_com(0x0c);
TR0=1;
}
}
if(s1num!
=0)
{
if(s2==0)
{
delay(5);
if(s2==0)
{
while(!
s2);
if(s1num==1)
{
miao++;
if(miao==60)
miao=0;
write_sfm(7,miao);
write_com(0x80+0x40+7);
}
if(s1num==2)
{
fen++;
if(fen==60)
fen=0;
write_sfm(4,fen);
write_com(0x80+0x40+4);
}
if(s1num==3)
{
shi++;
if(shi==24)
shi=0;
write_sfm(1,shi);
write_com(0x80+0x40+1);
}
}
}
if(s3==0)
{
delay(5);
if(s3==0)
{
while(!
s3);
if(s1num==1)
{
miao--;
if(miao==-1)
miao=59;
write_sfm(7,miao);
write_com(0x80+0x40+7);
}
if(s1num==2)
{
fen--;
if(fen==-1)
fen=59;
write_sfm(4,fen);
write_com(0x80+0x40+4);
}
if(s1num==3)
{
shi--;
if(shi==-1)
shi=23;
write_sfm(1,shi);
write_com(0x80+0x40+1);
}
}
}
}
}
定时中断程序
voidtimer0()interrupt1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
count++;
if(count>18)
{
count=0;
miao++;
vone=vtwo;
vthr=vone;
vtwo=vthr;
vone=distance;
v=(150*(vone-vtwo));
if(miao>60)
{
miao=0;
fen++;
if(fen>60)
{
fen=0;
shi++;
if(shi>24)
{
shi=0;
}
}
}
}
}
外部中断程序
voidinterrupt_lcd()interrupt0
{
times++;
}
主程序
voidmain()
{
init();
while
(1)
{
distance=(50*times);
write_dis(distance);
if(distance==1000)
{distance=0;
kilo++;
}
write_space(v);
write_kilo(kilo);
write_sfm(1,shi);
write_sfm(4,fen);
write_sfm(7,miao);
keyscan();
}
}
电路图
创新点与实用性
应用单片机进行自行车的测速,简单方便,设计精妙。
可以用在平时的自行车上,在测速,测距离上很方便。
学习收获
最大的收获是程序编程方面,因为中断服务程序太长,导致响应中断的时候时间暂停时间过长,影响了时间,给我们造成了很大的困扰,最后我们把除了计数的程序放入主程序,往LCD中写数据也放入主程序后很好的调节了这个问题
附录
#include
#defineucharunsignedchar
#defineuintunsignedint
sbitdula=P2^6;
sbitwela=P2^7;
sbitrs=P1^0;
sbitrw=P1^1;
sbitlcden=P2^5;
sbits1=P3^0;
sbits2=P3^1;
sbits3=P3^2;
sbitrd=P3^7;
ucharcount,s1num,t0=0,kilo=0,ts=0,cnt=0;
charmiao,shi,fen;
ucharv=0;
uintspace=0,distance=0,times=0;
uintvone=0,vtwo=0,vthr=0;
ucharcodetable[]="v:
00m/ss:
0000m";
ucharcodetable1[]="00:
00:
00000km";
voiddelay(uintz)
{
uintx,y;
for(x=z;x>0;x--)
for(y=110;y>0;y--);
}
voidwrite_com(ucharcom)
{
rs=0;
lcden=0;
P0=com;
delay(5);
lcden=1;
delay(5);
lcden=0;
}
voidwrite_date(uchardate)
{
rs=1;
lcden=0;
P0=date;
delay(5);
lcden=1;
delay(5);
lcden=0;
}
voidinit()
{
ucharnum;
dula=0;
wela=0;
lcden=0;
rw=0;
write_com(0x38);
write_com(0x0c);
write_com(0x06);
write_com(0x01);
write_com(0x80);
for(num=0;num<15;num++)
{
write_date(table[num]);
delay(5);
}
write_com(0x80+0x40);
for(num=0;num<15;num++)
{
write_date(table1[num]);
delay(5);
}
TMOD=0x01;
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
EA=1;
EX0=1;
IT0=1;
ET0=1;
TR0=1;
}
voidwrite_sfm(ucharadd,uchardate)
{
ucharshi,ge;
shi=date/10;
ge=date%10;
write_com(0x80+0x40+add);
write_date(0x30+shi);
write_date(0x30+ge);
}
/*****************************************************///显示米
voidwrite_dis(uintdistance)
{
uintqian=0,bai=0,shi=0,ge=0;
qian=distance/1000;
if(qian>1)
qian=0;
bai=distance%1000/100;
if(bai>9)
bai=0;
shi=distance%100/10;
if(shi>9)
shi=0;
ge=distance%10;
if(ge>9)
ge=0;
write_com(0x80+0x0a);
write_date(0x30+qian);
write_date(0x30+bai);
write_date(0x30+shi);
write_date(0x30+ge);
}
/*****************************************************///显示千米
voidwrite_kilo(ucharkilo)
{
ucharbaik=0,shik=0,gek=0;
baik=kilo/100;
if(baik>1)
baik=0;
shik=kilo%100/10;
if(shik>9)
shik=0;
gek=kilo%10;
if(gek>9)
gek=0;
write_com(0x80+0x40+0x0a);
write_date(0x30+baik);
write_date(0x30+shik);
write_date(0x30+gek);
}
/************************************************************///显示速度
voidwrite_space(ucharspace)
{
ucharshis=0,ges=0;
shis=space/10;
if(shis>9)
shis=0;
ges=space%10;
if(ges>9)
ges=0;
write_com(0x80+0x02);
write_date(0x30+shis);
write_date(0x30+ges);
}
voidkeyscan()
{
rd=0;
if(s1==0)
{
delay(5);
if(s1==0)
{s1num++;
while(!
s1);
if(s1num==1)
{
TR0=0;
write_com(0x80+0x40+7);
write_com(0x0f);
}
}
if(s1num==2)
{
write_com(0x80+0x40+4);
}
if(s1num==3)
{
write_com(0x80+0x40+1);
}
if(s1num==4)
{
s1num=0;
write_com(0x0c);
TR0=1;
}
}
if(s1num!
=0)
{
if(s2==0)
{
delay(5);
if(s2==0)
{
while(!
s2);
if(s1num==1)
{
miao++;
if(miao==60)
miao=0;
write_sfm(7,miao);
write_com(0x80+0x40+7);
}
if(s1num==2)
{
fen++;
if(fen==60)
fen=0;
write_sfm(4,fen);
write_com(0x80+0x40+4);
}
if(s1num==3)
{
shi++;
if(shi==24)
shi=0;
write_sfm(1,shi);
write_com(0x80+0x40+1);
}
}
}
if(s3==0)
{
delay(5);
if(s3==0)
{
while(!
s3);
if(s1num==1)
{
miao--;
if(miao==-1)
miao=59;
write_sfm(7,miao);
write_com(0x80+0x40+7);
}
if(s1num==2)
{
fen--;
if(fen==-1)
fen=59;
write_sfm(4,fen);
write_com(0x80+0x40+4);
}
if(s1num==3)
{
shi--;
if(shi==-1)
shi=23;
write_sfm(1,shi);
write_com(0x80+0x40+1);
}
}
}
}
}
voidmain()
{
init();
while
(1)
{
distance=(50*times);
write_dis(distance);
if(distance==1000)
{distance=0;
kilo++;
}
write_space(v);
write_kilo(kilo);
write_sfm(1,shi);
write_sfm(4,fen);
write_sfm(7,miao);
keyscan();
}
}
voidtimer0()interrupt1
{
TH0=(65536-50000)/256;
TL0=(65536-50000)%256;
count++;
if(count>18)
{
count=0;
miao++;
vone=vtwo;
vthr=vone;
vtwo=vthr;
vone=distance;
v=(150*(vone-vtwo));
if(miao>60)
{
miao=0;
fen++;
if(fen>60)
{
fen=0;
shi++;
if(shi>24)
{
shi=0;
}
}
}
}
}
voidinterrupt_lcd()interrupt0
{
times++;
}
- 配套讲稿:
如PPT文件的首页显示word图标,表示该PPT已包含配套word讲稿。双击word图标可打开word文档。
- 特殊限制:
部分文档作品中含有的国旗、国徽等图片,仅作为作品整体效果示例展示,禁止商用。设计者仅对作品中独创性部分享有著作权。
- 关 键 词:
- 电工 电子 实习 创新 设计