pid.h 1.8 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748
  1. /*
  2. * Copyright (c) 2022 OpenLuat & AirM2M
  3. *
  4. * Permission is hereby granted, free of charge, to any person obtaining a copy of
  5. * this software and associated documentation files (the "Software"), to deal in
  6. * the Software without restriction, including without limitation the rights to
  7. * use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of
  8. * the Software, and to permit persons to whom the Software is furnished to do so,
  9. * subject to the following conditions:
  10. *
  11. * The above copyright notice and this permission notice shall be included in all
  12. * copies or substantial portions of the Software.
  13. *
  14. * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
  15. * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS
  16. * FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR
  17. * COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER
  18. * IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN
  19. * CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.
  20. */
  21. #ifndef __PID_H__
  22. #define __PID_H__
  23. #include "bsp_common.h"
  24. #define VAR_TYPE double
  25. typedef struct{
  26. VAR_TYPE Scope; //输出限幅量
  27. VAR_TYPE Target; //传感器目标输入量
  28. VAR_TYPE Measure; //测量到的实际输入量,每次测量后变更
  29. VAR_TYPE Kp;
  30. VAR_TYPE Ki;
  31. VAR_TYPE Kd;
  32. VAR_TYPE Sum; //累计误差
  33. VAR_TYPE e0; //当前误差
  34. VAR_TYPE e1; //上一次误差
  35. VAR_TYPE e2; //上上次误差
  36. }PID_VarType;
  37. /*
  38. * 增量PID,输出值是控制器输出量的增量
  39. */
  40. VAR_TYPE PID_IncrementalCal(PID_VarType *PIDVar);
  41. /*
  42. * 位置PID,输出值是控制器输出量
  43. */
  44. VAR_TYPE PID_PositionCal(PID_VarType *PIDVar);
  45. #endif