现在有了AI , 这些算法不用死记硬背了 稍微修改下 就可以用, 主要精力可以放在KP KI KD的整定上,
下面这部分是AI做的, 直接调用, 就行, 在结构体对PID初始化的时候填入整定好的参数即可运行; 但是AI也不是完全准确,他只对共用算法很准确,对STC的单片机就有点问题, PWM部分需要自己重写,
/********************* PID计算函数 *********************/
float PID_Compute(PID_Controller *pid, float setpoint, float input) {
float error = setpoint - input; //声明误差变量
float Pout; //声明比例变量
float Iout; //声明积分变量
float Dout; //声明微分变量
// 死区处理(误差小于0.3℃时不调节)
if(fabs(error) < 0.3) {
error = 0;
}
// 比例项
Pout = pid->Kp * error;
// 积分项(抗积分饱和)
pid->integral += pid->Ki * error;
if(pid->integral > pid->out_max) pid->integral = pid->out_max;
else if(pid->integral < pid->out_min) pid->integral = pid->out_min;
Iout = pid->integral;
// 微分项
Dout = pid->Kd * (error - pid->prev_error);
pid->prev_error = error; // 保存误差用于下次计算
// 计算输出PID
pid->output = Pout + Iout + Dout;
// 输出限幅
if(pid->output > pid->out_max) pid->output = pid->out_max;
else if(pid->output < pid->out_min) pid->output = pid->out_min;
return pid->output;
} |