2020-08-17 02:22:25 -07:00
|
|
|
#pragma once
|
|
|
|
|
2020-11-10 20:11:22 -08:00
|
|
|
#include "expected.h"
|
2021-12-26 09:59:53 -08:00
|
|
|
#include "injector_model_generated.h"
|
2020-08-17 02:22:25 -07:00
|
|
|
|
2021-11-17 09:13:19 -08:00
|
|
|
struct IInjectorModel : public EngineModule {
|
2020-08-17 14:03:59 -07:00
|
|
|
virtual void prepare() = 0;
|
|
|
|
virtual floatms_t getInjectionDuration(float fuelMassGram) const = 0;
|
2021-03-03 04:30:56 -08:00
|
|
|
virtual float getFuelMassForDuration(floatms_t duration) const = 0;
|
2020-08-17 14:03:59 -07:00
|
|
|
};
|
|
|
|
|
2021-12-26 09:59:53 -08:00
|
|
|
class InjectorModelBase : public IInjectorModel, public injector_model_s {
|
2020-08-17 02:22:25 -07:00
|
|
|
public:
|
2020-08-17 14:03:59 -07:00
|
|
|
void prepare() override;
|
|
|
|
floatms_t getInjectionDuration(float fuelMassGram) const override;
|
2021-03-03 04:30:56 -08:00
|
|
|
float getFuelMassForDuration(floatms_t duration) const override;
|
2020-08-17 02:22:25 -07:00
|
|
|
|
|
|
|
virtual floatms_t getDeadtime() const = 0;
|
2021-12-26 09:59:53 -08:00
|
|
|
virtual float getInjectorMassFlowRate() = 0;
|
|
|
|
virtual float getInjectorFlowRatio() = 0;
|
2020-11-10 20:11:22 -08:00
|
|
|
virtual expected<float> getAbsoluteRailPressure() const = 0;
|
2021-07-07 20:46:44 -07:00
|
|
|
virtual float correctShortPulse(float baseDuration) const = 0;
|
2020-08-17 02:22:25 -07:00
|
|
|
|
2020-10-26 04:23:13 -07:00
|
|
|
virtual void postState(float deadTime) const { (void)deadTime; };
|
2020-10-23 17:25:47 -07:00
|
|
|
|
2020-08-17 02:22:25 -07:00
|
|
|
private:
|
|
|
|
float m_massFlowRate = 0;
|
|
|
|
};
|
|
|
|
|
2021-11-16 13:52:11 -08:00
|
|
|
class InjectorModel : public InjectorModelBase {
|
2020-08-17 02:22:25 -07:00
|
|
|
public:
|
2020-10-23 17:25:47 -07:00
|
|
|
void postState(float deadtime) const override;
|
2020-08-17 02:22:25 -07:00
|
|
|
floatms_t getDeadtime() const override;
|
2021-12-26 09:59:53 -08:00
|
|
|
float getInjectorMassFlowRate() override;
|
|
|
|
float getInjectorFlowRatio() override;
|
2020-11-10 20:11:22 -08:00
|
|
|
expected<float> getAbsoluteRailPressure() const override;
|
2021-07-07 20:46:44 -07:00
|
|
|
|
|
|
|
// Small pulse correction logic
|
|
|
|
float correctShortPulse(float baseDuration) const override;
|
|
|
|
virtual float correctInjectionPolynomial(float baseDuration) const;
|
2021-11-17 09:13:19 -08:00
|
|
|
|
|
|
|
using interface_t = IInjectorModel; // Mock interface
|
2020-08-17 02:22:25 -07:00
|
|
|
};
|