PID算法的简单C语言实现

#include <stdio.h>

typedef struct {
	float Target_value;  //目标值
	float Current_value;  //当前值
	float Err;  //目前误差
	float Last_Err;  //上一次误差
	float Kp,Ki,Kd;  //比例常数,积分常数,微分常数
	float output;  //PID输出,通常作为控制执行器的变量
	float integral;  //积分值
	
}PID_TypeDef;

PID_TypeDef PID;  //定义结构体变量

void PID_Init();
float PID_operation(float value);

int main(){
	freopen("E:\\PID_output.txt","w",stdout);  //重定向输出到文件
	PID_Init();  //PID初始化
	
	for(int i=1; i<=1000; i++){
		printf("%f\n",PID_operation(200.0));
	}
	return 0;
}

//初始化PID各项参数

void PID_Init(){
	
	PID.Target_value = 0.0;
	PID.Current_value = 0.0;
	PID.Err = 0.0;
	PID.Last_Err = 0.0;
	PID.output = 0.0;
	PID.integral = 0.0;
	PID.Kp = 0.2;  
	PID.Ki = 0.05;  
	PID.Kd = 0.2;     //比例常数,积分常数,微分常数的调整非常重要,这里的参数是经过几次试验得出的经验参数
}

//PID操作

float PID_operation(float value){
	
	PID.Target_value = value;  //确定目标值
	PID.Err = PID.Target_value - PID.Current_value;  //计算偏差量
	PID.integral += PID.Err;  //计算和
	
	PID.output = PID.Kp*PID.Err + PID.Ki*PID.integral + PID.Kd* (PID.Err-PID.Last_Err);  //PID运算
	
	PID.Last_Err = PID.Err;  //将当前误差值存入上一误差值
	PID.Current_value = PID.output*1.0;  //将当前值更新为PID的输出值
	
	return PID.Current_value;  //返回当前值
}

  • 1
    点赞
  • 23
    收藏
    觉得还不错? 一键收藏
  • 2
    评论
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值