浙江大学城市学院智能汽车邀请赛技术报告.docx
《浙江大学城市学院智能汽车邀请赛技术报告.docx》由会员分享,可在线阅读,更多相关《浙江大学城市学院智能汽车邀请赛技术报告.docx(40页珍藏版)》请在冰豆网上搜索。
浙江大学城市学院智能汽车邀请赛技术报告
目录
第一章引言………………………………………………………………………………………1
第二章智能车方案设计…………………………………………………………………………2
第三章智能车机械改造设计……………………………………………………………………4
第四章智能车电路设计与实现…………………………………………………………………6
第五章智能车控制策略与算法………………………………………………………………10
第六章运行调试与小结……………………………………………………………………….13
第七章技术参数统计…………………………………………………………………………15.
参考文献………………………………………………………………………………………16
附录A程序源代码
第一章引言
“飞思卡尔”杯智能车大赛是教育部为了加强大学生实践、创新能力和团队精神的培养而举办的面向全国大学生的智能汽车比赛。
我国大学生“飞思卡尔”杯智能汽车竞赛,是在统一汽车模型平台上,使用飞思卡尔半导体公司的8位、16位微型控制器作为核心控制模块,自主构思控制方案进行系统设计,包括传感器信号采集处理、控制算法及执行、动力电机驱动、转向舵机控制等。
系统按照功能划分为:
电源模块、单片机模块、运行调试模块、路径识别模块、直流电机驱动模块、转向伺服模块、速度测量模块等。
该竞赛是涵盖了控制工程、模式识别、传感技术、电子工程、电气工程、计算机、机械及车辆工程等多个学科的科技创意性比赛,对大学生的知识融合和实践动手能力的培养,对汽车电子技术的发展,具有良好的长期的推动作用。
本文将先从整体上介绍模型车的制作思路和方案,再从车子的机械、传感器、电路等硬件方面到控制的策略、算法的实现等方面具体介绍模型车的制作以及调试过程,最后介绍模型车的主要技术参数。
第二章智能车方案设计
本章主要简要地介绍智能车系统总体方案的选定和总体设计思路,在后面的章节中将整个系统分为机械结构、控制模块、控制算法等三部分对智能车控制系统进行深入的介绍分析。
通过学习竞赛规则和往届竞赛相关技术资料了解到,路径识别模块是智能车系统的关键模块之一,路径识别方案的好坏,直接关系到最终性能的优劣,因此确定路径识别模块的类型是决定智能车总体方案的关键。
如图2.1,而目前能够用于智能车辆路径识别的传感器主要有光电传感器和CCD/CMOS传感器。
光电传感器寻迹方案的优点是电路简单、信号处理速度快,但是其前瞻距离有限;CCD摄像头寻迹方案的优点则是可以更远更早地感知赛道的变化,但是信号处理却比较复杂,如何对摄像头记录的图像进行处理和识别,加快处理速度是摄像头方案的难点之一。
在比较了两种传感器优劣之后,考虑到CCD传感器图像处理的困难后,决定选用应用广泛的光电传感器,相信通过选用大前瞻的光电传感器,加之精简的程序控制和较快的信息处理速度,光电传感器还是可以极好的控制效果的。
系统采用采用了7.2V2000mAhNi-Cd蓄电池作为系统能源,并且通过稳压电路分出6伏,5伏已分别给舵机和单片机供电。
直流电机驱动模块接收速度控制信号控制驱动电机运行,达到控制车速目的。
转向伺服模块控制舵机转向,进而控制智能车转弯。
速度测量模块实时测量智能车车速,用于系统的车速闭环控制,以精确控制车速。
系统充分使用了MC9S12XS128单片机的外围模块,具体使用到的模块包括:
ADC模拟数字转换模块、定时器模块、PWM脉冲宽度调制模块、中断模块、I/O端口和实时时钟模块等。
系统调试过程中,使用了组委会提供的代码调试环境CodeWarriorIDE,同时使用了清华的Plastid2软件进行了仿真试验。
图2.2系统结构框图
第三章智能车机械改造设计
3.1舵机部分
为了使转弯更加灵活,对舵机相关部分作了部分改动。
首先,我们将舵机力臂加长85mm。
这样,对于同样的转弯角度值,只需更小的舵机转角,减小了舵机转弯时惯性带来的弊端。
其次,我们将舵机反装,使舵机连杆水平,因为此时舵机提供的力全部用在转弯上。
图3.1舵机的安装
3.2前轮部分
为了增加前轮转弯时的稳定性,对前轮相关部分进行了部分改动。
首先,更改前后垫片的数量,使前轮主销后倾,这样,车轮具有更好的自动回正功能。
其次,更改连杆的长度,使车轮外倾,车轮转弯时,前半部分重心上移,促使赛车转弯更加稳定。
再次,我们通过更改舵机连杆的长度,增加前轮前束,同样增加了前轮的稳定性。
3.3底盘部分
为了提高赛车运行时的稳定性,对地盘相关部分作了部分改动。
首先,前轮相关位置加垫片,降低了前轮重心。
其次,更改后轮车轴处的调节块,使后轮重心升高,这样,车身前倾,一定程度上,增加了车的稳定性。
3.4后轮部分
首先,更换后轮轮距调节块,使后轮两轮之间间距加大。
这样,车在转弯时不容易产生侧滑。
其次,调节后轮差速,使赛车转弯更加灵活。
3.5测速传感器
测速传感器的安装如图3.2所示。
第四章智能车的电路设计与实现
4.1电源部分
为了能使智能车系统能正常工作,就需要对电池电压调节。
其中,单片机系统、车速传感器电路需要5V电压,路径识别的光电传感器和接收器电路电压工作为5V、伺服电机工作电压范围4.8V到6V(或直接由电池提供),直流电机可以使用7.2V2000mAhNi-cd蓄电池直接供电。
考虑到由于驱动电机引起的电压瞬间下降的现象,因此采用低压降的三端稳压器成为必然。
我们在采用lm7805,和lm7806作为稳压芯片。
经试验电压纹波小,完全可以满足要求。
舵机电源部分采用MC34063API芯片。
电池(7.2v)2000mAhNi-cd
6V
5V
7.2V
测速板Encoder
图4.1系统电压调节图
4.2测速电路
由于考虑到成本需要,我们采用了红外对管和黑白码盘作为测速模块的硬件构成。
其中码盘为32格的黑白相间圆盘,如下图所示:
图4.2码盘
红外传感器安装在正对码盘的前方,虽然这样做精度比编码器要低很多,但是成本低廉制作容易,如果智能车速度较快,可以考虑再减少码盘上黑白色条的数量即可。
当圆盘随着齿轮转动时,光电管接收到的反射光强弱交替变化,由此可以得到一系列高低电脉冲。
设置9S12的ECT模块,同时捕捉光电管输出的电脉冲的上升沿和下降沿。
通过累计一定时间内的脉冲数,或者记录相邻脉冲的间隔时间,可以得到和速度等价的参数值。
测速电路使用自行研制的红外反射式光电测速传感器。
速度测量电路使用红外反射式光电对管RPR220,自行制作的编码盘,比较电路等组成。
图4.3测速电路
速度测量电路图2.8所示。
红外反射式光电对管的光敏三极管信号通过比较器处理后输入单片机的计数器模块,利用单片机的输入捕捉功能,处理智能车速度信息。
自制的编码盘有24道黑色条纹,电机旋转一周将产生24次输入捕捉中断。
单片机记录两次中断的时间间隔T。
两次中断对应于智能车前进的距离S为:
16.5/24cm,即0.6875cm,其中16.5cm为智能车后轮实测周长[7]。
智能车实时速度V(cm/s)的计算公式如下:
4.3红外对管检测电路
由于我们采用了大功率对管,所以红外对管的电路是整个电路中要求最高的,不紧要保证对管正常工作,而且还要考虑整个电路的能耗和发热问题。
经测试我们发现单个对管在通以100mA到170mA电流时可以。
保证抬高20到30厘米的距离。
此时每个对管的管压降为1.2到1.5伏。
为了进一步加大发光量,我们采用了双发射管的办法,即一个接受管对应两个发射管。
为了降低整体的能耗。
我们让同一对的发射管串联,14对发射管再并联。
同时使用了irf540进行开关控制。
控制对管脉冲发光。
开关频率为200HZ。
这样既保证了大前瞻探测的需要,又降低了整体的能耗和对电源的冲击
图4.4先串联再并联的脉冲发光对管电路图。
4.4拨码开关电路
由于在智能车比赛开始后,不能够对智能车硬件及软件进行修改,在保证了硬件有效可靠的同时,软件有可能不能够适应新场地,所以设计拨码开关对智能车有关参数进行设置也是必要的。
拨码开关电路如下图所示:
(换掉)
图4.6拨码开关
这是一个八段的拨码开关,我们把它成成上下连个部分,显然,每个部分都有16种状态,前四个来改变舵机参数,后四个改变直流电机参数,这样对于适应新的场地很有好处。
第五章智能车的控制策略和算法
5.1路径搜索算法
对于本控制系统采用14对光电对管的方案,单排排列在车体头部10cm处。
编号为6、7的光电对管处于正中央位置。
利用14对传感器进行道路识别。
传感器对白色的反射率比黑色的大。
单片机ADC读入值相应也大。
在程序中对传感器信号进行处理,判断传感器是否检测到黑色引导线。
将单个传感器对白色和黑色路面的ADC值之差分为平均的两段,每次处理实时传感器信号时,判断本次采样的ADC值与黑色路面ADC值之差落在两段中的哪一段。
如果在靠近黑色的一段,则判定该传感器检测到黑线,将该传感器对应的变量置为判定值1;如果在靠近白色的一段,则判定该传感器检测到白线,将该传感器对应的变量置为判定值1;为了增强判断的准确性,在对ADC值采样时,采用了中值滤波方法,以去除瞬间的干扰。
路径检测完后,将测的的路径值暂时存储,然后将路径信息传递给舵机和电机控制部分,以选择给定合适的转角和速度。
5.2舵机、电机的控制
智能车的舵机和电机都采用了经典的PID控制方法。
但是由于舵机和电机性能的不同要求,分别对其进行了不同的修改。
PID控制器由比例单元(P)、积分单元(I)和微分单元(D)组成。
其输入e(t)与输出u(t)的关系为
式中积分的上下限分别是0和t,因此它的传递函数为:
G(s)=U(s)/E(s)=kp(1+1/(TI*s)+TD*s)
其中kp为比例系数;TI为积分时间常数;TD为微分时间常数,比例KP用来控制当前,误差值和一个负常数P(表示比例)相乘,然后和预定的值相加。
P只是在控制器的输出和系统的误差成比例的时候成立,KP能够快速的跟随变化量。
及时的产生与之相关的调节作用。
但是KP是有差调节,无法消除静态误差。
积分KI来控制过去,误差值是过去一段时间的误差和,然后乘以一个负常数I,然后和预定值相加。
I从过去的平均误差值来找到系统的输出结果和预定值的平均误差。
一个简单的比例系统会振荡,会在预定值的附近来回变化,因为系统无法消除多余的纠正。
通过加上一个负的平均误差比例值,平均的系统误差值就会总是减少。
所以,最终这个PID回路系统会在预定值定下来。
微分KD来控制将来,计算误差的一阶导,并和一个负常数D相乘,最后和预定值相加。
这个导数的控制会对系统的改变作出反应。
导数的结果越大,那么控制系统就对输出结果作出更快速的反应。
这个D参数也是PID被成为可预测的控制器的原因。
D参数对减少控制器短期的改变很有帮助。
一些实际中的速度缓慢的系统可以不需要D参数。
由于舵机是一个具有大的延迟的执行机构,所以在PID控制中不能加入积分环节。
否则会导致小车震荡。
所以小车采用PD控制。
同时加入一个一阶惯性环节,构成不完全微分,给小车一个超前的调节。
实际使用中,为了减少计算时间,将位置式PID转化为增量式
增量式PID公式:
电机PID控制
小车行使过程中,随着跑道的不同,需要配合不同的速度值,因此对电机的PID是一个给定值不断变化的PID。
小车的目标速度(Object_Speed)给定规则:
1.小车在直道上,Object_Speed为最大值200。
2.小车在大弯道上,Object_Speed为160。
3.小车在小弯道或S型弯道上,Object_Speed为120
4.小车冲出跑道,Object_Speed为70。
5.小车由直道进入弯道,Object_Speed逐渐减小。
6.小车由弯道进入直道,Object_Speed逐渐加大。
在实验中发现,PID的超调量主要在第一个波形中起作用,也即单速度由很大到很小的时候,或由低速突然加到高速的过程中,会出现很大的超调。
但是这个超调并不是有害的,因为,当速度要求突变的时候,往往是小车由直道入弯道,或者由弯道入直道的过程,这个过程往往需要很快的大加减速,而由于小车的惯性,一般的PID调节难以满足要求,这时使用大的超调量可以使小车有一个加速或刹车的过程,使之更好的达到要求速度。
第六章运行调试与小结
6.1Codewarrior开发环境
在整个开发调试过程中,使用Metrowerks公司为MC9S12系列专门提供的全套开发工具(FreescaleCodewarriorIDE4.6)。
这是一套用C语言进行编程的集成开发环境——本文智能车定位系统的软件设计部分就是在此开发环境下完成的。
Codewarrior是由Metrowerks公司提供的专门面向Freescale所有MCU与DSP嵌入式应用开发的软件工具。
其中包括集成开发环境IDE、处理器专家、全芯片仿真、可视化参数显示工具、项目工程管理、C交叉编译器、汇编器、链接器以及调试器。
CodeWarriorIDE能够自动地检查代码中的明显错误,它通过一个集成的调试器和编辑器来扫描你的代码,以找到并减少明显的错误,然后编译并链接程序以便计算机能够理解并执行你的程序。
每个应用程序都经过了使用象CodeWorrior这样的开发工具进行编码、编译、编辑、链接和调试的过程。
MetrowerksCodewarriorIDE中的mc9s12dg128.h文件对所有寄存器对应的存储映射地址都进行了宏定义,开发者在软件开发时直接调用这些宏就可以了。
6.2软件仿真
为了更好的定量分析影响小车行驶的各个因素,而且最大限度的节约时间和成本。
我们采用了软件仿真和实际调试相结合的办法。
仿真软件使用了清华的PLAST2。
通过仿真,我们发现:
1、小车传感器的探测距离对速度有着决定的影响。
所以传感器应该尽量的探测更远。
但是传感器的探测距离不能超过最小转弯的半径。
否则会出现盲区。
2、适度增加舵机的灵敏度,可以使转弯更加灵活。
所以我们在实际调试中,加长了舵机的力臂。
6.2实际调试
实际调试过程中,我们发现小车在直道上会出现左右抖动的现象,通过软件设置死区或其他处理方法,效果都不是很明显,最后发现小车舵机和前轮的间隙是罪魁祸首,通过把前轮设置为内八形,完美的解决了这个问题。
在调试过程中,我们加了液晶显示,还设置了蜂鸣器,这些辅助设备在比赛中为了减轻小车的重量,都是不需要的。
但是在调试过程中,通过这些设备,可以及时的了解小车运行的情况,达到事倍功半的效果。
第七章技术参数统计
表7.1模型车技术参数统计:
项目
参数
路径检测方法(赛题组)
光电组
车模几何尺寸(长、宽、高)(毫米)
385*220*60
车模轴距/轮距(毫米)
200/150
车模平均电流(匀速行驶)(毫安)
200
电路电容总量(微法)
430
传感器种类及个数
红外对管14个
新增加伺服电机个数
1
赛道信息检测空间精度(毫米)
9
赛道信息检测频率(次/秒)
200
主要集成电路种类/数量
9s12单片机最小系统/133886电机驱动电路/4
速度检测电路/1
车模重量(带有电池)(千克)
1.2
参考文献
[1]卓晴.黄开胜学做智能车[M].北京航空航天大学出版社.2006
[2]邵贝贝,单片机嵌入式的在线开发方法[M],北京:
清华大学出版社.2004
[3]邹伯敏.自动控制理论[M].北京:
机械工业出版社.2002
[4]黄开胜.金华民,蒋荻南.韩国智能模型车技术方案分析[J].电子产品世界.2006(5):
150-152
[5]王启志,王永初.智能PID控制器研究的现状与进展[J].自动化仪表2002年第12期
[6]王淑芳编.电机驱动技术[M].科学出版社.2008
[7]杨文元仪.光电编码器分类及应用[J].表技术与传感器-1994年1期
附录A
程序源代码
#include/*commondefinesandmacros*/
#include/*derivativeinformation*/
#pragmaLINK_INFODERIVATIVE"mc9s12xs128"
#include"includes.h"
inttemp1=0,temp2=0;
voidmain(void)
{
unsignedinti;
unsignedcharj;
intlast_add_speed;
unsignedcharstart_line_numb=0;
asmsei;
CLK_Init();
Port_Init();
PIT_Init();//定时器
TIM_Init();//计数器
Sci0Open();
AD_Init();
PWM_Init();
asmcli;
time_up_AD=2;
AD_Max_Min();//环境检测
for(;;)
{
if(start_key()==1)
{
time_up_AD=2;
if(PWME_PWME3==0)
{
DELAY(20000);
stop_car=0;
cnt=0;
PWME=0x8a;
}else
{
PWME=0x82;
}
aim_speed=Max_Speed;
Speed_PID_Clear();
}
key_board();
if(time_up_AD)
{
if(count_1ms>7)//5
{
count_1ms=0;
if(send_flag==1)
{
put_numb(speed_break);//short_straightspeed_break
put_char('');
put_numb(now_speed);//history_error0Down[now_pointer]history_error0Down[now_pointer]
put_str("\r\n");
}
Road_UP();//黑线
AD_Change_Max();
Turn_RL();
brake();
//Display_Array(LED_V,LEDNUM_UP);
}else
{
}
time_up_AD=0;
}
Speed_Control();
if(start_flag==1||start_flag_boma==1)
{
if((PORTK&0x20)==0)
{
if(start_flag_boma==1)
{
start_flag_boma=0;
stop_car=1;
PWME=0X82;
}
}
}
//速度设置
/*
if((PTJ&0x01)==0)//中速
{
speed_flag=1;
if(narload_flag==1)add_speed=45;//if(wideload_flag==1)
elseif(narload_flag==2)add_speed=70;
elseadd_speed=40;
if(last_add_speed!
=add_speed)
{
aim_speed=Max_Speed-add_speed;
last_add_speed=add_speed;
}
}else
if((PTJ&0x02)==0)//高速
{
speed_flag=2;
if(narload_flag==1)add_speed=40;
elseif(narload_flag==2)add_speed=60;
elseadd_speed=0;
if(last_add_speed!
=add_speed)
{
aim_speed=Max_Speed-add_speed;
last_add_speed=add_speed;
}
}
elseif((PTJ&0x03)==0)//超高速
{
speed_flag=3;
if(narload_flag==1)add_speed=10;
elseif(narload_flag==2)add_speed=20;
elseadd_speed=-15;
if(last_add_speed!
=add_speed)
{
aim_speed=Max_Speed-add_speed;
last_add_speed=add_speed;
}
}else//低速
{
speed_flag=0;
if(narload_flag==1)add_speed=90;
elseif(narload_flag==2)add_speed=90;
elseadd_speed=90;
if(last_add_speed!
=add_speed)
{
aim_speed=Max_Speed-add_speed;
last_add_speed=add_speed;
}
}*/
}
}
部分函数的定义
#include"includes.h"
intspeed_flag=0;//速度大小标志位
intstop_car;
intadd_speed=0;
//intadd_speed[200];
intaim_speed=Max_Speed;
intcount_curve=0;//弯曲次数
//--------------------------------------------------------------------------------------
//函数名称:
intDianJi_PID(intAD10)
//函数功能:
PID电机控制dian_P=15,dian_I=25,dian_D=0P=80,dian_I=40,dian_D=40
//--------------------------------------------------------------------------------------
//longdian_P=100,dian_I=60,dian_D=70,speed_error0,speed_error1,speed_error2;
longdian_P=50,dian_I=20,dian_D=20,speed_error0,speed_error1,speed_error2;
longDianJi_PID(longpresent_speed)
{
speed_error2=speed_error1;
speed_error1=speed_error0;
speed_error0=aim_speed-present_speed;
r