custom-board-bundle-sample-.../firmware/controllers/math/pid.h

97 lines
2.3 KiB
C
Raw Normal View History

2015-07-10 06:01:56 -07:00
/**
* @file pid.h
*
* @date Sep 16, 2014
2017-01-03 03:05:22 -08:00
* @author Andrey Belomutskiy, (c) 2012-2017
2015-07-10 06:01:56 -07:00
*/
#ifndef PID_H_
#define PID_H_
2016-02-06 09:02:24 -08:00
#include "global.h"
2016-01-20 20:03:03 -08:00
#include "engine_configuration_generated_structures.h"
2017-05-25 05:49:04 -07:00
#include "datalogging.h"
2016-02-06 09:02:24 -08:00
#if EFI_PROD_CODE || EFI_SIMULATOR
#include "tunerstudio_configuration.h"
#endif
2016-01-20 20:03:03 -08:00
2017-12-24 18:17:10 -08:00
// See PidCic below
#define PID_AVG_BUF_SIZE_SHIFT 5
#define PID_AVG_BUF_SIZE (1<<PID_AVG_BUF_SIZE_SHIFT) // 32*sizeof(float)
2015-07-10 06:01:56 -07:00
class Pid {
public:
2016-02-06 09:02:24 -08:00
Pid();
2017-05-29 20:15:07 -07:00
Pid(pid_s *pid);
void init(pid_s *pid);
2016-09-15 20:01:48 -07:00
bool isSame(pid_s *pid);
2016-02-06 09:02:24 -08:00
2017-01-22 14:03:31 -08:00
float getValue(float target, float input);
2017-05-25 05:49:04 -07:00
// todo: dTime should be taken from pid_s
2017-12-24 18:17:10 -08:00
virtual float getValue(float target, float input, float dTime);
// doesn't limit the result (used in incremental CIC PID, see below)
float getRawValue(float target, float input, float dTime);
2015-07-10 06:01:56 -07:00
void updateFactors(float pFactor, float iFactor, float dFactor);
2017-12-24 18:17:10 -08:00
virtual void reset(void);
2015-07-10 06:01:56 -07:00
float getP(void);
float getI(void);
float getD(void);
2016-02-06 09:02:24 -08:00
float getOffset(void);
2016-01-24 13:01:28 -08:00
float getIntegration(void);
float getPrevError(void);
2016-02-06 09:02:24 -08:00
#if EFI_PROD_CODE || EFI_SIMULATOR
void postState(TunerStudioOutputChannels *tsOutputChannels);
2017-07-23 09:12:35 -07:00
void postState(TunerStudioOutputChannels *tsOutputChannels, int pMult);
2016-02-06 09:02:24 -08:00
#endif
2015-07-10 06:01:56 -07:00
float minResult;
float maxResult;
2017-05-22 19:32:08 -07:00
float iTerm;
float dTerm; // we are remembering this only for debugging purposes
2017-05-29 20:15:07 -07:00
void showPidStatus(Logging *logging, const char*msg);
2017-05-28 19:10:35 -07:00
void sleep();
2017-06-02 18:34:00 -07:00
int resetCounter;
2017-04-10 12:16:00 -07:00
private:
pid_s *pid;
2015-07-10 06:01:56 -07:00
float prevError;
2017-05-25 05:56:36 -07:00
// these are only used for logging
float prevTarget;
float prevInput;
float prevResult;
2017-12-24 18:17:10 -08:00
private:
virtual void updateITerm(float value);
};
/**
* A PID impl. with a modified cascaded integrator-comb (CIC) filtering.
* Used for incremental auto-IAC control. See autoIdle() in idle_thread.cpp
2017-12-24 18:26:42 -08:00
*
* https://rusefi.com/forum/viewtopic.php?f=9&t=1315
2017-12-24 18:17:10 -08:00
*/
class PidCic : public Pid {
public:
PidCic();
PidCic(pid_s *pid);
virtual void reset(void);
virtual float getValue(float target, float input, float dTime);
private:
// Circular running-average buffer for I-term, used by CIC-like filter
float iTermBuf[PID_AVG_BUF_SIZE];
// Needed by averaging (smoothing) of iTerm sums
float iTermInvNum;
// Total PID iterations (>240 days max. for 10ms update period)
int totalItermCnt;
private:
virtual void updateITerm(float value);
2015-07-10 06:01:56 -07:00
};
#endif /* PID_H_ */