智能小车仿真程序4页_第1页
智能小车仿真程序4页_第2页
智能小车仿真程序4页_第3页
智能小车仿真程序4页_第4页
全文预览已结束

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、#include<reg52.h>#define uchar unsigned char#define uint unsigned int / * * * * * * * * * * * * * * * * * * * * * 第 一 部 分 S t a r t * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * * *sbit IN1=P10; / 以 下 是 电 机 驱 动 芯 片 L 2 9 8 管 脚 位 声 明 sbit PWM1=P11; sbit IN2=P12; sbit IN3=P13; sbit

2、 PWM2=P14; sbit IN4=P15; sbit RPR3=P16; / 此 处 是 传 感 器 R P R 2 2 0 管 脚 位 声 明 sbit RPR4=P17;sbit RPR1=P20;sbit RPR2=P21;sbit bz1=P00;/避障1sbit bz2=P01; /避障2sbit A=P32; /默认为遥控避障工作模式,按下A键后小车变换为循迹避障模式sbit B=P03;/ 按下B键不放,小车前进sbit C=P04;/ 按下C键不放,小车左转弯sbit D=P05;/ 按下D键不放,小车右转弯sbit led=P07;int n=1;/ * * * * *

3、 * * * * * * * * * * * * * * * * 第 一 部 分 E n d * * * * * * * * * * * * * * * * * * * * * * * * * */ * * * * * * * * * * * * * * * * * * * * * 第 二 部 分 子 函 数 定 义 S t a r t * * * * * * * * * * * */*延时函数 */ void timer(unsigned int t) /中断计时 unsigned int i; for(i=0;i<t;i+) /*延时t*50ms*/ TMOD=0X10; TH0=0

4、x3C; TL0=0xB0; TR1=1; while(!TF1); TR1=0; int0()interrupt 0 n=n+1; /默认遥控功能 if(n%2=0) led=0; else led=1; EA=1; EX0=1; IT0=1;main() EA=1; EX0=1; IT0=1; while(1) while(n%2=1) if(A=1) break; if(A=0&&B=1&&bz1=1) IN1=0,IN2=1,IN3=0,IN4=1; PWM1=1; PWM2=1; timer(100); /5S PWM1=0; PWM2=0; time

5、r(100); /5S if(A=0&&C=1&&bz1=1) IN1=0,IN2=1,IN3=0,IN4=1; PWM1=0; PWM2=1; timer(50); PWM1=0; PWM2=1; timer(50); PWM1=0; PWM2=0; timer(10); if(A=0&&D=1&&bz1=1) IN1=0,IN2=1,IN3=0,IN4=1; PWM1=1; PWM2=0; timer(50); PWM1=1; PWM2=0; timer(50); PWM1=0; PWM2=0; timer(10); if(A

6、=0&&bz1=0)unsigned int k=0; IN1=0,IN2=1,IN3=1,IN4=0;for(k=0;k<=30;k+) PWM1=1; PWM2=1; timer(25); PWM1=0; PWM2=0; timer(25); while(n%2=0) if(A=1) break; if(A=0&&bz1=1&&(RPR4=0&&RPR3=0&&RPR1=0&&RPR2=0) |(RPR1=0&&RPR2=1&&RPR3=1&&

7、;RPR4=0)/ 未 检 测 到 黑 线 , 小 车 继 续 前 进 IN1=0,IN2=1,IN3=0,IN4=1; PWM1=1; PWM2=1; timer(100); PWM1=0; PWM2=0; timer(400); if(A=0&&bz1=1&&RPR1=0&&RPR2=1&&RPR3=0&&RPR4=0) / 仅 左 轮 检 测 到 黑 线 , 小 车 向 左 转 弯 IN1=0,IN2=1,IN3=0,IN4=1; PWM1=1; PWM2=1; timer(50); PWM1=0; PWM2

8、=1; timer(50); PWM1=0; PWM2=0; timer(400); if(A=0&&bz1=1&&RPR1=0&&RPR2=0&&RPR3=1&&RPR4=0) / 仅 右 轮 检 测 到 黑 线 , 小 车 向 右 转 弯 未检测到障碍物 IN1=0,IN2=1,IN3=0,IN4=1; PWM1=1; PWM2=1; timer(50); PWM1=1; PWM2=0; timer(50); PWM1=0; PWM2=0; timer(400); if(A=0&&bz1=1&a

9、mp;&RPR4=1&&RPR3=0&&RPR1=0&&RPR2=0) / 右轮最外围检测到黑线 向右大转弯 未检测到障碍物 IN1=0,IN2=1,IN3=0,IN4=1; PWM1=1; PWM2=1; timer(50); PWM1=1; PWM2=0; timer(100); PWM1=0; PWM2=0; timer(50); if(A=0&&bz1=1&&RPR4=0&&RPR3=0&&RPR1=1&&RPR2=0) /左轮最外围检测到黑线 左轮大

10、转弯 未检测到障碍物 IN1=0,IN2=1,IN3=0,IN4=1; PWM1=1; PWM2=1; timer(50); PWM1=0; PWM2=1; timer(100); PWM1=0; PWM2=0; timer(400); if(A=0&&bz1=1&&RPR4=0&&RPR3=0&&RPR1=1&&RPR2=1) / 左转 90°弯 未检测到障碍物 IN1=1,IN2=0,IN3=0,IN4=1; while(RPR3=1) PWM1=1; PWM2=1; timer(250); PWM1=0; PWM2=0; timer(250); if(A=0&&bz1=1&&RPR4=1&&RPR3=1&&RPR1=0&&RPR2=0)/ 右转90°弯 IN1=0,IN2=1,IN3=1,IN4=0; while(RPR4=1) PWM1=1; PWM2=1; timer(250); PWM1=0; PWM2=0; timer(250); if(A=0&&bz1=0) unsigned int k=0; for(k=0;k<=30;k+) IN1=0,IN2=

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论