找回密码
 立即注册

QQ登录

只需一步,快速开始

搜索
查看: 2635|回复: 0
收起左侧

单片机控制的自主寻迹智能小车设计论文和源程序

[复制链接]
ID:202279 发表于 2017-5-18 18:31 | 显示全部楼层 |阅读模式
(1)直道检测。在小车的中部平行装有两个色标传感器,采用查询检测的方法对黑线进行检测。89C51
在检测到黑线信号后,通过89C51的PI.5和Pl.6口得知是哪一个传感器检测到黑线,以此作为调整小车方向的基准。在程序方面,我们采用了差补控制算法。在校正服务程序中通过检测PI.5和Pl.6口的状态,运用差补算法,精确调节左右前轮的方向,达到使小车稳定沿黑线行走的目的。为了保证程序的准确性,服务程序中设置了2重黑线检测,有效的防止了小车冲出跑道。在直道上的铁片,我们使用金属探测传感器来检测。通过计算小车开始检测到铁片与离开铁片时的圈数之差,乘以车轮的周长,我们可以得到铁片的长度以及铁片一半的长度,由此可以得到起跑线到铁片中央的距离。当车轮转动时,安装在轮胎上的磁钢使霍尔元件产生电平变化。因此只需记录电平变化的次数,便能得到实际转速。为了提高准确度,减少误差,我们安装了两块磁钢。
    (2)转弯检测。为了防止小车冲出跑道以及按照黑线转弯,需要在进人弯道之前降低速度。因此我们采用了高效的HPWM电路调节转速。在进人转弯之前,我们通过提前减速程序使小车降低速度。通过跟随黑线行驶和检测最后一片铁片的位置,我们可以得到准确的停车位置和车头方向。在铁片上停留55的期间,驱动声光报警系统,发出声光报警信号;同时,由累计脉冲的总数便可得到全程行驶的时间。
    (3)
障碍检测。首先我们通过寻找Zoow灯泡的光源,来校正小车的方向。然后通过超声波对障碍物进行距离检测,以此为基准,绕过障碍物。再通过检测光源找到小车与车库之间的距离,并由此引导小车准确进入车库。
0.png
0.png

单片机源程序如下:
  1. //========================================================
  2. //  工程名称:        Car_Demo
  3. //  功能描述:        实现DIY竞赛小车的语音控制
  4. //  涉及的库:        CMacro1016.lib
  5. //                    bsrv222SDL.lib
  6. //                                sacmv26e.lib
  7. //  组成文件:        main.c
  8. //                                Flash.asm, hardware.asm,ISR.asm
  9. //                             hardware.h,s480.h, hardware.inc
  10. //        硬件连接:        IOA0-----KEY1
  11. //                                IOA1-----KEY2
  12. //                                IOA2-----KEY3
  13. //                                IOB10----MOTOR1A
  14. //                                IOB11----MOTOR1B
  15. //                                IOB12----MOTOR2A
  16. //                                IOB13----MOTOR2B
  17. //        维护记录:        2007-06  v1.0
  18. //  本代码在原凌阳小车代码上修改而成,版权原作者所有!-61mcu
  19. //========================================================

  20. #include "s480.h"
  21. #include "bsrsd.h"

  22. #define        P_IOA_Data                         (volatile unsigned int *)0x7000   
  23. #define P_IOA_Dir                         (volatile unsigned int *)0x7002
  24. #define P_IOA_Attrib                 (volatile unsigned int *)0x7003
  25. #define P_IOB_Data                        (volatile unsigned int *)0x7005  
  26. #define P_IOB_Dir                        (volatile unsigned int *)0x7007   
  27. #define P_IOB_Attrib                (volatile unsigned int *)0x7008   
  28. #define P_TimerA_Data                (volatile unsigned int *)0x700A   
  29. #define P_TimerA_Ctrl                (volatile unsigned int *)0x700B   
  30. #define P_TimerB_Data                (volatile unsigned int *)0x700C   
  31. #define P_TimerB_Ctrl                (volatile unsigned int *)0x700D   
  32. #define P_Watchdog_Clear        (volatile unsigned int *)0x7012   
  33. #define P_INT_Mask                        (volatile unsigned int *)0x702D   
  34. #define P_INT_Clear                        (volatile unsigned int *)0x7011   

  35. #define NAME_ID                         0x100
  36. #define COMMAND_GO_ID                 0x101
  37. #define COMMAND_BACK_ID         0x102
  38. #define COMMAND_LEFT_ID         0x103
  39. #define COMMAND_RIGHT_ID         0x104

  40. #define S_NAME                                0                                                        //给我取个名字吧
  41. #define S_ACT1                                1                                                        //前进
  42. #define S_ACT2                                2                                                        //倒车,请注意
  43. #define S_ACT3                                3                                                        //左拐
  44. #define S_ACT4                                4                                                        //右拐       
  45. #define S_RDY                                5                                                        //Yeah
  46. #define S_AGAIN                                6                                                        //请再说一遍
  47. #define S_NOVOICE                        7                                                        //没有听到任何声音
  48. #define S_CMDDIFF                        8                                                        //说什么暗语呀
  49. #define S_NOISY                                8                                                        //说什么暗语呀
  50. #define S_START                                9                                                        //准备就绪,开始辨识       
  51. #define S_GJG                                10                                                        //拐就拐
  52. #define S_DCZY                                11                                                        //倒车,请注意

  53. extern  unsigned int BSR_SDModel[100];                                        //外部变量BSR_SDModel[100],辨识器自带
  54. extern void F_FlashWrite1Word(unsigned int addr,unsigned int Value);
  55. extern void F_FlashErase(unsigned int sector);
  56. unsigned int uiTimeset = 3;                                                                //运行时间定时,调整该参数控制运行时间
  57. unsigned int uiTimecont;                                                                 //运行时间计时

  58. //=============================================================
  59. // 语法格式:        void Delay();
  60. // 实现功能:        延时
  61. // 参数:                无
  62. // 返回值:                无
  63. //=============================================================
  64. void Delay()                                                       
  65. {
  66.         unsigned int i;
  67.         for(i=0;i<0x3Fff;i++)
  68.         {
  69.                 *P_Watchdog_Clear=0x0001;
  70.         }
  71. }

  72. //=============================================================
  73. // 语法格式:        void PlaySnd(unsigned SndIndex,unsigned DAC_Channel);
  74. // 实现功能:        语音播放函数
  75. // 参数:                SndIndex-播放语音资源索引号
  76. //                                DAC_Channel-播放声道选择
  77. // 返回值:                无
  78. //=============================================================
  79. void PlaySnd(unsigned SndIndex,unsigned DAC_Channel)
  80. {
  81.         BSR_StopRecognizer();                                                                //停止识别器
  82.         SACM_S480_Initial(1);                                                                //初始化为自动播放
  83.         SACM_S480_Play(SndIndex, DAC_Channel, 3);                        //开始播放一段语音
  84.         while((SACM_S480_Status()&0x0001)!= 0)                                //是否播放完毕?
  85.         {
  86.                 SACM_S480_ServiceLoop();                                                //解码并填充队列
  87.                 *P_Watchdog_Clear=0x0001;                                                //清看门狗
  88.         }
  89.         SACM_S480_Stop();                                                                        //停止播放
  90.         BSR_InitRecognizer(BSR_MIC);                                                //初始化识别器
  91. }

  92. //=============================================================
  93. // 语法格式:        int TrainWord(int WordID,int SndID);
  94. // 实现功能:        训练一条指令
  95. // 参数:                WordID-指令编码
  96. //                                SndID-指令提示音索引号
  97. // 返回值:                无
  98. //=============================================================
  99. int TrainWord(unsigned int WordID,unsigned int SndID)
  100. {
  101.         int Result;
  102.         PlaySnd(SndID,3);                                                                        //引导训练,播放指令对应动作
  103.         while(1)
  104.         {
  105.                 Result = BSR_Train(WordID,BSR_TRAIN_TWICE);                //训练两次,获得训练结果
  106.                                                                                
  107.                 if(Result==0)break;
  108.                 switch(Result)
  109.                 {
  110.                 case -1:                                                                                //没有检测出声音
  111.                         PlaySnd(S_NOVOICE,3);
  112.                         return -1;
  113.                 case -2:                                                                                 //需要训练第二次
  114.                         PlaySnd(S_AGAIN,3);
  115.                         break;
  116.                 case -3:                                                                                //环境太吵
  117.                         PlaySnd(S_NOISY,3);
  118.                         return -3;       
  119.                 case -4:                                                                                //数据库满
  120.                          return -4;       
  121.                 case -5:                                                                     //检测出声音不同
  122.                         PlaySnd(S_CMDDIFF,3);
  123.                         return -5;
  124.                 case -6:                                                                     //序号错误
  125.                         return -6;
  126.                 default:
  127.                         break;
  128.                 }
  129.         }
  130.         return 0;
  131. }

  132. //=============================================================
  133. // 语法格式:        void TrainSD();
  134. // 实现功能:        训练函数
  135. // 参数:                无
  136. // 返回值:                无
  137. //=============================================================
  138. void TrainSD()
  139. {
  140.         while(TrainWord(NAME_ID,S_NAME) != 0) ;                          //训练名称
  141.         while(TrainWord(COMMAND_GO_ID,S_ACT1) != 0) ;                  //训练第1个动作
  142.         while(TrainWord(COMMAND_BACK_ID,S_ACT2) != 0) ;          //训练第2个动作
  143.         while(TrainWord(COMMAND_LEFT_ID,S_ACT3) != 0) ;          //训练第3个动作
  144.         while(TrainWord(COMMAND_RIGHT_ID,S_ACT4) != 0) ;        //训练第4个动作
  145. }

  146. //=============================================================
  147. // 语法格式:        void StoreSD();
  148. // 实现功能:        存储语音模型函数
  149. // 参数:                无
  150. // 返回值:                无
  151. //=============================================================
  152. void StoreSD()                                                  
  153. {        unsigned int ulAddr,i,commandID,g_Ret;
  154.         F_FlashWrite1Word(0xef00,0xaaaa);
  155.         F_FlashErase(0xe000);
  156.            F_FlashErase(0xe100);
  157.            F_FlashErase(0xe200);
  158.            ulAddr=0xe000;//********
  159.         for(commandID=0x100;commandID<0x105;commandID++)
  160.         {
  161.                 g_Ret=BSR_ExportSDWord(commandID);                       
  162.                 while(g_Ret!=0)                                                                        //模型导出成功?
  163.                 g_Ret=BSR_ExportSDWord(commandID);               
  164.                 for(i=0;i<100;i++)                                                                //保存语音模型SD1(0xe000---0xe063)
  165.                 {
  166.                     F_FlashWrite1Word(ulAddr,BSR_SDModel[i]);
  167.                         ulAddr+=1;                                                                                               
  168.                 }
  169.         }
  170. }

  171. //=============================================================
  172. // 语法格式:        void StoreSD();
  173. // 实现功能:        装载语音模型函数
  174. // 参数:                无
  175. // 返回值:                无
  176. //=============================================================
  177. void LoadSD()                                                  
  178. {        unsigned int *p,k,jk,Ret,g_Ret;
  179.         p=(int *)0xe000;                                                                                                                                                                       
  180.         for(jk=0;jk<5;jk++)
  181.         {
  182.                 for(k=0;k<100;k++)
  183.                 {
  184.                         Ret=*p;                                                       
  185.                         BSR_SDModel[k]=Ret;                                        //装载语音模型                       
  186.                         p+=1;                                                                                                       
  187.                 }                                       
  188.                 g_Ret=BSR_ImportSDWord();                               
  189.                 while(g_Ret!=0)                                                        //模型装载成功?
  190.                 g_Ret=BSR_ImportSDWord();                                                               
  191.         }
  192. }

  193. //=============================================================
  194. // 语法格式:        void GoAhead();
  195. // 实现功能:        前进子函数
  196. // 参数:                无
  197. // 返回值:                无
  198. //=============================================================
  199. void GoAhead()                                                     //前进
  200. {  
  201.         PlaySnd(S_ACT1,3);                                                        //提示
  202.         *P_IOB_Data=0x1400;                                                        //前进
  203.         *P_INT_Mask |= 0x0004;                                                //以下为中断定时操作
  204.         __asm("int fiq,irq");
  205.         uiTimecont = 0;
  206. }
  207. //=============================================================
  208. // 语法格式:        void BackUp();
  209. // 实现功能:        后退子函数
  210. // 参数:                无
  211. // 返回值:                无
  212. //=============================================================
  213. void BackUp()                                                //倒退
  214. {       
  215.         PlaySnd(S_DCZY,3);                                                        //提示
  216.         *P_IOB_Data=0x2800;                                                        //倒退
  217.         *P_INT_Mask |= 0x0004;                                                //以下为中断定时操作
  218.         __asm("int fiq,irq");
  219.         uiTimecont = 0;
  220. }

  221. //=============================================================
  222. // 语法格式:        void TurnLeft();
  223. // 实现功能:        左转子函数
  224. // 参数:                无
  225. // 返回值:                无
  226. //=============================================================
  227. void TurnRight()                                           //右转
  228. {
  229.         PlaySnd(S_GJG,3);       
  230.         *P_IOB_Data=0x1800;                                                        //右转
  231.         Delay();                                                                        //延时
  232.         *P_IOB_Data=0x2400;                                                        //左转
  233.         *P_INT_Mask |= 0x0004;                                                //以下为中断定时操作
  234.         __asm("int fiq,irq");
  235.         uiTimecont = 0;
  236. }
  237. //=============================================================
  238. // 语法格式:        void TurnRight();
  239. // 实现功能:        右转子函数
  240. // 参数:                无
  241. // 返回值:                无
  242. //=============================================================
  243. void TurnLeft()                                               //左转
  244. {
  245.         PlaySnd(S_GJG,3);                                                        //语音提示
  246.     *P_IOB_Data=0x2400;                                                        //左转
  247.         Delay();                                                                        //延时
  248.         *P_IOB_Data=0x1800;                                                        //右转       
  249.         *P_INT_Mask |= 0x0004;                                                //以下为中断定时操作
  250.         __asm("int fiq,irq");
  251.         uiTimecont = 0;
  252. }

  253. //=============================================================
  254. // 语法格式:        void Stop();
  255. // 实现功能:        停车子函数
  256. // 参数:                无
  257. // 返回值:                无
  258. //=============================================================
  259. void Stop()                                                   //停车
  260. {
  261.         *P_IOB_Data=0x0000;                                                        //停车
  262.         PlaySnd(S_RDY,3);                                                        //语音提示
  263. }

  264. //=============================================================
  265. // 语法格式:        void BSR(void);
  266. // 实现功能:        辨识子函数
  267. // 参数:                无
  268. // 返回值:                无
  269. //=============================================================
  270. void BSR(void)
  271. {       
  272.         int Result;                                                                        //辨识结果寄存
  273.         Result = BSR_GetResult();                                        //获得识别结果

  274.         if(Result>0)                                                                //有语音触发?
  275.         {       
  276.                 *P_IOB_Data=0x0000;                                                //临时停车
  277.                 switch(Result)
  278.                 {
  279.                 case NAME_ID:                                                        //识别出名称命令
  280.                         Stop();                                                                //停车待命
  281.                         break;
  282.                 case COMMAND_GO_ID:                                                //识别出第一条命令
  283.                         GoAhead();                                                        //执行动作一:直走
  284.                         break;
  285.                 case COMMAND_BACK_ID:                                        //识别出第二条命令
  286.                         BackUp();                                                        //执行动作二:倒车
  287.                         break;
  288.                 case COMMAND_LEFT_ID:                                        //识别出第三条命令
  289.                         TurnLeft();                                                        //执行动作三:左转
  290.                         break;
  291.                 case COMMAND_RIGHT_ID:                                        //识别出第四条命令
  292.                         TurnRight();                                                //执行动作四:右转
  293.                         break;
  294.                 default:
  295.                         break;
  296.                 }
  297.         }
  298. }
  299. //=============================================================
  300. // 语法格式:        void IRQ5(void);
  301. // 实现功能:        中断服务子函数
  302. // 参数:                无
  303. // 返回值:                无
  304. //=============================================================
  305. void IRQ5(void)__attribute__((ISR));                        //运动定时控制
  306. void IRQ5(void)
  307. {
  308.         if(uiTimecont++ == uiTimeset)
  309.         {
  310.                 *P_IOB_Data = 0x0000;
  311.         }
  312.         *P_INT_Clear = 0x0004;
  313. }

  314. //=============================================================
  315. // 语法格式:        int main(void);
  316. // 实现功能:        主函数
  317. // 参数:                无
  318. ……………………

  319. …………限于本文篇幅 余下代码请从51黑下载附件…………
复制代码

所有资料51hei提供下载:
单片机智能小车.rar (387.98 KB, 下载次数: 17)
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

手机版|小黑屋|51黑电子论坛 |51黑电子论坛6群 QQ 管理员QQ:125739409;技术交流QQ群281945664

Powered by 单片机教程网

快速回复 返回顶部 返回列表