直流电机测速程序
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
#include
#define T0_H 0xc3
#define T0_L 0x50//定时50ms
#define uchar unsigned char
#define uint unsigned int
sbit P20=P2^0;
sbit P21=P2^1;
sbit P22=P2^2;
sbit P23=P2^3;
sbit P32=P3^2; //用到的子函数
void count();//转速计算
void display(); //数码管显示
void disp_init();//数码管初始化
uchar i,number;
uint n,len[4],sum=0;
char code table[]={0x3f,0x06,0x5b,0x4f,0x66,0x6d, 0x7d,0x07,0x7f,0x6f,0x77,0x7c, 0x39,0x5e,0x79,0x71,0x00};//译码表
void main()
{
disp_init();
while(1)
{
while(!P32)//查询方式
if(P32)
{
sum++;
while(P32);
}
}
}
?
void?count()?
{?
n=sum;//1s钟转的圈数?
len[0]=n/1000;?
len[1]=n%1000/100;?
len[2]=n%1000%100/10;?
len[3]=n%10;?
}
void display()
{ P0=number;
for(i=0;i<1000;i--);//短暂延时
}
voi disp_init()
{ for(i=0;i<1000;i--)
{ P20=0;
P21=1;
P22=1;
P23=1;
P0=Oxff;
P20=1;
P21=0;
P22=1;
P23=1;
P0=Oxff;
P20=1;
P21=1;
P22=0;
P23=1;
P0=Oxff;
P20=1;
P21=1;
P22=1;
P23=0;
P0=Oxff;
}
TMOD=0x11;
TCON=0x00;
TH0=TO_H;
TL0=T0_L;
IE=0x82;
TR0=1;
}
void disp_speed(void) interrupt 1
{ static uchar second_cnt=20;//20次*50ms=1s
TR0=0;//暂停计时,因为执行中断时主程序没执行
TH0=T0_H;
TL0=T0_L;
second_cnt--;
if(!second_cnt)
{
count();
P20=0;
P21=1;
P22=1;
P23=1;
P0=Oxff;
number=table[len[3]];
display();
P20=1;
P21=0;
P22=1;
P23=1;
P0=Oxff;
number=table[len[2]];
display();
P20=1;
P21=1;
P22=0;
P23=1;
P0=Oxff;
number=table[len[1]];
display();
P20=1;
P21=1;
P22=1;
P23=0;
P0=Oxff;
number=table[len[0]];
display();
second_cnt=20;
sum=0;
}
TR0=1;
}