最新消息: USBMI致力于为网友们分享Windows、安卓、IOS等主流手机系统相关的资讯以及评测、同时提供相关教程、应用、软件下载等服务。

智能小车pid算法

IT圈 admin 30浏览 0评论

2024年6月13日发(作者:季飞宇)

-----WORD格式--可编辑--专业资料-----

3.1寻迹算法

采用PID(PD)控制算法,如果某时刻检测到黑线偏左,就要向左转弯;如果检测到黑线偏

右,就要向右转。偏得越多,就要向黑线方向打越大的转角。这就是比例控制(P)。

遗憾的是,因为小车有惯性。假设黑线偏左,说明小车偏右了,需要左传舵,等到小车回

到中心的时候,停止转舵,可是小车的惯性会使车身继续左转,直到冲过黑线,黑线又偏右。

然后控制过程反复,车身是在左右摇摆中向前行走的。这种摇摆叫做“超调”,超调越大,控

制越不稳定,容易出轨。

为了克服惯性,我们除了位置信息之外,还需要知道轨迹的变化趋势。我们可以用黑线位

置的微分值来提前得到变化趋势。用本次位置减去前次位置求出差值,就大致知道偏移量的变

化趋势。将该差值和比例相加后一起作为控制量,即可实现提前控制。这就叫做比例微分控制

(PD控制)

/*PID(PD)控制算法*/

int PID_Control(signed char Position)

{

int Temp_P,Temp_D,Temp_PID,Temp_I,k; //声明三个变量,用于存放P、I、D三分量

的运算结果(I没用上)

if(Position==-128) return (No_black); //错误处理(值得改进的地方)

else

--完整版学习资料分享----

-----WORD格式--可编辑--专业资料-----

{

Temp_I=Position;

for(k=0;k<5;k++)Temp_I+=Last_Position[k];

Temp_I*=I_coefficient;

Temp_P=P_coefficient*Position; //计算比例分量(P)=比例系数*本次位置差

Temp_D=D_coefficient*(Position-Last_Position[5]); //计算微分分量(D)=微分系

数*(本次位置差-前3次的位置差)

//注意由于采样比较快,用本次位置-前3次位置才有足

够大的控制量

Last_Position[6]=Last_Position[5];

Last_Position[4]=Last_Position[3];

Last_Position[3]=Last_Position[2];

Last_Position[2]=Last_Position[1];

Last_Position[1]=Last_Position[0];

Last_Position[0]=Position; /*保存前5次的位置,以备用。

--完整版学习资料分享----

2024年6月13日发(作者:季飞宇)

-----WORD格式--可编辑--专业资料-----

3.1寻迹算法

采用PID(PD)控制算法,如果某时刻检测到黑线偏左,就要向左转弯;如果检测到黑线偏

右,就要向右转。偏得越多,就要向黑线方向打越大的转角。这就是比例控制(P)。

遗憾的是,因为小车有惯性。假设黑线偏左,说明小车偏右了,需要左传舵,等到小车回

到中心的时候,停止转舵,可是小车的惯性会使车身继续左转,直到冲过黑线,黑线又偏右。

然后控制过程反复,车身是在左右摇摆中向前行走的。这种摇摆叫做“超调”,超调越大,控

制越不稳定,容易出轨。

为了克服惯性,我们除了位置信息之外,还需要知道轨迹的变化趋势。我们可以用黑线位

置的微分值来提前得到变化趋势。用本次位置减去前次位置求出差值,就大致知道偏移量的变

化趋势。将该差值和比例相加后一起作为控制量,即可实现提前控制。这就叫做比例微分控制

(PD控制)

/*PID(PD)控制算法*/

int PID_Control(signed char Position)

{

int Temp_P,Temp_D,Temp_PID,Temp_I,k; //声明三个变量,用于存放P、I、D三分量

的运算结果(I没用上)

if(Position==-128) return (No_black); //错误处理(值得改进的地方)

else

--完整版学习资料分享----

-----WORD格式--可编辑--专业资料-----

{

Temp_I=Position;

for(k=0;k<5;k++)Temp_I+=Last_Position[k];

Temp_I*=I_coefficient;

Temp_P=P_coefficient*Position; //计算比例分量(P)=比例系数*本次位置差

Temp_D=D_coefficient*(Position-Last_Position[5]); //计算微分分量(D)=微分系

数*(本次位置差-前3次的位置差)

//注意由于采样比较快,用本次位置-前3次位置才有足

够大的控制量

Last_Position[6]=Last_Position[5];

Last_Position[4]=Last_Position[3];

Last_Position[3]=Last_Position[2];

Last_Position[2]=Last_Position[1];

Last_Position[1]=Last_Position[0];

Last_Position[0]=Position; /*保存前5次的位置,以备用。

--完整版学习资料分享----

发布评论

评论列表 (0)

  1. 暂无评论