有关温度控制pid参数的问题

2019-07-15 17:43发布

用交流电220v加热铜板  控制温度在32度   上下波动不超过0.05度,想通过pid调节pwm占空比(低电平就加热,高电平不加热)来控制功率。   

程序重要参数说明     设定温度3200   放大一百倍
pwm加热是半波加热(由于目标温度较小 防止超调)
0--3000期间 不pid调节
3000--3200 期间 调节占空比。
pid程序为增量式pid


问题:温度在32度上下波动 幅度为0.15左右      具体哪里出问题   请高人指教
#define Kp 75 //比例系数
#define Ki 130 //积分系数
#define Kd 30 //微分系数
int Real_temp;  //实际温度值
int Set_temp;  //设置温度

uchar last_error;  //上次误差
float I_term;  //前面温差和
int PID_MAX=12800;   //
unsigned int out,PWMT,counter;

void PWM0_set (unsigned char a)
{
CCAP0L= a; //设置值直接写入CCAP0L
  CCAP0H= a; //设置值直接写入CCAP0H
}
int PID(int Set_value,int Real_value) //标准PID温度控制算法
{
int error;
float P_term, D_term;
int pid_out;

error=Set_value - Real_value;//误差量
  if(error<200)
  {
  P_term =Kp*error; //比例量
  I_term+=Ki*error; //积分量
  if(I_term>PID_MAX) I_term=PID_MAX; //限定积分量上限
  else if(I_term<0) I_term=0;   //限定积分量下限

  D_term =Kd*(error - last_error);  //微分量
  last_error=error; //缓存当前误差量
  if(error<20)  I_term=130;
  else I_term=0;
  pid_out=(signed int)(P_term+I_term+D_term); //PID控制量计算
  
  if(pid_out>PID_MAX) pid_out=PID_MAX;  //控制量上限=PID_MAX
  else if(pid_out<0) pid_out=0;    //控制量下限=0
  //return(pid_out);
  }
  else if(error>=200) pid_out=12800;
   
  return(pid_out);
   
}
void jiare_pid_kongzhi()
{
PWMT=12800;   //128级步进PWM控制  
PID_MAX=PWMT;
counter=0;
out=0;
I_term=0;
last_error=0;
Set_temp=3200;  //初始设定温度为32度
Real_temp=wenduzhi;
out=PID(Set_temp,Real_temp);  //PID程序
PWM0_set(12+out/100);
}
  

友情提示: 此问题已得到解决,问题已经关闭,关闭后问题禁止继续编辑,回答。