James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 1 | #pragma once |
| 2 | |
| 3 | #include "controller.hpp" |
| 4 | #include "ec/pid.hpp" |
| 5 | #include "fan.hpp" |
| 6 | |
Andrew Geissler | e30916c | 2020-05-20 21:27:05 -0500 | [diff] [blame] | 7 | #include <limits> |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 8 | #include <memory> |
| 9 | #include <vector> |
| 10 | |
Patrick Venture | a076487 | 2020-08-08 07:48:43 -0700 | [diff] [blame] | 11 | namespace pid_control |
| 12 | { |
| 13 | |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 14 | class ZoneInterface; |
| 15 | |
| 16 | /* |
| 17 | * Base class for PID controllers. Each PID that implements this needs to |
Patrick Venture | 563a356 | 2018-10-30 09:31:26 -0700 | [diff] [blame] | 18 | * provide an inputProc, setptProc, and outputProc. |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 19 | */ |
| 20 | class PIDController : public Controller |
| 21 | { |
| 22 | public: |
| 23 | PIDController(const std::string& id, ZoneInterface* owner) : |
Nirav Shah | ccc8bb6 | 2022-02-17 21:06:51 -0800 | [diff] [blame] | 24 | Controller(), _owner(owner), _id(id) |
Harvey Wu | 22579ca | 2022-11-07 14:53:37 +0800 | [diff] [blame] | 25 | { |
| 26 | _pid_info.initialized = false; |
Delphine CC Chiu | 9788963 | 2023-11-06 11:32:46 +0800 | [diff] [blame] | 27 | _pid_info.checkHysterWithSetpt = false; |
Harvey Wu | 22579ca | 2022-11-07 14:53:37 +0800 | [diff] [blame] | 28 | _pid_info.ts = static_cast<double>(0.0); |
| 29 | _pid_info.integral = static_cast<double>(0.0); |
| 30 | _pid_info.lastOutput = static_cast<double>(0.0); |
| 31 | _pid_info.proportionalCoeff = static_cast<double>(0.0); |
| 32 | _pid_info.integralCoeff = static_cast<double>(0.0); |
Josh Lehan | 31058fd | 2023-01-13 11:06:16 -0800 | [diff] [blame] | 33 | _pid_info.derivativeCoeff = static_cast<double>(0.0); |
Harvey Wu | 22579ca | 2022-11-07 14:53:37 +0800 | [diff] [blame] | 34 | _pid_info.feedFwdOffset = static_cast<double>(0.0); |
| 35 | _pid_info.feedFwdGain = static_cast<double>(0.0); |
| 36 | _pid_info.integralLimit.min = static_cast<double>(0.0); |
| 37 | _pid_info.integralLimit.max = static_cast<double>(0.0); |
| 38 | _pid_info.outLim.min = static_cast<double>(0.0); |
| 39 | _pid_info.outLim.max = static_cast<double>(0.0); |
| 40 | _pid_info.slewNeg = static_cast<double>(0.0); |
| 41 | _pid_info.slewPos = static_cast<double>(0.0); |
| 42 | _pid_info.negativeHysteresis = static_cast<double>(0.0); |
| 43 | _pid_info.positiveHysteresis = static_cast<double>(0.0); |
| 44 | } |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 45 | |
Patrick Williams | 8c05112 | 2023-05-10 07:50:59 -0500 | [diff] [blame] | 46 | virtual ~PIDController() {} |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 47 | |
Patrick Venture | 5f59c0f | 2018-11-11 12:55:14 -0800 | [diff] [blame] | 48 | virtual double inputProc(void) override = 0; |
| 49 | virtual double setptProc(void) = 0; |
| 50 | virtual void outputProc(double value) override = 0; |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 51 | |
Patrick Venture | ee30648 | 2018-10-30 13:35:37 -0700 | [diff] [blame] | 52 | void process(void) override; |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 53 | |
Patrick Venture | ee30648 | 2018-10-30 13:35:37 -0700 | [diff] [blame] | 54 | std::string getID(void) override |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 55 | { |
| 56 | return _id; |
| 57 | } |
Patrick Venture | 5f59c0f | 2018-11-11 12:55:14 -0800 | [diff] [blame] | 58 | double getSetpoint(void) |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 59 | { |
| 60 | return _setpoint; |
| 61 | } |
Patrick Venture | 5f59c0f | 2018-11-11 12:55:14 -0800 | [diff] [blame] | 62 | void setSetpoint(double setpoint) |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 63 | { |
| 64 | _setpoint = setpoint; |
| 65 | } |
| 66 | |
Patrick Venture | 563a356 | 2018-10-30 09:31:26 -0700 | [diff] [blame] | 67 | ec::pid_info_t* getPIDInfo(void) |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 68 | { |
| 69 | return &_pid_info; |
| 70 | } |
| 71 | |
James Feist | 572c43d | 2019-01-31 15:52:22 -0800 | [diff] [blame] | 72 | double getLastInput(void) |
| 73 | { |
| 74 | return lastInput; |
| 75 | } |
| 76 | |
Delphine CC Chiu | 9788963 | 2023-11-06 11:32:46 +0800 | [diff] [blame] | 77 | double calPIDOutput(double setpt, double input, ec::pid_info_t* info); |
| 78 | |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 79 | protected: |
| 80 | ZoneInterface* _owner; |
Nirav Shah | ccc8bb6 | 2022-02-17 21:06:51 -0800 | [diff] [blame] | 81 | std::string _id; |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 82 | |
| 83 | private: |
| 84 | // parameters |
| 85 | ec::pid_info_t _pid_info; |
Nirav Shah | ccc8bb6 | 2022-02-17 21:06:51 -0800 | [diff] [blame] | 86 | double _setpoint = 0; |
James Feist | 572c43d | 2019-01-31 15:52:22 -0800 | [diff] [blame] | 87 | double lastInput = std::numeric_limits<double>::quiet_NaN(); |
James Feist | 22c257a | 2018-08-31 14:07:12 -0700 | [diff] [blame] | 88 | }; |
Patrick Venture | a076487 | 2020-08-08 07:48:43 -0700 | [diff] [blame] | 89 | |
| 90 | } // namespace pid_control |