单片机
返回首页

增量式PID算法在c代码部分的实现过程

2024-06-27 来源:elecfans

下经常会用到对温度控制,适度控制,转速控制等需要自动控制相关的操作,因此在使用中需要不断提高对自动控制 原理部分的学习,一个好的自动控制系统包含三个 主要因素:稳,快,准。稳即系统的稳定性,快即系统的快速性,准即控制的准确性。


在自动控制中比例增益,积分时间,微分时间三个主要变量。下面就这三个变量进行动态展示。

动图

如上图所示,假设在单位阶跃响应下,比例控制幅值,kp越大值越高相关的,积分时间控制精确度,数值越大波形超调量越大,微分时间控制波形的平缓程度。


下面贴出增量式PID算法在c代码部分的实现过程。


//实现增量式PID算法 


#include 'stdio.h' 

void pid_init();//PID参数初始化 

float pid_realise(float speed);//实现PID算法   


struct {

    float set_speed;//设定速度 

    float actual_speed;//实际速度

    float error;//偏差  

    float error_next;//上一个偏差  

    float error_last;//上上一个偏差 

    float kp,ki,kd;//定义比例,积分,微分参数  

     

}pid;



int main()

{

    pid_init();

    int count = 0;

    while(count<400)//进行400次 PID 运算,使初始值从0开始接近200.0   

    {

        float speed = pid_realise(200.0);//设定值设定为200.0  

        printf('%fn',speed);//输出每一次PID 运算后的结果  

        count++;

    }

}



void pid_init()

{

    pid.set_speed = 0.0;

    pid.actual_speed = 0.0;

    pid.error = 0.0;

    pid.error_next = 0.0;

    pid.error_last = 0.0;

    //可调节PID 参数。使跟踪曲线慢慢接近阶跃函数200.0 // 

    pid.kp = 0.2;

    pid.ki = 0.01;

    pid.kd = 0.2;

}



float pid_realise(float speed)//实现pid  

{

    pid.set_speed = speed;//设置目标速度  

    pid.error = pid.set_speed - pid.actual_speed;

    float increment_speed;//增量

     

    increment_speed = pid.kp*(pid.error-pid.error_next)+pid.ki*pid.error+

    pid.kd*(pid.error-2*pid.error_next+pid.error_last);//增量计算公式  

    

    pid.actual_speed+= increment_speed;

    pid.error_last = pid.error_next;//下一次迭代  

    pid.error_next = pid.error;

    return pid.actual_speed; 

    

}


运行数据得到图标如下 :

poYBAGKqov2ALrgkAABTRApyEyM634.png

进入单片机查看更多内容>>
相关视频
  • RISC-V嵌入式系统开发

  • SOC系统级芯片设计实验

  • 云龙51单片机实训视频教程(王云,字幕版)

  • 2022 Digi-Key KOL 系列: 你见过1GHz主频的单片机吗?Teensy 4.1开发板介绍

  • TI 新一代 C2000™ 微控制器:全方位助力伺服及马达驱动应用

  • MSP430电容触摸技术 - 防水Demo演示

精选电路图
  • 简洁的过零调功器电路设计与分析

  • 单稳态控制电路设计与分析

  • 光控电路设计与分析

  • CCFL的工作原理及电子驱动电路解析

  • 开关电源的基本组成及工作原理

  • 基于M66T旋律发​​生器的电路图解析

    相关电子头条文章