QQ登录

只需要一步,快速开始

 注册地址  找回密码
查看: 1735|回复: 0
打印 上一主题 下一主题

【simulink进阶必备基础知识】——PID通俗教程、6

[复制链接]
字体大小: 正常 放大

3503

主题

538

听众

5990

积分

  • TA的每日心情
    开心
    2017-2-7 15:12
  • 签到天数: 691 天

    [LV.9]以坛为家II

    社区QQ达人 元老勋章 发帖功臣 新人进步奖 优秀斑竹奖 金点子奖 原创写作奖 最具活力勋章 助人为乐奖 风雨历程奖

    群组2013年国赛赛前培训

    群组2014年地区赛数学建模

    群组数学中国第二期SAS培训

    群组物联网工程师考试

    群组2013年美赛优秀论文解

    跳转到指定楼层
    1#
    发表于 2016-3-7 16:05 |只看该作者 |倒序浏览
    |招呼Ta 关注Ta
    增量式PID控制算法与位置式PID算法相比,计算量小得多,因此在实际中得到广泛的应用。
    位置式PID控制算法也可以通过增量式控制算法推出递推计算公式:

    就是目前在计算机控制中广泛应用的数字递推PID控制算法。

    下面是用C++实现的PID调节过程(只学过matlab和一点C的楼主表示压力很大,还是杀了我算了,同学们只做了解吧,以后有机会我会用simulink来演示它

    typedef struct PID
    {
    int SetPoint; //设定目标 Desired Value
    long SumError; //误差累计
    double Proportion; //比例常数 Proportional Const
    double Integral; //积分常数 Integral Const
    double Derivative; //微分常数 Derivative Const
    int LastError; //Error[-1]
    int PrevError; //Error[-2]
    } PID;


    static PID sPID;
    static PID *sptr = &sPID;
    /*====================================================================================================
    Initialize PID Structure PID参数初始化
    =====================================================================================================*/
    void IncPIDInit(void)
    {
    sptr->SumError = 0;
    sptr->LastError = 0; //Error[-1]
    sptr->PrevError = 0; //Error[-2]
    sptr->Proportion = 0; //比例常数 Proportional Const

    sptr->Integral = 0; //积分常数Integral Const
    sptr->Derivative = 0; //微分常数 Derivative Const
    sptr->SetPoint = 0;
    }

    /*====================================================================================================
    增量式PID计算部分
    =====================================================================================================*/

    int IncPIDCalc(int NextPoint)
    {
    register int iError, iIncpid; //当前误差
    iError = sptr->SetPoint - NextPoint; //增量计算
    iIncpid = sptr->Proportion * iError //E[k]
    - sptr->Integral * sptr->LastError //E[k
    + sptr->Derivative * sptr->PrevError; //E[k
    //存储误差,用于下次计算
    sptr->PrevError = sptr->LastError;
    sptr->LastError = iError;
    //返回增量值
    return(iIncpid);
    }

    zan
    转播转播0 分享淘帖0 分享分享0 收藏收藏0 支持支持0 反对反对0 微信微信
    您需要登录后才可以回帖 登录 | 注册地址

    qq
    收缩
    • 电话咨询

    • 04714969085
    fastpost

    关于我们| 联系我们| 诚征英才| 对外合作| 产品服务| QQ

    手机版|Archiver| |繁體中文 手机客户端  

    蒙公网安备 15010502000194号

    Powered by Discuz! X2.5   © 2001-2013 数学建模网-数学中国 ( 蒙ICP备14002410号-3 蒙BBS备-0002号 )     论坛法律顾问:王兆丰

    GMT+8, 2025-8-6 04:37 , Processed in 0.351935 second(s), 55 queries .

    回顶部