智能车制作

 找回密码
 注册

扫一扫,访问微社区

查看: 15378|回复: 71
打印 上一主题 下一主题

形象解释PID算法+PID算法源代码

  [复制链接]

24

主题

603

帖子

1

精华

跨届大侠

西点君

Rank: 10Rank: 10Rank: 10

积分
8838

活跃会员奖章优秀会员奖章论坛元老奖章在线王奖章资源大师奖章

威望
3135
贡献
3875
兑换币
1580
注册时间
2011-5-9
在线时间
914 小时
跳转到指定楼层
1#
发表于 2012-12-21 19:38:52 | 只看该作者 回帖奖励 |正序浏览 |阅读模式
小明接到这样一个任务:
有一个水缸点漏水(而且漏水的速度还不一定固定不变),
要求水面高度维持在某个位置,
一旦发现水面高度低于要求位置,就要往水缸里加水。

小明接到任务后就一直守在水缸旁边,
时间长就觉得无聊,就跑到房里看小说了,
每30分钟来检查一次水面高度。水漏得太快,
每次小明来检查时,水都快漏完了,离要求的高度相差很远
,小明改为每3分钟来检查一次,结果每次来水都没怎么漏
,不需要加水,来得太频繁做的是无用功。几次试验后,
确定每10分钟来检查一次。这个检查时间就称为采样周期。

开始小明用瓢加水,水龙头离水缸有十几米的距离,
经常要跑好几趟才加够水,于是小明又改为用桶加,
一加就是一桶,跑的次数少了,加水的速度也快了,
但好几次将缸给加溢出了,不小心弄湿了几次鞋,小明又动脑筋,
我不用瓢也不用桶,老子用盆,几次下来,发现刚刚好,不用跑太多次,
也不会让水溢出。这个加水工具的大小就称为比例系数。

小明又发现水虽然不会加过量溢出了,有时会高过要求位置比较多
,还是有打湿鞋的危险。他又想了个办法,在水缸上装一个漏斗,
每次加水不直接倒进水缸,而是倒进漏斗让它慢慢加。这样溢出的问题解决了,
但加水的速度又慢了,有时还赶不上漏水的速度。
于是他试着变换不同大小口径的漏斗来控制加水的速度
,最后终于找到了满意的漏斗。漏斗的时间就称为积分时间 。

小明终于喘了一口,但任务的要求突然严了,
水位控制的及时性要求大大提高,一旦水位过低,
必须立即将水加到要求位置,而且不能高出太多,否则不给工钱。
小明又为难了!于是他又开努脑筋,终于让它想到一个办法,常放一盆备用水在旁边,
一发现水位低了,不经过漏斗就是一盆水下去,这样及时性是保证了,但水位有时会高多了。
他又在要求水面位置上面一点将水凿一孔,再接一根管子到下面的备用桶里这样多出的水会从上面的孔里漏出来。
这个水漏出的快慢就称为微分时间。


大学时代做机器人时用的PID算法源代码:
#define PID_Uint struct pid_uint
PID_Uint
{
        int U_kk;
        int ekk;
        int ekkk;
        int Ur;                                //限幅输出值,需初始化
        int Un;                                //不灵敏区
        //int multiple;                //PID系数的放大倍数,用整形数据的情况下,提高PID参数的设置精度          固定为256
        int Kp;                                //比例,从小往大调
        int Ti;                                //积分,从大往小调
        int Td;                                //微分,用巡线板时设为0
        int k1;                                //
        int k2;
        int k3;
};

/********************************************************************
函 数 名:void Init_PID_uint(PID_uint *p)
功    能:初始化PID参数
说    明:调用本函数之前,应该先对Kp,Ti,Td做设置        ,简化了公式
入口参数:PID单元的参数结构体 地址
返 回 值:无
***********************************************************************/
void Init_PID_uint(PID_Uint *p)
{
        p->k1=(p->Kp)+(p->Kp)*1024/(p->Ti)+(p->Kp)*(p->Td)/1024;
        p->k2=(p->Kp)+2*(p->Kp)*(p->Td)/1024;
        p->k3=(p->Kp)*(p->Td)/1024;
}
/********************************************************************
函 数 名:void reset_Uk(PID_Uint *p)
功    能:初始化U_kk,ekk,ekkk
说    明:在初始化时调用,改变PID参数时有可能需要调用
入口参数:PID单元的参数结构体 地址
返 回 值:无
***********************************************************************/
void reset_Uk(PID_Uint *p)
{
        p->U_kk=0;
        p->ekk=0;
        p->ekkk=0;
}
/********************************************************************
函 数 名:int PID_commen(int set,int jiance,PID_Uint *p)
功    能:通用PID函数
说    明:求任意单个PID的控制量
入口参数:期望值,实测值,PID单元结构体
返 回 值:PID控制量
***********************************************************************/
int PID_common(int set,int jiance,PID_Uint *p)
{
        int ek,U_k=0;
        ek=jiance-set;
        if((ek>(p->Un))||(ek<-(p->Un)))                //积分不灵敏区
                U_k=(p->U_kk)+(p->k1)*ek-(p->k2)*(p->ekk)+(p->k3)*(p->ekkk);
        p->U_kk=U_k;
           p->ekkk=p->ekk;
        p->ekk=ek;
        if(U_k>(p->Ur))                                        //限制最大输出量,
                U_k=p->Ur;
        if(U_k<-(p->Ur))
                U_k=-(p->Ur);        
        return U_k/1024;
}

评分

1

查看全部评分

1

主题

292

帖子

0

精华

跨届大侠

Rank: 10Rank: 10Rank: 10

积分
6297

优秀会员奖章活跃会员奖章论坛元老奖章

威望
4366
贡献
1319
兑换币
617
注册时间
2012-12-2
在线时间
306 小时
72#
发表于 2014-8-8 08:44:57 | 只看该作者
厉害
回复 支持 反对

使用道具 举报

10

主题

197

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1791
威望
892
贡献
575
兑换币
590
注册时间
2013-5-23
在线时间
162 小时
71#
发表于 2014-4-18 08:04:00 | 只看该作者
好屌啊
回复 支持 反对

使用道具 举报

45

主题

254

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
2291
威望
1228
贡献
653
兑换币
698
注册时间
2014-1-22
在线时间
205 小时
毕业学校
高中
70#
发表于 2014-4-6 14:46:35 | 只看该作者
十分形象
回复 支持 反对

使用道具 举报

4

主题

114

帖子

0

精华

高级会员

Rank: 4

积分
828
威望
444
贡献
232
兑换币
260
注册时间
2014-3-1
在线时间
76 小时
毕业学校
dd
69#
发表于 2014-3-20 20:32:50 | 只看该作者
哈哈 好形象
回复 支持 反对

使用道具 举报

0

主题

1

帖子

0

精华

注册会员

Rank: 2

积分
16
威望
12
贡献
4
兑换币
5
注册时间
2013-3-28
在线时间
0 小时
毕业学校
黄河科技学院
68#
发表于 2014-3-19 11:26:04 | 只看该作者
真的是很形象。
回复 支持 反对

使用道具 举报

1

主题

16

帖子

0

精华

高级会员

Rank: 4

积分
833
威望
423
贡献
266
兑换币
279
注册时间
2013-11-1
在线时间
72 小时
67#
发表于 2014-3-18 17:24:51 | 只看该作者
学习了
回复 支持 反对

使用道具 举报

0

主题

3

帖子

0

精华

注册会员

Rank: 2

积分
71
威望
43
贡献
14
兑换币
16
注册时间
2014-3-15
在线时间
9 小时
毕业学校
纳溪中学
66#
发表于 2014-3-17 23:52:06 | 只看该作者
菜鸟第一天看PID就有一个形象的理解,不错感谢楼主的分享。赞一个
回复 支持 反对

使用道具 举报

14

主题

158

帖子

0

精华

金牌会员

Rank: 6Rank: 6

积分
1509
威望
655
贡献
326
兑换币
410
注册时间
2014-2-24
在线时间
264 小时
毕业学校
河南科技大学
65#
发表于 2014-3-17 10:57:23 | 只看该作者
带上文档
回复 支持 反对

使用道具 举报

0

主题

287

帖子

0

精华

常驻嘉宾

Rank: 8Rank: 8

积分
3700
威望
1835
贡献
1149
兑换币
1179
注册时间
2013-11-3
在线时间
358 小时
毕业学校
哈工大(威海)
64#
发表于 2014-3-1 16:29:28 | 只看该作者
谢谢。。。。。。。。。。。
回复 支持 反对

使用道具 举报

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

本版积分规则

关于我们|联系我们|小黑屋|智能车制作 ( 黑ICP备2022002344号

GMT+8, 2024-12-29 01:02 , Processed in 0.203620 second(s), 39 queries , Gzip On.

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

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