小车循迹控制程序设计.doc

上传人:laozhun 文档编号:2940916 上传时间:2023-03-05 格式:DOC 页数:21 大小:1.36MB
返回 下载 相关 举报
小车循迹控制程序设计.doc_第1页
第1页 / 共21页
小车循迹控制程序设计.doc_第2页
第2页 / 共21页
小车循迹控制程序设计.doc_第3页
第3页 / 共21页
小车循迹控制程序设计.doc_第4页
第4页 / 共21页
小车循迹控制程序设计.doc_第5页
第5页 / 共21页
点击查看更多>>
资源描述

《小车循迹控制程序设计.doc》由会员分享,可在线阅读,更多相关《小车循迹控制程序设计.doc(21页珍藏版)》请在三一办公上搜索。

1、武汉理工大学华夏学院课外自主实验分析报告实验名称 小车循迹控制程序设计 专 业 软件工程 班 级 学 号 姓 名 第1章 实验分析31.1 实验设计题目31.2 实验设计任务31.2.1 总体任务31.2.2 详细任务31.2.3 设计要求31.3软硬件运行环境及开发工具3第2章 概要设计42.1 小车软硬件设计原理42.1.1 小车硬件设计原理42.1.2小车软件设计原理42.2 功能设计原理及实现方法42.2.1小车前进功能实现42.2.2 小车旋转功能实现42.2.3 小车偏移修正功能设计4第3章 详细设计93.1 硬件设计与实现93.2 系统主程序流程103.3功能模块详细设计103.

2、3.1 起始点到中心点路线模块设计103.3.2 中心点到D点路线模块设计103.3.3 D点到黑色点路线模块设计113.3.4 白色点到中心点模块设计123.3.5 中心点到起始点路线模块设计13第4章 系统调试与操作说明154.1 系统调试154.1.1 直线调试154.1.2 达到黑色终点点调试154.3 操作说明15第5章 总结和体会16第6章 参考文献16附录:1课外实验设计计划学生姓名: 万志雄 专业班级: 软件1111 实验题目:小车循迹控制系统设计(路线3)实验器材:1、硬件设备:MCS-51单片机最小系统板、四个QTI传感器、两个舵机、两个车轮、锂电池、ISP下载线、面包板;

3、2、软件环境:Keil C51、progisp下载器。实验任务:(在规定的时间内完成下列任务)1完成硬件设计并连线,以MCS-51单片机为控制核心,根据4个QTI传感器采集到的数据控制舵机的运转,进而控制车轮的速度和方向,并画出硬件原理图和实验连线图;2用C语言编程实现以下小车行驶线路(地图见下页):起始点中心点D点,旋转360度黑色点,旋转180度原路返回。时间安排:各时间段的任务可以交替进行时间设计内容第一天设计题目,实物演示、规划任务、查找相关资料第二天进行需求分析,完成总体设计第三天硬件详细设计,连接实验电路,软件详细设计,编写程序;第四天调试程序、测试系统、总结;第五天总结后完成设计

4、报告。指 导 教 师 签 名: 2014 年 6 月 30 日教研室主任(或责任教师)签名: 2014年 6 月 30 日起始点 目 录第1章 实验分析1.1 实验设计题目 小车循迹控制系统设计(路线3)1.2 实验设计任务及要求1.2.1 实验总体任务(1)硬件部分:完成硬件设计并连线,以MCS-51单片机为控制核心,随时采集4个QTI传感器的数据控制舵机的运转,进而控制车轮的速度和方向。 (2)软件部分:用C语言编程实现小车行驶线路:起始点中心点D点(旋转360度)黑色点然后旋转180度原路返回。1.2.2任务 使用KeilC51编程软件采用C语言编程实现小车路线3的总体调试,同时不断修正

5、小车的路线。1.2.3 实验设计要求 完成硬件原理图设计、小车模型构建、软件编程、调试、运行等一整套工作任务。控制软件使用C语言编程;系统联调,提交一个满足要求的小车循迹控制系统设计。1.3软硬件运行环境及开发工具 以MCS-51单片机为控制核心,根据4个QTI传感器采集的数据控制舵机的运转,Windows xp操作系统PC机一台。KeilC51编程软件、progisp下载器、串口调试小助手等软件。第2章 概要设计2.1 小车软硬件设计原理2.1.1 小车硬件设计原理小车前面有4个qti感应器来随时采集数据,当探测为黑线的时候,返回值为1,当探测为白线的时候,返回值是0,只有当中间那个qti返

6、回值全为1的时候,才走在黑线上,根据返回的状态来控制小车舵机的速度。2.1.2小车软件设计原理将整个过程分为五部分来实现,分别为起点到中心点,中心点到D点,D点到黑色点,黑色点到中心点,中心点到起始点。在运动过程中还需设计旋转45度和180度和360度的旋转子模块,当小车偏离轨迹候后,需设计修正子模块。2.2 功能设计原理及实现方法2.2.1小车前进功能实现此模块原理是向伺服电机输出若干个PWM波,波形的占空比可控制小车移动,通过时间宽度和延时产生信号,作用于电机,从而控制其运动。在本次设计中,向伺服电机PWM波过程已经被模块化在头文件中,即motion()函数中,通过对motion()函数的

7、三个参数进行设置来实现控制电机转动从而控制小车前进。motor_motion(uint16_t left_val, uint16_t right_val, uint8_t count)例:其中参数left_val:左边电机的高电平时间宽度;right_val:右边电机的高电平时间宽度;count:脉冲数目 2.2.2 小车旋转功能实现小车旋转的原理是调整两轮的移动方式、速度及移动步数。当需旋转360度时,将左轮设置为快速后退状态,右轮为快速前进状态,多次调试测出旋转所需的步数. 2.2.3 小车偏移修正功能设计 小车偏移修正功能即对小车传感器信号状态进行检测并作出相应的处理的过程,在修正过程中

8、偏移情况及其代码和信号状态如下:void modify()if(P22_state()&(!P23_state()|(P21_state()&(!P22_state()&(!P23_state()&(!P24_state() motor_motion(1470, 1700,1); /左转修正 else if(!P22_state()&P23_state()|(!P21_state()& (!P22_state()&(!P23_state()&P24_state() motor_motion(1300, 1550,1); /右转修正 else motor_motion(1700,1300,1);

9、 (1) 当小车发生右偏移时,各传感器状态信号如下:100000001100 通过判断语句:if(P22_state()&(!P23_state()|(P21_state()&(!P22_state()&(!P23_state()&(!P24_state()判断小车是否向左偏移,若发生偏移此时通过调节左右轮的速度来实现,左偏时调用motor_motion(1770, 1740,1)实现左轮前进速度大于右轮前进速度来实现向右偏移来对偏移进行修正。 (2 ) 当小车发生右偏移时,各传感器状态信号如下:100000001100通过判断语句:if(!P22_state()&P23_state()|(!

10、P21_state()& (!P22_state()&(!P23_state()&P24_state() 判断小车是否向右偏移。若发生偏移,此时通过调节坐游轮的速度来实现,右偏时调用motor_motion(1550, 1300,1),通过调节左右轮的速度,当右轮速度大于左轮速度进行修正。2.3.1编程头文件 (1)各个头文件如下图图2.1 (2)delay.h头文件实现延时功能,帮助系统更加理性化,易于操作。例如小车开始部分延时3秒。delay.h头文件详细代码如下:void delay_nus(unsigned int i) i=i/10; while(-i); void delay_nm

11、s(unsigned int n) n=n+1; while(-n) delay_nus(900); /进行时间补偿 (3)qti.h头文件其作用是获取4个QTI传感器采集的信号。为51单片机提供判断的输入数据。qti.h头文件P21口实例详细代码如下:/*函数名称:P21_state()功能: 获得左边第一个QTI的返回信号参数:无参数返回值:1:高电平,看到黑线;0:低电平,看到白线*/int P21_state() return (P2&0x02)?1:0;(4)global.h头文件其作用是定义用到的数据类型、变量。方便程序设计,简化程序结构。详细代码如下:#ifndef GLOBAL

12、_H#define GLOBAL_Htypedef unsigned int uint16_t;typedef unsigned char uint8_t;typedef unsigned char bool;#define true 1#define false 0#endif (5)motion.h头文件其作用是控制两个舵机运转 。详细代码如下:#include Global.hsbit left_motor = P10; /左电机接口sbit right_motor = P11; /右电机接口#define LEFT_FWD 1700 /高电平时间定义,单位微秒#define LEFT_

13、BWD 1300#define LEFT_SMALL_FWD1530#define LEFT_SMALL_BWD 1450#define RIGHT_FWD 1300#define RIGHT_BWD 1700#define RIGHT_SMALL_FWD 1450#define RIGHT_SMALL_BWD 1530函数名称:motor_motion(uint16_t left_val, uint16_t right_val, uint8_t count)作用:向伺服电机输出若干个PWM波,波形的占空比可控制参数:left_val:左边电机的高电平时间宽度;right_val:右边电机的高

14、电平时间宽度;count:脉冲数目返回值:无返回值void motor_motion(uint16_t left_val, uint16_t right_val, uint8_t count) uint8_t i; for(i=0; icount; i+) left_motor = 1; delay_nus(left_val); left_motor = 0 right_motor = 1; delay_nus( right_val ); right_motor = 0; delay_nms(20); /输出一定数量的PWM波形 第3章 详细设计3.1 硬件设计与实现小车是由多个硬件零件组装而

15、成,每个零件负责不同的功能,根据设计任务和要实现的主要功能,来进行硬件设计。硬件设计原理图如下: 图3.1 总体电路图图3.3灰度QTI传感器3.2 系统主程序流程小本系统设计了五个个模块,分别为起点到中心点路线模块、中心点到D点、D点黑色点、黑色点到中心点、中心点返回到起始点路线模块。通过对每个功能模块的调用实现系统要求的功能。3.3功能模块详细设计3.3.1 起始点到中心点路线模块设计起点到中心点,主要是从开始就前进,在前进过程中不停检测传感器传过来的信号,通过判断小车是否偏离路线后决定是否修正。程序代码如下while(1) motor_motion(1700,1300,1); modif

16、y(); if(P22_state()&P23_state()&P21_state()&!P24_state() /motor_motion(1500,1500,0); /中心点停 motor_motion(1500,1300,18); /右转45度 break; 3.3.2 中心点到D点路线模块设计中心点到B点,主要是从开始就前进,在前进过程中不停检测传感器传过来的信号,通过判断小车是否偏离路线后决定是否修正。如果检测到0000信号,则执行旋转360度程序。设计函数centerToD()来实现此模块功能。程序代码如下:while(1)motor_motion(1700,1300,1); mo

17、dify(); if(!P21_state()&!P22_state()&!P23_state()&!P24_state()/motor_motion(1500,1500,0); /D点停 motor_motion(1300,1300,150); /转360度 break; 程序流程图如下: 开始前进偏移?前进修正是否全为1?否旋转360度是退出循环 图3.3中心点到D点模块流程图3.3.3 D点到黑色点路线模块设计D点到黑色点前进过程中也要进行检测修正,当遇到1111信号时,执行旋转180度,其代码为:while(1) motor_motion(1700,1300,1); modify();

18、 if(P21_state()&P22_state()&P23_state()&P24_state() motor_motion(1300,1300,75); /转180度 break; 程序流程图如下: 开始前进偏移?前进修正是否全为1?否旋转180度是退出循环 图3.4 D点到黑点模块流程图3.3.4 白色点到中心点模块设计白色点到中心点循迹过程中,不断地通过传感器检测信号,进行路线修正。当第一次检测到1111信号时,这表示已经到达中心点。采用的函数和刚开始去中心点的一样,模块程序代码如下:while(1) motor_motion(1700,1300,1); modify(); if(P

19、21_state()&P22_state()&P23_state()&P24_state() /motor_motion(1500,1500,0); /回到中心点停 motor_motion(1700,1500,18); /向左转45度 break; 程序流程图如下: 开始前进偏移?前进修正是否全为1?否左旋转45度是退出循环 图3.5黑点到中心点模块流程图3.3.5 中心点到起始点路线模块设计 while(1) motor_motion(1700,1300,1); modify(); if(P21_state()&P22_state()&P23_state()&P24_state() mot

20、or_motion(1500,1500,0); /回到起始点 break; 程序流程图如下: 开始前进偏移?前进修正是否全为1?否停止是退出循环 图3.6中心点到D点出发点模块流程图第4章 系统调试与操作说明4.1 系统调试4.1.1 直线调试 主要是判断小车是否能沿着黑线向前走,方法:让程序只有函数modify(),main()函数中只有motor_motion(1700,1300,1)这条语句;并烧写到小车中,把小车放在一条黑线上,看它是否能一直在黑线上前进,若不能,再qti是否连接正确,直至小车能一直走在直线上。4.1.2 达到黑色终点点调试主要判断小车能否到黑色终点,并原地旋转180度

21、,方法:将自己模块程序烧写到小车中,放在黑点上面,观察小车能否到黑色终点旋转前进到中心点并并原地旋转180度,注意看其角度是否正常。 4.2 调试中遇到的问题 调试的时候,是在黑色终点处的时候,旋转度数不足。多次调试后为motor_motion(1300,1300,75)。4.3 操作说明在KeilC51中写好的程序进行编译生成.hex文件,然后通过ISP下载线和progisp软件将已生成的.hex文件烧写到单片机中。当烧写成功后,拔掉下载线,然后在已设定好的路径上,摆正小车的位置,打开小车上的开关。观察小车是否按照预定的路径进行行驶。 第5章 总结和体会整个过程中,从需求分析到设计、编码、测

22、试,我都力求规范化和文档化,努力让自己以前学的知识运用到本系统的开发中,尽量保证整个系统的开发进度和质量,顺利完成这次的课程设计。不过,在实验过程中,好多知识都是随学随用,就增加了很多不必要的麻烦。虽说这些都会消耗系统开发的时间,但在同学以及自己的不断努力下,不怕麻烦,不怕重复,当克服了这些问题之后,我会感觉到自己的知识在一点一滴地积累,不知不觉中增加。我相信,只要肯钻研,只要挤时间,一切自己想要的知识都可以掌握。通过本次课程设计,我对小车循迹系统经典问题有了进一步的了解,尤其是在软件与硬件的结合方面有了新的认识。在这次课程设计中,由于没有掌握好进程同步中的一些关键知识,导致在实际操作中遇到了

23、很多问题,比如说对单片机借口的不熟悉。此次课程设计使我明白,在程序设计中,我们需要有一个清晰的整体结构,然后针对每个模块逐步实现其功能,在设计中也需要有严谨和认真的态度,才会更好的完成一项任务。第6章 参考文献1 尹志宇、郭晴,单片机入门,北京:清华大学出版社,2011.072黄维通、王晓英,万能的51单片机 ,北京:清华大学出版社,2011.013 庞娅娟、房大伟51单片机简明教程,北京:人民邮电出版社,2009.104王小科、王军、赵会东,单片机开发案例全程实录(第二版),北京:清华大学出版社2011.01附录:#includereg52.h#includedelay.h#includeq

24、ti.h#includemotion.h#includeGlobal.hvoid modify()if(P22_state()&(!P23_state()|(P21_state()&(!P22_state()&(!P23_state()&(!P24_state() motor_motion(1470, 1700,1); /左转修正 else if(!P22_state()&P23_state()|(!P21_state()& (!P22_state()&(!P23_state()&P24_state() motor_motion(1300, 1550,1); /右转修正 else motor_

25、motion(1700,1300,1); void main(void)while(1) motor_motion(1700,1300,1); modify(); if(P22_state()&P23_state()&P21_state()&!P24_state() motor_motion(1500,1300,18); /右转45度 break; while(1)motor_motion(1700,1300,1); modify(); if(!P21_state()&!P22_state()&!P23_state()&!P24_state()motor_motion(1300,1300,15

26、0); /转360度 break; while(1) motor_motion(1700,1300,1); modify(); if(P21_state()&P22_state()&P23_state()&P24_state() motor_motion(1300,1300,75); /转180度 break; while(1) motor_motion(1700,1300,1); modify(); if(P21_state()&P22_state()&P23_state()&P24_state() motor_motion(1700,1500,18); /向左转45度 break; while(1) motor_motion(1700,1300,1); modify(); if(P21_state()&P22_state()&P23_state()&P24_state() motor_motion(1500,1500,0); /回到起始点 break; 照片:设计者: 万志雄 日 期:2014年6月5 日

展开阅读全文
相关资源
猜你喜欢
相关搜索

当前位置:首页 > 建筑/施工/环境 > 项目建议


备案号:宁ICP备20000045号-2

经营许可证:宁B2-20210002

宁公网安备 64010402000987号