色哟哟视频在线观看-色哟哟视频在线-色哟哟欧美15最新在线-色哟哟免费在线观看-国产l精品国产亚洲区在线观看-国产l精品国产亚洲区久久

電子發(fā)燒友App

硬聲App

0
  • 聊天消息
  • 系統(tǒng)消息
  • 評論與回復
登錄后你可以
  • 下載海量資料
  • 學習在線課程
  • 觀看技術視頻
  • 寫文章/發(fā)帖/加入社區(qū)
會員中心
創(chuàng)作中心

完善資料讓更多小伙伴認識你,還能領取20積分哦,立即完善>

3天內(nèi)不再提示
創(chuàng)作
電子發(fā)燒友網(wǎng)>電子資料下載>嵌入式開發(fā)>STM32運用之自平衡小車的PID算法封裝-求加精

STM32運用之自平衡小車的PID算法封裝-求加精

2017-11-27 | rar | 1.3 MB | 次下載 | 免費

資料介紹

繼卡爾曼封裝之后推出第二個封裝,PID算法,這個其實比上個簡單多了下面貼出代碼
/**
??******************************************************************************
??* @file ???PID_Control.h
??* @author ?willieon
??* @version V0.1
??* @date ???January-2015
??* @brief ??PID控制算法頭文件
??* ???????????????????????定義結構體類型以及聲明函數(shù)
??* ???????????????????????#define IF_THE_INTEGRAL_SEPARATION ?0/1 ?為積分分離標志
??******************************************************************************
??**/
?
#ifndef __PID_CONTROL_H__
#define __PID_CONTROL_H__
?
#define IF_THE_INTEGRAL_SEPARATION ?0 ???
//#define IF_THE_INTEGRAL_SEPARATION ?1 ??//是否積分分離 ?0-不分離,1 -分離
?
typedef struct
{
????????double SetPoint; // 設定目標 Desired Value ??
????????double Proportion; // 比例常數(shù) Proportional Const
????????double Integral; // 積分常數(shù) Integral Const
????????double Derivative; // 微分常數(shù) Derivative Const ??
????????double LastError; // Error[-1]
????????double PrevError; // Error[-2]
????????double SumError; // Sums of Errors ?
}PID;
?
#if IF_THE_INTEGRAL_SEPARATION ???????????//是否積分分離預編譯開始
?
double PIDCalc(double NextPoint ,double SepLimit, PID *pp); ??//帶積分分離的PID運算
?
#else
?
double PIDCalc( double NextPoint, PID *pp); ????//不帶積分分離的PID運算
?
#endif ???????//是否積分分離預編譯結束
?
void PIDInit (double SetPoint, double Proportion, double Integral, double Derivative, PID *pp);
?
#endif
/**
??******************************************************************************
??* @file ???PID_Control.c
??* @author ?willieon
??* @version V0.1
??* @date ???January-2015
??* @brief ??PID控制算法函數(shù)代碼
??* ???????
??*
??******************************************************************************
??**/
?
#include "PID_Control.h"
#include "math.h"
?
/*************************************************************************************
* ???????名 ???稱: double PIDCalc( PID *pp, double NextPoint ,double SepLimit)
* ???????功 ???能: PID控制運算
* ???????入口參數(shù): PID *pp ?- 定義的運算所需變量的結構體
* ??????????????????????????NextPoint - 負反饋輸入值
* ??????????????????????????SepLimit ?- 積分分離上限
* ???????出口參數(shù): 返回PID控制量
* ???????說 ???明: 默認不進行積分分離,如果用戶需要使用積分分離,需在PID_Control.h中
* ???????????????????????????????將 #define IF_THE_INTEGRAL_SEPARATION ?0 ?改為
* ???????????????????????????#define IF_THE_INTEGRAL_SEPARATION ?1
* ???????調(diào)用方法: 進行積分分離時入口參數(shù)為3個,具體方法如下:
* ???????????????????????????????PID PIDControlStruct ; ??//定義PID運算結構體
* ???????????????????????????????PIDInit(50, 0.24, 0.04, 0.2, &PIDControlStruct);//結構體初始化,注意&符號不能省
* ???????????????????????????????ControlData = PIDCalc(ReadData, 200, &PIDControlStruct); ??//控制量 = PIDCalc(反饋值,積分分離上限,PID運算結構體)
*
***************************************************************************************
*/
?
#if IF_THE_INTEGRAL_SEPARATION
?
double PIDCalc(double NextPoint ,double SepLimit, PID *pp)
{
????????double dError, Error,Flag; ??
????????Error = pp->SetPoint - NextPoint; ????????// 偏差
????????if(abs(Error) > SepLimit) ???????//當偏差大于分離上限積分分離
????????{
????????????????Flag = 0;
????????}
????????else ??????//當偏差小于分離上限,積分項不分離
????????{
????????????????Flag = 1;
????????????????pp->SumError += Error; ????????// 積分 ?
????????}
????????dError = pp->LastError - pp->PrevError; ????????// 當前微分
????????pp->PrevError = pp->LastError;
????????pp->LastError = Error; ?
????????return (
????????????????pp->Proportion ???????????????* ???????????????Error ????????????????// 比例項
????????????????+ Flag * pp->Integral ???????* ???????????????pp->SumError ????????// 積分項
????????????????+ pp->Derivative ???????????????* ???????????????dError ????????????????// 微分項
????????????????);
}
?
#else
?
double PIDCalc( double NextPoint, PID *pp)
{ ?
????????double dError, Error; ??
????????Error = pp->SetPoint - NextPoint; ????????????????????????// 偏差
????????pp->SumError += Error; ???????????????????????????????????????// 積分 ?
????????dError = pp->LastError - pp->PrevError; ???????????????// 當前微分
????????pp->PrevError = pp->LastError;
????????pp->LastError = Error; ?
????????return (pp->Proportion ???????* ???????Error ???????????????// 比例項
????????????????+ pp->Integral ???????????????* ???????pp->SumError ????????// 積分項
????????????????+ pp->Derivative ???????* ???????dError ????????// 微分項
????????????????);
}
?
#endif
?
?
/*************************************************************************************
* ???????名 ???稱: double PIDCalc( PID *pp, double NextPoint ,double SepLimit)
* ???????功 ???能: PID初始化設定
* ???????入口參數(shù): PID *pp ?- 定義的運算所需變量的結構體
* ??????????????????????????SetPoint - 設定的目標值
* ??????????????????????????Proportion,Integral ,Derivative - P,I,D系數(shù)
* ???????出口參數(shù): 無
* ???????說 ???明: ???????
* ???????調(diào)用方法: ?PID PIDControlStruct ; ??//定義PID運算結構體
* ???????????????????????????????PIDInit(50, 0.24, 0.04, 0.2, &PIDControlStruct);//結構體初始化,注意&符號不能省
* ???????????????????????????????因為函數(shù)需要傳入一個指針,需要對結構體取首地址傳給指針
*
***************************************************************************************
*/
?
?
void PIDInit (double SetPoint, double Proportion, double Integral, double Derivative, PID *pp)
{ ?
????????pp -> SetPoint = SetPoint; // 設定目標 Desired Value ??
????????pp -> Proportion = Proportion; // 比例常數(shù) Proportional Const
????????pp -> Integral = Integral; // 積分常數(shù) Integral Const
????????pp -> Derivative = Derivative; // 微分常數(shù) Derivative Const ??
????????pp -> LastError = 0; // Error[-1]
????????pp -> PrevError = 0; // Error[-2]
????????pp -> SumError = 0; // Sums of Errors
?
????????//memset ( pp,0,sizeof(struct PID)); ??//need include "string.h"
}
  將前篇 卡爾曼 和本次的 PID放在一起,在VS2010平臺中調(diào)試 代碼如下
#include "kalman.h"
?
#include "stdio.h"
#include "stdlib.h"
#include "PID_Control.h"
?
void main(void)
?
{
????????KalmanCountData k;
????????PID PIDControlStruct;
????????Kalman_Filter_Init(&k);
????????PIDInit(50, 1, 0.04, 0.2, &PIDControlStruct);
????????int m,n;
?
????????double out;
?
????????for(int a = 0;a<80;a++)
????????{
????????????????m = 1+ rand() %100;
????????????????n = 1+ rand() %100;
????????????????Kalman_Filter((float)m,(float)n,&k);
????????????????out = PIDCalc(k.Angle_Final, &PIDControlStruct);
????????????????printf("%3d and %3d is %6f -pid- %6f\r\n",m,n,k.Angle_Final,out);
?
????????}
}
?
下載該資料的人也在下載 下載該資料的人還在閱讀
更多 >

評論

查看更多

下載排行

本周

  1. 1TC358743XBG評估板參考手冊
  2. 1.36 MB  |  330次下載  |  免費
  3. 2開關電源基礎知識
  4. 5.73 MB  |  6次下載  |  免費
  5. 3100W短波放大電路圖
  6. 0.05 MB  |  4次下載  |  3 積分
  7. 4嵌入式linux-聊天程序設計
  8. 0.60 MB  |  3次下載  |  免費
  9. 5基于FPGA的光纖通信系統(tǒng)的設計與實現(xiàn)
  10. 0.61 MB  |  2次下載  |  免費
  11. 6基于FPGA的C8051F單片機開發(fā)板設計
  12. 0.70 MB  |  2次下載  |  免費
  13. 751單片機窗簾控制器仿真程序
  14. 1.93 MB  |  2次下載  |  免費
  15. 8基于51單片機的RGB調(diào)色燈程序仿真
  16. 0.86 MB  |  2次下載  |  免費

本月

  1. 1OrCAD10.5下載OrCAD10.5中文版軟件
  2. 0.00 MB  |  234315次下載  |  免費
  3. 2555集成電路應用800例(新編版)
  4. 0.00 MB  |  33564次下載  |  免費
  5. 3接口電路圖大全
  6. 未知  |  30323次下載  |  免費
  7. 4開關電源設計實例指南
  8. 未知  |  21548次下載  |  免費
  9. 5電氣工程師手冊免費下載(新編第二版pdf電子書)
  10. 0.00 MB  |  15349次下載  |  免費
  11. 6數(shù)字電路基礎pdf(下載)
  12. 未知  |  13750次下載  |  免費
  13. 7電子制作實例集錦 下載
  14. 未知  |  8113次下載  |  免費
  15. 8《LED驅(qū)動電路設計》 溫德爾著
  16. 0.00 MB  |  6653次下載  |  免費

總榜

  1. 1matlab軟件下載入口
  2. 未知  |  935054次下載  |  免費
  3. 2protel99se軟件下載(可英文版轉(zhuǎn)中文版)
  4. 78.1 MB  |  537796次下載  |  免費
  5. 3MATLAB 7.1 下載 (含軟件介紹)
  6. 未知  |  420026次下載  |  免費
  7. 4OrCAD10.5下載OrCAD10.5中文版軟件
  8. 0.00 MB  |  234315次下載  |  免費
  9. 5Altium DXP2002下載入口
  10. 未知  |  233046次下載  |  免費
  11. 6電路仿真軟件multisim 10.0免費下載
  12. 340992  |  191185次下載  |  免費
  13. 7十天學會AVR單片機與C語言視頻教程 下載
  14. 158M  |  183278次下載  |  免費
  15. 8proe5.0野火版下載(中文版免費下載)
  16. 未知  |  138040次下載  |  免費
主站蜘蛛池模板: 国产精品嫩草免费视频| 偷拍亚洲制服另类无码专区| 5g天天影院天天看天天爽| 免费观看久久| 高h 纯肉文| 亚洲中文无码AV在线观看| 免费A级毛片无码鲁大师| 大胸美女脱内衣黄网站| 亚洲国产精品久久精品成人网站| 老司机福利视频一区在线播放| adc网址在线观看| 微福利92合集| 久久亚洲黄色| 国产成人自产拍免费视频| 夜色爽爽爽久久精品日韩| 鸥美一级黄色片| 黄色a三级三级三级免费看| 99日精品欧美国产| 亚洲国产AV精品一区二区蜜芽| 嗯啊快停下我是你老师啊H | 亚洲黄色网页| 免费人成网站在线观看10分钟| 国产扒开美女双腿屁股流白浆| 伊人网综合| 无码99久热只有精品视频在线| 蜜桃日本免费观看MV| 国产亚洲人成在线视频| 99视频福利| 亚洲日韩成人| 色情www日本欧美| 美女被日出水| 牛牛精品专区在线| 国产精品一区二区欧美视频| 99热最新在线| 一个人在线观看的视频| 忘忧草在线社区WWW日本直播| 欧美hdxxxx| 久久人人爽人人片AV人成| 国产精品伊人| 成人亚洲视频在线观看| 2021全国精品卡一卡二|