rusefi-1/firmware/controllers/trigger/decoders/trigger_honda.cpp

299 lines
10 KiB
C++
Raw Normal View History

2016-05-27 19:02:56 -07:00
/*
* @file trigger_honda.cpp
*
* @date May 27, 2016
2017-01-03 03:05:22 -08:00
* @author Andrey Belomutskiy, (c) 2012-2017
2016-05-27 19:02:56 -07:00
*/
#include "trigger_honda.h"
2017-02-13 21:02:59 -08:00
#include "trigger_universal.h"
2016-05-27 19:02:56 -07:00
#define S24 (720.0f / 24 / 2)
2017-05-15 20:28:49 -07:00
static float addAccordPair(TriggerShape *s, float sb, trigger_wheel_e const waveIndex DECLARE_ENGINE_PARAMETER_SUFFIX) {
s->addEvent2(sb, waveIndex, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb += S24;
2017-05-15 20:28:49 -07:00
s->addEvent2(sb, waveIndex, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb += S24;
return sb;
}
#define DIP 7.5f
2017-05-15 20:28:49 -07:00
static float addAccordPair3(TriggerShape *s, float sb DECLARE_ENGINE_PARAMETER_SUFFIX) {
2016-05-27 19:02:56 -07:00
sb += DIP;
2017-05-15 20:28:49 -07:00
s->addEvent2(sb, T_CHANNEL_3, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb += DIP;
2017-05-15 20:28:49 -07:00
s->addEvent2(sb, T_CHANNEL_3, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb += 2 * DIP;
return sb;
}
/**
* Thank you Dip!
* http://forum.pgmfi.org/viewtopic.php?f=2&t=15570start=210#p139007
*/
2017-05-15 20:28:49 -07:00
void configureHondaAccordCDDip(TriggerShape *s DECLARE_ENGINE_PARAMETER_SUFFIX) {
2016-05-27 19:02:56 -07:00
s->initialize(FOUR_STROKE_CAM_SENSOR, true);
s->initialState[T_SECONDARY] = TV_RISE;
float sb = 0;
2017-05-15 20:28:49 -07:00
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(90, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb = 90;
2017-05-15 20:28:49 -07:00
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(180, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb = 180;
2017-05-15 20:28:49 -07:00
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(270, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb = 270;
2017-05-15 20:28:49 -07:00
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(360.0f - DIP, T_PRIMARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
s->addEvent2(360, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb = 360;
2017-05-15 20:28:49 -07:00
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(450, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb = 450;
2017-05-15 20:28:49 -07:00
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(540, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb = 540;
2017-05-15 20:28:49 -07:00
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(630, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
sb = 630;
2017-05-15 20:28:49 -07:00
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair3(s, sb PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(720.0f - DIP, T_PRIMARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
// s->addEvent2(720.0f - 12 * sb, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
// s->addEvent2(720.0f, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(720.0f, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
s->isSynchronizationNeeded = false;
2016-06-11 21:00:15 -07:00
s->useOnlyPrimaryForSync = true;
2016-05-27 19:02:56 -07:00
}
2017-02-13 21:02:59 -08:00
/**
* '1' is conditional
* '4' is conditional
* '24' is always secondary channel
*/
void configureHonda_1_4_24(TriggerShape *s, bool withOneEventSignal, bool withFourEventSignal,
2016-05-27 19:02:56 -07:00
trigger_wheel_e const oneEventWave,
trigger_wheel_e const fourEventWave,
2017-05-15 20:28:49 -07:00
float prefix DECLARE_ENGINE_PARAMETER_SUFFIX) {
2016-05-27 19:02:56 -07:00
s->initialize(FOUR_STROKE_CAM_SENSOR, true);
2017-02-13 21:02:59 -08:00
2016-05-27 19:02:56 -07:00
float sb = 5.0f + prefix;
float tdcWidth = 0.1854 * 720 / 4;
s->isSynchronizationNeeded = false;
2017-05-15 20:28:49 -07:00
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
if (withOneEventSignal)
2017-05-15 20:28:49 -07:00
s->addEvent2(sb - S24 / 2, oneEventWave, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
2017-05-15 20:28:49 -07:00
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
if (withOneEventSignal)
2017-05-15 20:28:49 -07:00
s->addEvent2(sb - S24 / 2, oneEventWave, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
if (withFourEventSignal) {
2017-05-15 20:28:49 -07:00
s->addEvent2(1 * 180.0f + prefix - tdcWidth, fourEventWave, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
}
2017-05-15 20:28:49 -07:00
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
if (withFourEventSignal) {
2017-05-15 20:28:49 -07:00
s->addEvent2(1 * 180.0f + prefix, fourEventWave, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
}
2017-05-15 20:28:49 -07:00
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb,T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
if (withFourEventSignal) {
2017-05-15 20:28:49 -07:00
s->addEvent2(2 * 180.0f + prefix - tdcWidth, fourEventWave, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
}
2017-05-15 20:28:49 -07:00
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
if (withFourEventSignal) {
2017-05-15 20:28:49 -07:00
s->addEvent2(2 * 180.0f + prefix, fourEventWave, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
}
for (int i = 3; i <= 4; i++) {
2017-05-15 20:28:49 -07:00
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
if (withFourEventSignal) {
2017-05-15 20:28:49 -07:00
s->addEvent2(i * 180.0f + prefix - tdcWidth, fourEventWave, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
}
2017-05-15 20:28:49 -07:00
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
if (withFourEventSignal) {
2017-05-15 20:28:49 -07:00
s->addEvent2(i * 180.0f + prefix, fourEventWave, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
}
}
2016-06-11 21:00:15 -07:00
s->useOnlyPrimaryForSync = true;
2016-05-27 19:02:56 -07:00
}
2017-05-15 20:28:49 -07:00
void configureHondaCbr600(TriggerShape *s DECLARE_ENGINE_PARAMETER_SUFFIX) {
2016-05-27 19:02:56 -07:00
// todo: finish this
2017-05-15 20:28:49 -07:00
setToothedWheelConfiguration(s, 24, 0, FOUR_STROKE_CRANK_SENSOR PASS_ENGINE_PARAMETER_SUFFIX);
2016-05-27 19:02:56 -07:00
}
2017-05-15 20:28:49 -07:00
void configureHondaCbr600custom(TriggerShape *s DECLARE_ENGINE_PARAMETER_SUFFIX) {
2016-07-09 11:02:36 -07:00
float w = 720 / 2 / 24;
// s->initialize(FOUR_STROKE_CAM_SENSOR, false);
s->initialize(FOUR_STROKE_CAM_SENSOR, true);
s->useOnlyPrimaryForSync = true;
s->isSynchronizationNeeded = true;
2016-07-12 06:03:22 -07:00
s->setTriggerSynchronizationGap2(0.7, 1.1);
2016-07-09 11:02:36 -07:00
float a = 0;
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a - 1, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX); // 30
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
s->addEvent2(52.4, T_PRIMARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a - 1, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX); // 60
2016-07-09 11:02:36 -07:00
for (int i = 0;i<10;i++) {
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
}
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(381.34f, T_PRIMARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a - 1, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
for (int i = 0;i<1;i++) {
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
}
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(449.1f, T_PRIMARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
for (int i = 0;i<8;i++) {
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
}
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
a += w;
2017-05-15 20:28:49 -07:00
s->addEvent2(a - 1, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(720.0f, T_PRIMARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
}
2017-05-15 20:28:49 -07:00
void configureHondaAccordShifted(TriggerShape *s DECLARE_ENGINE_PARAMETER_SUFFIX) {
2016-10-15 20:03:28 -07:00
float w = 720 / 2 / 24;
s->initialize(FOUR_STROKE_CAM_SENSOR, true);
float sb = S24;
2016-10-28 19:03:00 -07:00
// like this there is no issue
2017-05-15 20:28:49 -07:00
// s->addEvent2(S24 + 0.001, T_PRIMARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
// s->addEvent2(S24 + 0.1, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-10-28 19:03:00 -07:00
2017-05-15 20:28:49 -07:00
s->addEvent2(S24 + 0.001, T_SECONDARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
s->addEvent2(S24 + 0.1, T_PRIMARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
2016-10-28 19:03:00 -07:00
2016-10-15 20:03:28 -07:00
sb += S24;
2017-05-15 20:28:49 -07:00
s->addEvent2(sb, T_SECONDARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-10-15 20:03:28 -07:00
sb += S24;
2017-05-15 20:28:49 -07:00
s->addEvent2(S24 + 22, T_PRIMARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
2016-07-09 11:02:36 -07:00
2016-05-27 19:02:56 -07:00
2016-10-31 19:02:12 -07:00
for (int i = 0;i<23;i++) {
2017-05-15 20:28:49 -07:00
sb = addAccordPair(s, sb, T_SECONDARY PASS_ENGINE_PARAMETER_SUFFIX);
2016-10-31 19:02:12 -07:00
}
2016-10-15 20:03:28 -07:00
s->useOnlyPrimaryForSync = true;
s->isSynchronizationNeeded = false;
}
2017-05-15 20:28:49 -07:00
void configureOnePlus16(TriggerShape *s, operation_mode_e operationMode DECLARE_ENGINE_PARAMETER_SUFFIX) {
2017-02-13 21:02:59 -08:00
s->initialize(FOUR_STROKE_CAM_SENSOR, true);
int totalTeethCount = 16;
int skippedCount = 0;
2017-05-15 20:28:49 -07:00
s->addEvent2(2, T_PRIMARY, TV_RISE PASS_ENGINE_PARAMETER_SUFFIX);
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 0, 360, 2, 20 PASS_ENGINE_PARAMETER_SUFFIX);
s->addEvent2(20, T_PRIMARY, TV_FALL PASS_ENGINE_PARAMETER_SUFFIX);
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 0, 360, 20, NO_RIGHT_FILTER PASS_ENGINE_PARAMETER_SUFFIX);
2017-02-13 21:02:59 -08:00
addSkippedToothTriggerEvents(T_SECONDARY, s, totalTeethCount, skippedCount, 0.5, 360, 360, NO_LEFT_FILTER,
2017-05-15 20:28:49 -07:00
NO_RIGHT_FILTER PASS_ENGINE_PARAMETER_SUFFIX);
2017-02-13 21:02:59 -08:00
s->isSynchronizationNeeded = false;
s->useOnlyPrimaryForSync = true;
}