久久久久久久999_99精品久久精品一区二区爱城_成人欧美一区二区三区在线播放_国产精品日本一区二区不卡视频_国产午夜视频_欧美精品在线观看免费

 找回密碼
 立即注冊

QQ登錄

只需一步,快速開始

搜索
查看: 3459|回復: 2
打印 上一主題 下一主題
收起左側

飛思卡爾控制電機PID算法代碼解析

[復制鏈接]
跳轉到指定樓層
樓主
ID:257741 發表于 2017-12-9 22:11 | 只看該作者 回帖獎勵 |倒序瀏覽 |閱讀模式
PID實指“比例proportional”、“積分integral”、“微分derivative” , 這三項構成PID基本要素。每一項完成不同任務對系統功能產生不同的影響。 搞軟件的往往對硬件不屑 ,卻忘了軟件再牛B也是為硬件服務的 , PID的數字化算法就完全是為硬件而生的 , 這是控制電機算法的一個難點 , 沒有一定的對軟硬件的理解 , 就連調試裝定PID參數都會很為難 ! 飛思卡爾智能車項目里面就會用到PID算法 , 比如車爬坡和平地連續拐彎時 , 代碼里面沒有PID算法 , 控制和驅動起來就會很拙急 , 對不對 ? 不過 ,搞清楚問題還是有個前提的 , 那就是懂點微積分 , 不會微積分嘛 , 下面的內容無需關注

實際上 , PID算法的應用基礎始于對PCB板上的運放的PID參數進行調校 , P對應于運放增益  ; I 就是運放輸入和輸出端之間接一個電容引入反饋 , 就是控制器的輸出與輸入誤差會積累起來影響輸出 ;  D 就是運放輸入端串接一個電容 ,起的微分作用是阻止輸出與輸入誤差的變化 .  結合示波器來觀察控制電機的PID參數設定的話 , 網上有一首詩 , 它就代表我的心聲了 :

參數整定找最佳,從小到大順序查
先是比例后積分,最后再把微分加
曲線振蕩很頻繁,比例度盤要放大
曲線漂浮繞大灣,比例度盤往小扳
曲線偏離回復慢,積分時間往下降
曲線波動周期長,積分時間再加長
曲線振蕩頻率快,先把微分降下來
動差大來波動慢,微分時間應加長
理想曲線兩個波,前高后低四比一
一看二調多分析,調節質量不會低 !


下面貼段代碼 (真的是僅供參考):
  1.     #include <mc9s12dg128.h> /* derivative information */
  2.     /*******************************************************************
  3.     * 宏定義
  4.     **********************************************************************************/
  5.     #define STABMAX 50
  6.     #define SENSORNUM 8
  7.     #define SAMPLETIMES 5
  8.     /********************************************************************
  9.     FUNCTION PROTOTYPES
  10.     ********************************************************************/
  11.     int CalculateP(void);
  12.     float CalculatePID(void);
  13.     /********************************** PID控制程序 *******************/
  14.     struct CARSTATE
  15.     {
  16.     int E0;
  17.     int E1;
  18.     int E2;
  19.     int E3;
  20.     float Integral;
  21.     }CarState;
  22.     /*
  23.     ********************************************************************
  24.     * 初始化PID參數
  25.     ********************************************************************/
  26.     void Init_PID()
  27.     {
  28.     CarState.E0 = 0;
  29.     CarState.E1 = 0;
  30.     CarState.E2 = 0;
  31.     CarState.E3 = 0;
  32.     CarState.Integral = 0;
  33.     }
  34.     /*
  35.     ********************************************************************
  36.     * 信號處理函數
  37.     * 程序描述: 對傳感器采集過來的數據進行處理,得到一些基本的計算參數

  38.     ********************************************************************/
  39.     int SignalProcess( unsigned int signal )
  40.     {
  41.     const int BitValue[8] = {43,26,12,6,-6,-12,-26,-43}; //MAX:28
  42.     int i,CurrPoint=0,LastPoint=0,BitNum=0;
  43.     unsigned char SignalBit[8];
  44.     for(i=0;i<8;i++)
  45.     {
  46.     SignalBit = signal & 0x0001;
  47.     BitNum += SignalBit;
  48.     signal >>= 1;
  49.     }
  50.     switch(BitNum)
  51.     {
  52.     case 1:
  53.     for(i=0;i<8;i++)
  54.     if(SignalBit != 0)
  55.     CurrPoint += BitValue;
  56.     CarState.E0 = CurrPoint;
  57.     break;
  58.     case 2:
  59.     for(i=0;i<8;i++)
  60.     if(SignalBit != 0)
  61.     CurrPoint += BitValue;
  62.     CurrPoint >>= 1;
  63.     CarState.E0 = CurrPoint;
  64.     break;
  65.     default:
  66.     CarState.E0 = CarState.E1;
  67.     break;
  68.     }
  69.     return CalculateP()*100;
  70.     }
  71.     /*******************************************************************
  72.     * PID計算函數

  73.     * 程序描述: 計算P參數

  74.     ********************************************************************/
  75.     int CalculateP(void)
  76.     {
  77.     CarState.E1 = CarState.E0;
  78.     return((int)CarState.E0);
  79.     }

  80.     /*
  81.     ***********************************************************************************
  82.     * PID計算函數
  83.     *
  84.     * 程序描述: 對傳感器采集過來的數據進行處理,得到一些基本的計算參數
  85.     *
  86.     ******************************************************************* ***************/
  87.     float CalculatePID(void)
  88.     {
  89.     float P, I = 0, D;
  90.     /* parameter const */
  91.     float Kp = 1.0, Ki = -0.0002, Kd = -0.0002;
  92.     /* P parameter */
  93.     P = CarState.E0 * Kp;
  94.     /* I parameter */
  95.     if(P+I<2)
  96.     {
  97.     CarState.Integral += Ki * CarState.E0;
  98.     I = CarState.Integral;
  99.     }
  100.     /* D parameter */
  101.     D = Kd * ( CarState.E0 + 3*CarState.E1 - 3*CarState.E2 - CarState.E3 )/6.0;
  102.     CarState.E3 = CarState.E2;
  103.     CarState.E2 = CarState.E1;
  104.     CarState.E1 = CarState.E0;
  105.     return (P+I+D);
  106.     }
復制代碼



分享到:  QQ好友和群QQ好友和群 QQ空間QQ空間 騰訊微博騰訊微博 騰訊朋友騰訊朋友
收藏收藏 分享淘帖 頂 踩
回復

使用道具 舉報

沙發
ID:242544 發表于 2018-1-8 16:16 | 只看該作者
不錯。很實用
回復

使用道具 舉報

板凳
ID:242544 發表于 2018-1-8 16:17 | 只看該作者
不錯,很實用
回復

使用道具 舉報

您需要登錄后才可以回帖 登錄 | 立即注冊

本版積分規則

手機版|小黑屋|51黑電子論壇 |51黑電子論壇6群 QQ 管理員QQ:125739409;技術交流QQ群281945664

Powered by 單片機教程網

快速回復 返回頂部 返回列表
主站蜘蛛池模板: 亚洲人成人一区二区在线观看 | 精品视频一区二区 | 国产精品亚洲精品久久 | 欧美嘿咻 | 91人人在线 | 精品在线观看一区 | 国产成人短视频在线观看 | 成人黄在线观看 | 精品自拍视频在线观看 | 天堂一区二区三区 | 日韩在线不卡视频 | 密色视频 | 亚洲精品电影网在线观看 | 午夜男人视频 | 黄视频欧美 | 欧美精品一区二区三区在线播放 | 中文在线一区二区 | 精品视频一区二区三区 | 亚洲成人一区二区 | 欧美中文字幕 | 在线亚洲人成电影网站色www | 久久一区二区免费视频 | 在线亚州| 国产综合精品一区二区三区 | 福利国产| 久久视频精品 | 国产伦精品一区二区三区高清 | 日韩视频三区 | 午夜精品一区二区三区免费视频 | 亚洲一二三区免费 | 欧美一级大片免费观看 | 国产露脸国语对白在线 | 日韩av一区二区在线观看 | 国产91丝袜在线18 | 日韩毛片中文字幕 | 欧美精品一区二区三区四区五区 | 国产激情在线 | 日日摸天天添天天添破 | 国产精品福利网站 | 国产一区二区三区在线 | 国产亚洲精品美女久久久久久久久久 |