From e70df582900bd0d1fb5f039a4645b7905ffb84af Mon Sep 17 00:00:00 2001 From: Andrey G Date: Wed, 26 Jun 2024 09:37:51 +0300 Subject: [PATCH] Underheat issue (#314) * f0_module needs hack to start pump before closed loop * Fix paranoid check * Make START_PUMP_TEMP_THRESHOLD relative --- firmware/boards/f0_module/wideband_board_config.h | 6 ++++++ firmware/heater_control.cpp | 5 +++++ firmware/heater_control.h | 2 ++ firmware/pump_control.cpp | 6 +++++- firmware/pump_dac.cpp | 2 ++ 5 files changed, 20 insertions(+), 1 deletion(-) diff --git a/firmware/boards/f0_module/wideband_board_config.h b/firmware/boards/f0_module/wideband_board_config.h index 529dcf9..b71fc98 100644 --- a/firmware/boards/f0_module/wideband_board_config.h +++ b/firmware/boards/f0_module/wideband_board_config.h @@ -17,3 +17,9 @@ // Nernst voltage & ESR sense // ******************************* #define VM_RESISTOR_VALUE (10) + +// ******************************* +// Hack: allow pump driving above target temperature +// minus this offset to avoid Vnerns voltage clamp near 0V +// ******************************* +#define START_PUMP_TEMP_OFFSET (200.0) diff --git a/firmware/heater_control.cpp b/firmware/heater_control.cpp index 03329ec..44ba203 100644 --- a/firmware/heater_control.cpp +++ b/firmware/heater_control.cpp @@ -27,6 +27,11 @@ bool HeaterControllerBase::IsRunningClosedLoop() const return heaterState == HeaterState::ClosedLoop; } +float HeaterControllerBase::GetTargetTemp() const +{ + return m_targetTempC; +} + float HeaterControllerBase::GetHeaterEffectiveVoltage() const { return heaterVoltage; diff --git a/firmware/heater_control.h b/firmware/heater_control.h index df0b2a2..02149a2 100644 --- a/firmware/heater_control.h +++ b/firmware/heater_control.h @@ -25,6 +25,7 @@ struct IHeaterController virtual bool IsRunningClosedLoop() const = 0; virtual float GetHeaterEffectiveVoltage() const = 0; virtual HeaterState GetHeaterState() const = 0; + virtual float GetTargetTemp() const = 0; }; class HeaterControllerBase : public IHeaterController @@ -37,6 +38,7 @@ public: bool IsRunningClosedLoop() const override; float GetHeaterEffectiveVoltage() const override; HeaterState GetHeaterState() const override; + float GetTargetTemp() const override; virtual void SetDuty(float duty) const = 0; diff --git a/firmware/pump_control.cpp b/firmware/pump_control.cpp index 601d7d9..9bf6eb9 100644 --- a/firmware/pump_control.cpp +++ b/firmware/pump_control.cpp @@ -38,7 +38,11 @@ static void PumpThread(void*) const auto& heater = GetHeaterController(ch); // Only actuate pump when running closed loop! - if (heater.IsRunningClosedLoop()) + if (heater.IsRunningClosedLoop() || +#ifdef START_PUMP_TEMP_OFFSET + (sampler.GetSensorTemperature() >= heater.GetTargetTemp() - START_PUMP_TEMP_OFFSET) || +#endif + (0)) { float nernstVoltage = sampler.GetNernstDc(); diff --git a/firmware/pump_dac.cpp b/firmware/pump_dac.cpp index ed543a6..9d6576f 100644 --- a/firmware/pump_dac.cpp +++ b/firmware/pump_dac.cpp @@ -90,11 +90,13 @@ void InitPumpDac() void SetPumpCurrentTarget(int ch, int32_t microampere) { +#ifndef START_PUMP_TEMP_OFFSET // Don't allow pump current when the sensor isn't hot if (!GetHeaterController(ch).IsRunningClosedLoop()) { microampere = 0; } +#endif state[ch].curIpump = microampere;