- 1、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。。
- 2、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 3、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
- 4、该文档为VIP文档,如果想要下载,成为VIP会员后,下载免费。
- 5、成为VIP后,下载本文档将扣除1次下载权益。下载后,不支持退款、换文档。如有疑问请联系我们。
- 6、成为VIP后,您将拥有八大权益,权益包括:VIP文档下载权益、阅读免打扰、文档格式转换、高级专利检索、专属身份标志、高级客服、多端互通、版权登记。
- 7、VIP文档为合作方或网友上传,每下载1次, 网站将根据用户上传文档的质量评分、类型等,对文档贡献者给予高额补贴、流量扶持。如果你也想贡献VIP文档。上传文档
查看更多
实用标准文案
精彩文档
//T0产生双路PWM信号,L298N为直流电机调速,接L298N时相应的管脚上最好接上10K的上拉电阻。
/* 晶振采用12M,产生的PWM的频率约为100Hz */
#includereg51.h
#includemath.h
#define uchar unsigned char
#define uint unsigned int
sbit en1=P3^4; /* L298的Enable A */
sbit en2=P3^5; /* L298的Enable B */
sbit s1=P1^0; /* L298的Input 1 */
sbit s2=P1^1; /* L298的Input 2 */
sbit s3=P1^3; /* L298的Input 3 */
sbit s4=P1^2; /* L298的Input 4 */
sbit R=P2^0;
sbit C=P2^1;
sbit L=P2^2;
sbit key=P1^4;
uchar t=0; /* 中断计数器 */
uchar m1=0; /* 电机1速度值 */
uchar m2=0; /* 电机2速度值 */
uchar tmp1,tmp2; /* 电机当前速度值 */
/* 电机控制函数 index-电机号(1,2); speed-电机速度(0-100) */
void motor(uchar index, char speed)
{
if(speed=100)
{
if(index==1) /* 电机1的处理 */
{
m1=abs(speed); /* 取速度的绝对值 */
s1=1;
s2=0;
}
if(index==2) /* 电机2的处理 */
{
m2=abs(speed); /* 电机2的速度控制 */
s3=1;
s4=0;
}
}
}
void Back(void)
{
s1=0;
s2=1;
s3=1;
s4=0;
}
void GO(void)
{
s1=1;
s2=0;
s3=1;
s4=0;
}
void TL(void)
{
s1=1;
s2=0;
s3=0;
s4=1;
}
void TR(void)
{
s1=0;
s2=1;
s3=1;
s4=0;
}
void STOP(void)
{
s1=1;
s2=1;
s3=1;
s4=1;
}
/*
void delay(uint j) /* 简易延时函数 */
{
for(j;j0;j--);
} */
void delay(uint z)
{
uint x,y;
for(x=z;x0;x--)
for(y=110;y0;y--);
}
void main()
{
uchar i=0,j=0;
TMOD=0x02; /* 设定T0的工作模式为2 ,8位自动重置定时器,每过几个机器周期,计数器加一*/
TH0=0x9B; /* 装入定时器的初值,计数100次溢出 */
TL0=0x9B; /*装入时间常数*/
EA=1; /* 开中断 */
ET0=1; /* 定时器0允许中断 */
TR0=1; /* 启动定时器0 */
while(1)
{
if(key==1)
{
/* 电机实际控制演示 */
if(i=100) // 正转加速
{
motor(1,i);
motor(2,i);
delay(5000);
i++;
}
else
{
GO();
}
}
else
{
EA=0;
while(1)
{
if((L|C|R)==0)
STOP();
if(LR)
GO();
if(L==0)
{
while(C)
{
TL();
}
}
if(R==0)
{
while(C)
{
TR();
}
}
}
}
}
}
void timer0() interrupt 1 /* T0中断服务程序 */
{
if(t==0) /* 1个PWM周期完成后才会接受新数值 */
{ tmp1=m1;
tmp2=m2;
}
if(ttmp1) en1=1; else en1=0; /* 产生电机1的PWM信号 */
if(ttmp2) en2=1; else en
您可能关注的文档
- 偏瘫患者地输液管理系统.doc
- 企业的阿米巴整体实施方案设计设计陈一拙.doc
- 企业的安全系统管理系统论文完整版.doc
- 企业的安全系统文化建设评价与衡量与衡量准则AQT9005-2008.doc
- 企业的安全系统文化手册簿簿.doc
- 企业的财务管理系统常见问的题目及改进建议.doc
- 企业的财务内控规章规章制度全案修改.doc
- 企业的法律体检调研问卷.doc
- 企业的高高质量安全系统管理系统规章规章制度参考.doc
- 企业的高高质量安全系统管理系统规章规章制度例例范本.doc
- 2025年智能电网柔性直流输电技术在我国西部地区应用前景.docx
- 7.2 弹力-人教版八年级物理下册.pptx
- 2025年智能电网柔性直流输电技术在智能变电站中的应用研究.docx
- 2025年智能电网柔性直流输电技术在智能电网智能化存储中的应用.docx
- 2025年智能电网柔性直流输电技术在新能源并网中的应用研究.docx
- 2025年智能电网柔性直流输电技术在智能电网智能化控制中的应用.docx
- 2025年智能电网柔性直流输电技术在智能电网智能化预测中的应用.docx
- 2025年智能电网柔性直流输电技术在智能电网智能化服务中的应用.docx
- 2025年智能电网柔性直流输电技术在智能电网智能化运维中的应用.docx
- 2025年智能电网柔性直流输电技术智能化保护系统研究.docx
原创力文档


文档评论(0)