![循迹小车的程序_第1页](http://file4.renrendoc.com/view/e99e4026dabbe7143562b6b2fbb67240/e99e4026dabbe7143562b6b2fbb672401.gif)
![循迹小车的程序_第2页](http://file4.renrendoc.com/view/e99e4026dabbe7143562b6b2fbb67240/e99e4026dabbe7143562b6b2fbb672402.gif)
![循迹小车的程序_第3页](http://file4.renrendoc.com/view/e99e4026dabbe7143562b6b2fbb67240/e99e4026dabbe7143562b6b2fbb672403.gif)
![循迹小车的程序_第4页](http://file4.renrendoc.com/view/e99e4026dabbe7143562b6b2fbb67240/e99e4026dabbe7143562b6b2fbb672404.gif)
下载本文档
版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领
文档简介
循迹小车程序#include<reg52.h>
//*********************第一部分Start***************************************
sbitIN1=P1^0;//以下是点击驱动芯片L298管脚位声明
sbitPWM1=P1^1;
sbitIN2=P1^2;
sbitIN3=P1^3;
sbitPWM2=P1^4;
sbitIN4=P1^5;
sbitRPR1=P1^6;//此处是传感器RPR220管脚位声明
sbitRPR2=P1^7;
intcount1=0;//用于定时计数的两个全局变量位声明
intcount2=0;
//*********************第一部分End***************************************
//*********************第二部分子函数定义Start****************************
voidforward_turn1()//电机1前进
{
IN1=0;
IN2=1;
}
voidreverse_return1()//电机1后退
{
IN1=1;
IN2=0;
}
voidforward_turn2()//电机2前进{
IN3=0;
IN4=1;
}
voidreverse_return2()//电机2后退
{
IN1=1;
IN2=0;
}
voidspeed1(intct,intsd)//电机1速度控制函数,其中参数sd为生成PWM波形的比较基准
{
if(ct<=sd)
PWM1=1;
else
PWM1=0;
}
voidspeed2(intct,intsd)//电机2速度控制函数,其中参数sd为生成PWM波形的比较基准
{
if(ct<=sd)
PWM2=1;
else
PWM2=0;
}
//*********************第二部分子函数定义End*********************
//**********第三部分小车直线前进,左转,右转函数定义Start********
voidadvance(intct1,intsd1,intct2,intsd2)//小车直线前进函数
{
forward_turn1();
forward_turn2();
speed1(ct1,sd1);
speed2(ct2,sd2);
}
//*************以下是方案1,通过使两轮一快一慢来实现转向******************************
voidleft_turn1(intct1,intsd1,intct2,intsd2)//小车左转
{
forward_turn1();
forward_turn2();
speed1(ct1,sd1);
speed2(ct2,sd2);
}
voidright_turn1(intct1,intsd1,intct2,intsd2)//小车右转
{
forward_turn1();
forward_turn2();
speed1(ct1,sd1);
speed2(ct2,sd2);
}
//*************以下是方案2,通过使两轮一正传,一反转来实现转向************************
voidleft_turn2(intct1,intsd1,intct2,intsd2)//小车左转
{
forward_turn1();
reverse_return2();speed1(ct1,sd1);
speed2(ct2,sd2);
}
voidright_turn2(intct1,intsd1,intct2,intsd2)//小车右转
{
forward_turn2();
reverse_return1();
speed1(ct1,sd1);
speed2(ct2,sd2);
}
//**********第三部分小车直线前进,左转,右转函数定义End********
//**********第4部分主函数Start********************************
main()
{
TMOD=0x11;//中断模式设置
TH0=(65536-1000)/256;//定时器1初始化
TL0=(65536-1000)%256;
EA=1;
ET0=1;
TR0=1;
TH1=(65536-1000)/256;//定时器2初始化
TL1=(65536-1000)%256;
EA=1;
ET1=1;
TR1=1;
while(1){
if(RPR1==0&&RPR2==0)//未检测到黑线,小车继续前进
{
advance(count1,500,count2,500);
}
if(RPR1==1&&RPR2==0)//仅左轮检测到黑线,小车向左转弯
{
left_turn1(count1,200,count2,500);
}
if(RPR1==0&&RPR2==1)//仅右轮检测到黑线,小车向右转弯
{
right_turn1(count1,500,count2,200);
}
if(RPR1==1&&RPR2==1)/*左右轮均检测黑线,小车继续前进*/
/*(此处用来处理"8"字型路线交叉处小车如何前进的问题)*/
{
advance(count1,500,count2,500);
}
}
}
//**********第4部分主函数End********************************
//**********第五部分中断服务程序Start********************************
voidtime0()interrupt1
{
TH0=(65536-1000)/256;//定时1ms
TL0=(65536-1000)%256;
count1++;
if(count1>=1000)//周期是1s
count1=0;
}voidtime1()interrupt3
{
TH0=(65536-1000)/
温馨提示
- 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
- 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
- 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
- 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
- 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
- 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
- 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。
最新文档
- 二零二五年度创新办公园区草坪设计与生态友好合同
- 三农村土地综合整治指南
- 家具购销合同协议书
- 知识产权与法务管理作业指导书
- 仪器仪表与自动化设备行业作业指导书
- 游戏策划设计作业指导书
- 医美股份转让协议合同
- 藕塘承包合同样本
- 地质勘察合同付款条件
- 2025年雅安货车丛业资格证考试题
- 2025江苏太仓水务集团招聘18人高频重点提升(共500题)附带答案详解
- 2025年八省联考陕西高考生物试卷真题答案详解(精校打印)
- 2025脱贫攻坚工作计划
- 借款人解除合同通知书(2024年版)
- 《血小板及其功能》课件
- 江苏省泰州市靖江市2024届九年级下学期中考一模数学试卷(含答案)
- 沐足店长合同范例
- 《旅游资料翻译》课件
- 《既有轨道交通盾构隧道结构安全保护技术规程》
- 初中物理22-23人大附中初三物理寒假作业及答案
- 科学计算语言Julia及MWORKS实践 课件 6- Julia REPL的几种模式
评论
0/150
提交评论