bsp_PID.cpp
D:/gitt/MicrochipFor32/bsp_Device/bsp_PID.cpp
浏览该文件的文档.00001 /*----------------------------------------------------------------------------------------------------
00002 #
00003 # Copyright (c) 2022 Yuankang Liang(XerolySkinner)
00004 #
00005 # 本软件按原样提供,无任何明示或暗示
00006 # 在任何情况下,作者都不承担任何损害赔偿责任
00007 #
00008 # 使用的许可声明:
00009 # 1. 不得歪曲本软件的来源,你不能声称你编写了原始软件.
00010 # 2. 免费授予以任何目的,前提是版权声明出现在所有副本中.
00011 # 并且版权声明和许可声明同时出现.
00012 # 3. 你有使用,复制,修改,分发,和销售本软件的许可.
00013 # 4. 如果你在产品中使用,产品文档中的声明是赞赏的但不是必须的.
00014 # 5. 本通知不得从任何来源删除或更改.
00015 #
00016 # Yuankang Liang(XerolySkinner)
00017 # E-mail:zabbcccbbaz@163.com
00018 # QQ:2715099320
00019 # Mobile Phone:13005636215
00020 #
00021 # All rights reserved.
00022 */
00023
00035 //----------------------------------------------------------------------------------------------------
00036 // 头文件
00037 //
00038 #include "bsp_PID.h"
00040 //----------------------------------------------------------------------------------------------------
00041 // 类函数
00042 //
00048 float bsp_Position_PID::PID(float temp) {
00049 float thisError;
00050 thisError = target - temp; //当前误差等于设定值减去当前值
00051 integral += thisError; //误差积分,把所有误差累加起来
00052 result =
00053 Kp * thisError +
00054 Ki * integral +
00055 Kd * (thisError - lasterror);
00056 lasterror = thisError;
00057
00058 if (result_H == result_L)return result;
00059 if (result >= result_H)result == result_H;
00060 else if (result <= result_L)result == result_L;
00061 return result;
00062 }
00063 //----------------------------------------------------------------------------------------------------
00069 float bsp_Increment_PID::PID(float temp) {
00070 float thisError=target - temp; //当前误差等于设定值减去当前值
00071 float increment;
00072 float pError, dError, iError;
00073
00074 pError = thisError - lasterror;
00075 iError = thisError;
00076 dError = thisError - 2 * lasterror + preerror;
00077
00078 increment =
00079 Kp * pError +
00080 Ki * iError +
00081 Kd * dError; //增量计算
00082 preerror = lasterror; //存放偏差用于下次运算
00083 lasterror = thisError; //存放偏差用于下次运算
00084 result += increment; //上次结果叠加增量
00085
00086 if (result_H == result_L)return result;
00087 if (result >= result_H)result == result_H;
00088 else if (result <= result_L)result == result_L;
00089 return result;}
00090 //----------------------------------------------------------------------------------------------------
00091 //----------------------------------------------------------------------------------------------------
00096 void bsp_Position_PID::clean(void) {
00097 integral = 0; //积分值
00098 lasterror = 0; //前一拍偏差
00099 result = 0; //输出值
00100 }
00101 //----------------------------------------------------------------------------------------------------
00106 void bsp_Increment_PID::clean(void) {
00107 lasterror = 0; //前一拍偏差
00108 preerror = 0; //前两拍偏差
00109 result = 0; //输出值
00110 }
00111 //----------------------------------------------------------------------------------------------------
00112 //----------------------------------------------------------------------------------------------------
00119 void bsp_Position_PID::set(float P, float I, float D) {
00120 Kp = P; Ki = I; Kd = D;}
00121 //----------------------------------------------------------------------------------------------------
00128 void bsp_Increment_PID::set(float P, float I, float D) {
00129 Kp = P; Ki = I; Kd = D;}
00131 //----------------------------------------------------------------------------------------------------
00132 // 构造函数
00133 //
00134 bsp_Position_PID::bsp_Position_PID(void) {
00135 bsp_Position_PID::target = 0;
00136 bsp_Position_PID::lasterror = 0;
00137 bsp_Position_PID::Kp = 0;
00138 bsp_Position_PID::Ki = 0;
00139 bsp_Position_PID::Kd = 0;
00140 bsp_Position_PID::integral = 0;
00141 bsp_Position_PID::result = 0;
00142 bsp_Position_PID::result_H = 0;
00143 bsp_Position_PID::result_L = 0;
00144 }
00145 //----------------------------------------------------------------------------------------------------
00155 bsp_Position_PID::bsp_Position_PID(
00156 float Kp, float Ki, float Kd, float target,
00157 float result_H, float result_L) {
00158 bsp_Position_PID::target = target;
00159 bsp_Position_PID::lasterror = 0;
00160 bsp_Position_PID::Kp = Kp;
00161 bsp_Position_PID::Ki = Ki;
00162 bsp_Position_PID::Kd = Kd;
00163 bsp_Position_PID::integral = 0;
00164 bsp_Position_PID::result = 0;
00165 bsp_Position_PID::result_H = 0;
00166 bsp_Position_PID::result_L = 0;
00167 }
00168 //----------------------------------------------------------------------------------------------------
00169 bsp_Position_PID::~bsp_Position_PID(void) {}
00170 //----------------------------------------------------------------------------------------------------
00171 bsp_Increment_PID::bsp_Increment_PID(void) {
00172 bsp_Increment_PID::target = 0;
00173 bsp_Increment_PID::lasterror = 0;
00174 bsp_Increment_PID::preerror = 0;
00175 bsp_Increment_PID::Kp = 0;
00176 bsp_Increment_PID::Ki = 0;
00177 bsp_Increment_PID::Kd = 0;
00178 bsp_Increment_PID::result = 0;
00179 bsp_Increment_PID::result_H = 0;
00180 bsp_Increment_PID::result_L = 0;
00181 }
00182 //----------------------------------------------------------------------------------------------------
00192 bsp_Increment_PID::bsp_Increment_PID(
00193 float Kp, float Ki, float Kd, float target,
00194 float result_H, float result_L) {
00195 bsp_Increment_PID::target = target;
00196 bsp_Increment_PID::lasterror = 0;
00197 bsp_Increment_PID::preerror = 0;
00198 bsp_Increment_PID::Kp = Kp;
00199 bsp_Increment_PID::Ki = Ki;
00200 bsp_Increment_PID::Kd = Kd;
00201 bsp_Increment_PID::result = 0;
00202 bsp_Increment_PID::result_H = 0;
00203 bsp_Increment_PID::result_L = 0;
00204 }
00205 //----------------------------------------------------------------------------------------------------
00206 bsp_Increment_PID::~bsp_Increment_PID(void) {}