2020-10-31 16:59:35 -07:00
|
|
|
#include "pump_control.h"
|
|
|
|
#include "wideband_config.h"
|
|
|
|
#include "heater_control.h"
|
|
|
|
#include "sampling.h"
|
|
|
|
#include "pump_dac.h"
|
|
|
|
#include "pid.h"
|
|
|
|
|
|
|
|
#include "ch.h"
|
|
|
|
|
2022-08-29 17:19:30 -07:00
|
|
|
struct pump_control_state {
|
|
|
|
Pid pumpPid;
|
|
|
|
};
|
|
|
|
|
|
|
|
static struct pump_control_state state[AFR_CHANNELS] =
|
|
|
|
{
|
|
|
|
{
|
|
|
|
Pid(50.0f, 10000.0f, 0.0f, 10.0f, 2),
|
|
|
|
},
|
|
|
|
#if (AFR_CHANNELS > 1)
|
|
|
|
{
|
|
|
|
Pid(50.0f, 10000.0f, 0.0f, 10.0f, 2),
|
|
|
|
}
|
|
|
|
#endif
|
|
|
|
};
|
2020-10-31 16:59:35 -07:00
|
|
|
|
|
|
|
static THD_WORKING_AREA(waPumpThread, 256);
|
|
|
|
static void PumpThread(void*)
|
|
|
|
{
|
2022-12-12 19:29:32 -08:00
|
|
|
chRegSetThreadName("Pump");
|
|
|
|
|
2020-10-31 16:59:35 -07:00
|
|
|
while(true)
|
|
|
|
{
|
2022-08-29 17:19:30 -07:00
|
|
|
for (int ch = 0; ch < AFR_CHANNELS; ch++)
|
2020-10-31 16:59:35 -07:00
|
|
|
{
|
2022-08-29 17:19:30 -07:00
|
|
|
pump_control_state &s = state[ch];
|
2020-10-31 16:59:35 -07:00
|
|
|
|
2022-08-29 17:19:30 -07:00
|
|
|
// Only actuate pump when running closed loop!
|
|
|
|
if (IsRunningClosedLoop(ch))
|
|
|
|
{
|
|
|
|
float nernstVoltage = GetNernstDc(ch);
|
2020-10-31 16:59:35 -07:00
|
|
|
|
2022-08-29 17:19:30 -07:00
|
|
|
float result = s.pumpPid.GetOutput(NERNST_TARGET, nernstVoltage);
|
|
|
|
|
|
|
|
// result is in mA
|
|
|
|
SetPumpCurrentTarget(ch, result * 1000);
|
|
|
|
}
|
|
|
|
else
|
|
|
|
{
|
|
|
|
// Otherwise set zero pump current to avoid damaging the sensor
|
|
|
|
SetPumpCurrentTarget(ch, 0);
|
|
|
|
}
|
2021-04-26 17:37:53 -07:00
|
|
|
}
|
2020-10-31 17:12:34 -07:00
|
|
|
|
|
|
|
// Run at 500hz
|
|
|
|
chThdSleepMilliseconds(2);
|
2020-10-31 16:59:35 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
void StartPumpControl()
|
|
|
|
{
|
|
|
|
chThdCreateStatic(waPumpThread, sizeof(waPumpThread), NORMALPRIO + 4, PumpThread, nullptr);
|
|
|
|
}
|