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
|
|
|
|
2023-06-23 14:38:17 -07:00
|
|
|
const auto& sampler = GetSampler(ch);
|
|
|
|
const auto& heater = GetHeaterController(ch);
|
|
|
|
|
2022-08-29 17:19:30 -07:00
|
|
|
// Only actuate pump when running closed loop!
|
2024-06-25 23:37:51 -07:00
|
|
|
if (heater.IsRunningClosedLoop() ||
|
|
|
|
#ifdef START_PUMP_TEMP_OFFSET
|
|
|
|
(sampler.GetSensorTemperature() >= heater.GetTargetTemp() - START_PUMP_TEMP_OFFSET) ||
|
|
|
|
#endif
|
|
|
|
(0))
|
2022-08-29 17:19:30 -07:00
|
|
|
{
|
2023-06-23 14:38:17 -07:00
|
|
|
float nernstVoltage = sampler.GetNernstDc();
|
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);
|
|
|
|
}
|