2015-07-10 06:01:56 -07:00
|
|
|
/**
|
2019-12-03 22:11:10 -08:00
|
|
|
* @file state_sequence.cpp
|
2015-07-10 06:01:56 -07:00
|
|
|
*
|
|
|
|
* @date May 18, 2014
|
2020-01-13 18:57:43 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2020
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
2019-12-03 22:11:10 -08:00
|
|
|
#include "state_sequence.h"
|
2015-07-10 06:01:56 -07:00
|
|
|
#include "trigger_structure.h"
|
|
|
|
|
2021-11-10 16:47:27 -08:00
|
|
|
void MultiChannelStateSequence::checkSwitchTimes(const float scale) const {
|
2021-11-21 01:56:07 -08:00
|
|
|
if (getSwitchTime(phaseCount - 1) != 1) {
|
|
|
|
firmwareError(CUSTOM_ERR_WAVE_1, "last switch time has to be 1/%f not %.2f/%f",
|
|
|
|
scale, getSwitchTime(phaseCount - 1),
|
|
|
|
scale * getSwitchTime(phaseCount - 1));
|
2015-07-10 06:01:56 -07:00
|
|
|
return;
|
|
|
|
}
|
2021-11-10 16:47:27 -08:00
|
|
|
for (int i = 0; i < phaseCount - 1; i++) {
|
2021-11-21 01:56:07 -08:00
|
|
|
if (getSwitchTime(i) >= getSwitchTime(i + 1)) {
|
|
|
|
firmwareError(CUSTOM_ERR_WAVE_2, "invalid switchTimes @%d: %.2f/%.2f",
|
|
|
|
i, getSwitchTime(i), getSwitchTime(i + 1));
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
2018-12-08 13:38:44 -08:00
|
|
|
|
2021-11-10 16:47:27 -08:00
|
|
|
int MultiChannelStateSequence::findInsertionAngle(const float angle) const {
|
|
|
|
for (int i = phaseCount - 1; i >= 0; i--) {
|
2021-11-21 01:56:07 -08:00
|
|
|
if (angle > getSwitchTime(i))
|
2018-12-08 13:38:44 -08:00
|
|
|
return i + 1;
|
|
|
|
}
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
2021-11-10 16:47:27 -08:00
|
|
|
int MultiChannelStateSequence::findAngleMatch(const float angle) const {
|
|
|
|
for (int i = 0; i < phaseCount; i++) {
|
2021-11-21 01:56:07 -08:00
|
|
|
if (isSameF(getSwitchTime(i), angle))
|
2018-12-08 13:38:44 -08:00
|
|
|
return i;
|
|
|
|
}
|
|
|
|
return EFI_ERROR_CODE;
|
|
|
|
}
|