PID-C语言实现

#include <stdio.h>

typedef struct {
    float Kp;           // 比例增益
    float Ki;           // 积分增益
    float Kd;           // 微分增益
    float previous_error; // 上一次的误差值,用于计算微分
    float integral;       // 积分累积量
    float output_limit;   // 输出限幅
} PID_Controller;




void PID_Init(PID_Controller *pid, float Kp, float Ki, float Kd, float output_limit) {
    pid->Kp = Kp;
    pid->Ki = Ki;
    pid->Kd = Kd;
    pid->previous_error = 0.0f;
    pid->integral = 0.0f;
    pid->output_limit = output_limit;
}



float PID_Update(PID_Controller *pid, float setpoint, float measured_value, float dt) {
    // 计算当前误差
    float error = setpoint - measured_value;

    // 比例项
    float proportional = pid->Kp * error;

    // 积分项(累积误差)
    pid->integral += error * dt;
    float integral = pid->Ki * pid->integral;

    // 微分项(误差变化率)
    float derivative = pid->Kd * (error - pid->previous_error) / dt;

    // 计算总输出
    float output = proportional + integral + derivative;

    // 更新上一次误差
    pid->previous_error = error;

    // 输出限幅,防止过大
    if (output > pid->output_limit) {
        output = pid->output_limit;
    } else if (output < -pid->output_limit) {
        output = -pid->output_limit;
    }

    return output;
}

powered by GPT-4o

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值