基本信息
源码名称:PID控制算法的C语言实现(完整版)
源码大小:0.42M
文件格式:.rar
开发语言:C/C++
更新时间:2019-07-29
友情提示:(无需注册或充值,赞助后即可获取资源下载链接)
嘿,亲!知识可是无价之宝呢,但咱这精心整理的资料也耗费了不少心血呀。小小地破费一下,绝对物超所值哦!如有下载和支付问题,请联系我们QQ(微信同号):813200300
本次赞助数额为: 2 元×
微信扫码支付:2 元
×
请留下您的邮箱,我们将在2小时内将文件发到您的邮箱
源码介绍
float PID_realize(float speed){
float index;
pid.SetSpeed=speed;
pid.err=pid.SetSpeed-pid.ActualSpeed;
if(abs(pid.err)>200) //变积分过程
{
index=0.0;
}else if(abs(pid.err)<180){
index=1.0;
pid.integral =pid.err;
}else{
index=(200-abs(pid.err))/20;
pid.integral =pid.err;
}
pid.voltage=pid.Kp*pid.err index*pid.Ki*pid.integral pid.Kd*(p
id.err-pid.err_last);
pid.err_last=pid.err;
pid.ActualSpeed=pid.voltage*1.0;
return pid.ActualSpeed;
}
该文件里面还有各种改进的PID的算法,比如变积分控制等
具体 PID 实现代码如下:
pid.Kp=0.4;
pid.Ki=0.2; | //增加了积分系数 |
pid.Kd=0.2; |
float PID_realize(float speed){
float index;
pid.SetSpeed=speed;
pid.err=pid.SetSpeed-pid.ActualSpeed;
if(abs(pid.err)>200) //变积分过程
{
index=0.0;
}else if(abs(pid.err)<180){
index=1.0;
pid.integral =pid.err;
}else{
index=(200-abs(pid.err))/20;
pid.integral =pid.err;
}
pid.voltage=pid.Kp*pid.err index*pid.Ki*pid.integral pid.Kd*(p
id.err-pid.err_last);
pid.err_last=pid.err;
pid.ActualSpeed=pid.voltage*1.0;
return pid.ActualSpeed;
}