基于智能车非匀速行驶记忆算法的研究和实现
本文对基于非匀速行驶状态下光电智能车的记忆算法进行了深入研究,详细介绍了系统硬件设计、原始数据的记忆、数据处理和记忆算法的实现。
硬件实现原理 按照竞赛的某些规定,本文设计了如图1所示的硬件原理框图。红外传感器采用一排13对红外发射接收管,利用其接收的电平大小经过MCU的ADC后由MCU判断当前黑线所处的位置,为了降低功耗,系统中还增加了MOS开关管,当检测某红外传感器时该传感器供电打开,其余的则关闭。赛道中具有十字交叉路口,同时必须判断起始(即终止线),因此智能车预先可以配置当前赛道的总的十字交叉个数,同时通过软件算法可以判断出是否经过世纪交叉口(起始终止线可以作为一个十字交叉线)。系统运行时,按照红外传感器采集的信息可以判断出当前引导线的位置,即在小车的左边、中间或右边,偏离多少,MCU据此以及由Hall测速传感器获知的当前小车的速度确定小车当前的行为,主要控制舵机即小车的方向和电机即小车的速度。
图1 系统硬件框图
软件控制算法 系统软件控制主要包括两部分,也即记忆算法的两个过程,从行驶过程中看即第一圈和第二圈,其流程框图如图2所示。
图2 系统软件控制流程图
初圈的控制和记忆 智能车在行使第一圈时的主要目的就是记忆赛道信息特征,并进行一定的处理。按常规方法小车需要匀速行驶,以便在固定的时间间隔或固定的路程间隔记忆相关的道路信息。数据记忆时,采用了12个磁钢的霍尔传感器,车轮转一圈得到12个计数,即使在速度很快的情况下响应时间也是us级的,精度足够满足要求。 在非匀速的条件下,采用了新的数据存储格式。首先对当前的状态进行弯直的判断,根据迷糊控制得到的舵机的转角值c_ang,判断得到当前车的弯直情况。同时由于车是非匀速行驶的,而第二圈所行驶的时间间隔和路程间隔也并不一定和第一圈完全相同,因此只判断弯直情况,在弯道时,记忆每一个测试点的转角值,而直道时,既没必要存储转角,又可节省大量存储空间,因此对于直道时只记忆直道的起点和终点路程,而该路程是小车相对于起始点的绝对路程,也即霍尔传感器检测到的磁钢的个数ect_cnt。 系统按照前一状态和当前状态的不同情况分别进行数据存储,其算法如下:当前一状态是弯道,现状态是直道时,即弯直态,则写入0x7f,ect_cnt,其中ect_cnt是当前的路径计数;当直直态时,不存储;当直弯时,写入当前的ect_cnt,0x7f,当前的c_ang;当弯弯时,写入c_ang。系统初始化时为弯道,则开始行驶后,进入起跑线,此时检测到是直道,进入弯直状态,写入0x47和当前的ect_cnt,这就是道路的起始存储数据。
数据的分析及处理 第二圈过起跑线时,系统配置成进入弯直状态,此时应该根据第一圈记录的数据算出直道的长度,这样车在直线上就可以以很高的速度行使,并且能够提前减速,安全进弯,达到很好的控制效果。 在由直线进弯时,如果在弯道中出现直道,并且计算出其长度小于某一值的时候,认为是过弯过程中出现的小范围的直线,仍按照弯道处理。本算法的核心也在于如何过滤弯道中出现的直道,以及从分析不同的弯道形式。把弯道分成以下几类: (a) 急弯:这里所说的急弯也就是竞赛规定的曲率最小的弯。在急弯时,转角的个数相对较少,转角值相对较大,并且在正常情况下所有的都是同向的。 (b)圆形弯道:相比于其他几种赛道元素,圆形赛道的识别比较简单,当同一个方向的转角大于某一个数值时,并且中间过程中没有换向发生,便可以认为小车进入了圆形赛道。因为在角度的控制上,本系统采用了模糊控制,车在进弯时能够迅速调整角度,并以一个恒定的角度过弯,以上的数据是验证了这一结果。 (c)小S弯:小S弯的特点是:在过弯的整个过程中既有左转又有右转的,并且左转角度的个数和右转角度的个数都应该大于某一个值。此外,单次左转或者右转的角度的个数小于某一个值。考虑到小S的前后可能会接着其他弯道,本系统在第一个换向点之前,按照其弯道行走,在换向点之后采取小S的行走策略,在最后一个换向点之前结束。 (d)大S弯:大S相比小S而言,其赛道特征是相似的,只是判断的标准稍有不同。首先,大S之间有较长距离的直道,必须加大直道的判断范围才能将其过滤掉。其次,单次左转或者右转的角度的个数应该大于小S的个数。 针对以上赛道分析,系统首先分辨下一步的赛道元素,然后按照行驶策略,将第二圈的行驶速度及方向进行控制。其主要思想为: (a)直道行驶:将直道分为短直道和长直道,短直道就做一般加速处理;长直道在起始处全力加速,末端进行线型减速,也即将速度分成高速,中速,低速,从高到中再到低。经实验发现直接从高速转为低速时,小车在过弯时不稳,容易测滑,不仅影响速度,启动也慢。采用线型减速后过弯流畅,能达到很好的效果。这样就避免了由于车本身的某些局限性,如舵机响应时间、赛道摩擦系数、轮胎抓地力、传感器布局等因素的影响所造成的直线速度不能加到最高的缺点。 (b)对于小S,理想的情况下是实现同CCD同样的效果,采取高速直线过弯的策略。为了安全起见也可以采用滞后过弯的策略,让智能车采取较小的转角高速过弯。 (c)对于大S赛道,不同的曲率弯道,小车有它最佳极限速度存在。利用初圈得到弯道的曲率半径以及S道之间直线的长度,在过各弯道时将车速调至它相应的极限速度,从理论上就是它所能跑出的最优成绩了。 (d)对于圆形弯道,需要在弯道的曲率和过弯的速度之间做一个权衡。当行驶的曲率较大时,那么车可以以较高的速度行驶,当走内圈时,由于半径的减少,离心力的增大,就不能以较高的速度行驶,但是可以找到两者之间的平衡点。
|