资源描述:
《对串级PID和单级PID的理解》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
1、对串级PID和单级PID的理解(基于匿名微型六轴)来源:本站
2、作者:小古
3、发表时间:2015-04-01
4、点击量:14145/********************(C)COPYRIGHT2014ANOTech****************************文件名:ANO_FlyControl.cpp*描述:飞行控制**********************************************************************************/include"ANO_FlyControl.h"ANO_FlyCont
5、rolfc;/*先整定内环,后整定外环。参数整定找最佳,从小到大顺序查先是比例后积分,最后再把微分加曲线振荡很频繁,比例度盘要放大曲线漂浮绕大湾,比例度盘往小扳曲线偏离回复慢,积分时间往下降曲线波动周期长,积分时间再加长曲线振荡频率快,先把微分降下来动差大来波动慢。微分时间应加长理想曲线两个波,前高后低4比1*//*ROLL和PIT轴向按照以上公式计算PID输出,但YAW轴比较特殊,因为偏航角法线方向刚好和地球重力平行,这个方向的角度无法由加速度计直接测得,需要增加一个电子罗盘来替代加速度计。如果不使用罗盘的话,我们可以单纯的通过角速度积分来测得偏航角,缺点是
6、由于积分环节中存在积分漂移,偏航角随着时间的推移会偏差越来越大。我们不使用罗盘就没有比例项,只仅使用微分环节来控制。*/ANO_FlyControl::ANO_FlyControl(){yawRate=120;//重置PID参数PID_Reset();}//重置PID参数voidANO_FlyControl:ID_Reset(void){//因为YAW角度会漂移,所以参数和ROLL、PITCH不一样pid[PIDROLL].set_pid(70,15,120,2000000);//ROLL角度的内环控制系数,20000:积分上限pid[PIDPITCH].se
7、t_pid(70,30,120,2000000);//PITCH角度的内环控制系数pid[PIDYAW].set_pid(100,50,0,2000000);//YAW角度的内环控制系数pid[PIDLEVEL].set_pid(280,0,0,0);//外环控制系数pid[PIDMAG].set_pid(15,0,0,0);//电子罗盘控制系数}/*【扫盲知识】串级PID:采用的角度P和角速度PID的双闭环PID算法------>角度的误差被作为期望输入到角速度控制器中(角度的微分就是角速度)对于本系统则采用了将角度控制与角速度控制级联的方式组成整个串级PI
8、D控制器。串级PID算法中,角速度内环占着极为重要的地位。在对四旋翼飞行的物理模型进行分析后,可以知道造成系统不稳定的物理表现之一就是不稳定的角速度。因此,若能够直接对系统的角速度进行较好的闭环控制,必然会改善系统的动态特性及其稳定性,通常也把角速度内环称为增稳环节。而角度外环的作用则体现在对四旋翼飞行器的姿态角的精确控制。外环:输入为角度,输出为角速度内环:输入为角速度,输出为PWM增量使用串级pid,分为:角度环控制pid环,和角速度控制环稳定环。主调为角度环(外环),副调为角速度环(内环)。参数整定原则为先内后外,故在整定内环时将外环的PID均设为0所谓
9、外环就是只是一个P在起作用,也就是比例在起作用;P也就是修正力度,越大越容易使飞机震荡。震荡的特点是:频率小、幅度大*//*【横滚(Roll)和俯仰(Pitch)的控制算法】横滚(Roll)和俯仰(Pitch)的控制算法是一样的,控制参数也比较接近。首先得到轴姿态的角度差(angleerror),将这个值乘以角度系数p后限幅(限幅必须有,否则剧烈打舵时容易引发震荡)作为角速度控制器期望值(target_rate)。target_rate与陀螺仪得到的当前角速度作差,得到角速度误差(rate_error)乘以kp得到P。在I值小于限幅值(这个值大概在5%油门)或
10、者rate_error与i值异号时将rate_error累加到I中。前后两次rate_error的差作为D项,值得注意的是加需要入20hz(也可以采用其它合适频率)滤波,以避免震荡。将P,I,D三者相加并限幅(50%油门)得到最终PID输出。*///串环PID调节详情参见:http://blog.csdn.net/super_mic...36723//飞行器姿态外环控制voidANO_FlyControl::Attitude_Outter_Loop(void){int32_terrorAngle[2];Vector3fGyro_ADC;//计算角度误差值,角度
11、误差值=期望值-此刻姿态值//cons