139 lines
4.0 KiB
C++
139 lines
4.0 KiB
C++
// Mitsubishi 4G93 trigger pattern
|
|
// Crank: 2 teeth per rev (4 teeth per cycle)
|
|
// Cam: 4G92/93/94 pattern (big tooth - small tooth)
|
|
|
|
#include "pch.h"
|
|
|
|
#include "logicdata_csv_reader.h"
|
|
|
|
TEST(real4g93, cranking) {
|
|
CsvReader reader(1, /* vvtCount */ 1);
|
|
|
|
reader.open("tests/trigger/resources/4g93-cranking.csv");
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
|
engineConfiguration->isFasterEngineSpinUpEnabled = true;
|
|
engineConfiguration->alwaysInstantRpm = true;
|
|
|
|
engineConfiguration->isPhaseSyncRequiredForIgnition = true;
|
|
|
|
engineConfiguration->vvtMode[0] = VVT_MITSUBISHI_4G63;
|
|
|
|
eth.setTriggerType(TT_MITSU_4G63_CRANK);
|
|
|
|
bool gotRpm = false;
|
|
bool gotSync = false;
|
|
|
|
static const float gapRatios[2][4] = {
|
|
{ 0, NAN, INFINITY, 0.89f }, // no sync
|
|
{ 0.4f, 3.788f, 0.62f, 1.02f }
|
|
};
|
|
static const int gapRatioIndices[12] = { 0, 0, 0, 0, 1, 1, 1, 2, 2, 2, 3, 3 };
|
|
|
|
for (int idx = 0; reader.haveMore(); idx++) {
|
|
reader.processLine(ð);
|
|
|
|
// Expect that all teeth are in the correct spot
|
|
|
|
auto rpm = Sensor::getOrZero(SensorType::Rpm);
|
|
if (!gotRpm && rpm) {
|
|
gotRpm = true;
|
|
|
|
// We should get first RPM on exactly the first sync point - this means the instant RPM pre-sync event copy all worked OK
|
|
EXPECT_EQ(reader.lineIndex(), 6);
|
|
EXPECT_NEAR(rpm, 132.77f, 0.1);
|
|
}
|
|
|
|
if (!gotSync && engine->triggerCentral.triggerState.hasSynchronizedPhase()) {
|
|
gotSync = true;
|
|
|
|
EXPECT_EQ(reader.lineIndex(), 17);
|
|
EXPECT_NEAR(rpm, 204.01f, 0.1);
|
|
}
|
|
// float instantRpm = engine->triggerCentral.instantRpm.getInstantRpm();
|
|
// not looking too bad horrible printf("rpm=%f instant=%f\n", rpm, instantRpm);
|
|
|
|
float vvtSyncGapRatio = engine->triggerCentral.triggerState.vvtSyncGapRatio;
|
|
float gapRatio = gapRatios[idx < 12 ? 0 : 1][gapRatioIndices[idx % 12]];
|
|
if (isnan(gapRatio)) {
|
|
EXPECT_TRUE(isnan(vvtSyncGapRatio));
|
|
} else if (isinf(gapRatio)) {
|
|
EXPECT_TRUE(isinf(vvtSyncGapRatio));
|
|
}else {
|
|
EXPECT_NEAR(vvtSyncGapRatio, gapRatio, 0.1);
|
|
}
|
|
}
|
|
|
|
ASSERT_TRUE(gotRpm);
|
|
ASSERT_TRUE(gotSync);
|
|
|
|
ASSERT_EQ(0, eth.recentWarnings()->getCount());
|
|
}
|
|
|
|
TEST(real4g93, crankingOn11) {
|
|
CsvReader reader(2, /* vvtCount */ 0);
|
|
|
|
reader.open("tests/trigger/resources/4g93-cranking.csv");
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
|
engineConfiguration->isFasterEngineSpinUpEnabled = true;
|
|
|
|
engineConfiguration->isPhaseSyncRequiredForIgnition = true;
|
|
|
|
eth.setTriggerType(TT_MAZDA_MIATA_NA);
|
|
|
|
bool gotRpm = false;
|
|
while (reader.haveMore()) {
|
|
reader.processLine(ð);
|
|
|
|
auto rpm = Sensor::getOrZero(SensorType::Rpm);
|
|
if (!gotRpm && rpm) {
|
|
gotRpm = true;
|
|
|
|
// We should get first RPM on exactly the first sync point - this means the instant RPM pre-sync event copy all worked OK
|
|
EXPECT_EQ(reader.lineIndex(), 7);
|
|
EXPECT_NEAR(rpm, 168.43f, 0.1);
|
|
}
|
|
|
|
// float instantRpm = engine->triggerCentral.instantRpm.getInstantRpm();
|
|
// printf("%d rpm=%f instant=%f\n", reader.lineIndex(), rpm, instantRpm);
|
|
}
|
|
}
|
|
|
|
TEST(real4g93, crankingCamOnly) {
|
|
CsvReader reader(1, /* vvtCount */ 0);
|
|
|
|
reader.open("tests/trigger/resources/4g93-cranking-cam-only.csv");
|
|
EngineTestHelper eth(engine_type_e::TEST_ENGINE);
|
|
engineConfiguration->isFasterEngineSpinUpEnabled = true;
|
|
engineConfiguration->alwaysInstantRpm = true;
|
|
|
|
eth.setTriggerType(TT_MITSU_4G9x_CAM);
|
|
|
|
bool gotRpm = false;
|
|
bool gotSync = false;
|
|
|
|
while (reader.haveMore()) {
|
|
reader.processLine(ð);
|
|
|
|
// Expect that all teeth are in the correct spot
|
|
auto rpm = Sensor::getOrZero(SensorType::Rpm);
|
|
if (!gotRpm && rpm) {
|
|
gotRpm = true;
|
|
|
|
// We should get first RPM on exactly the first sync point - this means the instant RPM pre-sync event copy all worked OK
|
|
EXPECT_EQ(reader.lineIndex(), 17);
|
|
EXPECT_NEAR(rpm, 194.61f, 0.1);
|
|
}
|
|
|
|
if (!gotSync && engine->triggerCentral.triggerState.getShaftSynchronized() && engine->triggerCentral.triggerState.hasSynchronizedPhase()) {
|
|
gotSync = true;
|
|
|
|
EXPECT_EQ(reader.lineIndex(), 17);
|
|
}
|
|
}
|
|
|
|
ASSERT_TRUE(gotRpm);
|
|
ASSERT_TRUE(gotSync);
|
|
|
|
ASSERT_EQ(0, eth.recentWarnings()->getCount());
|
|
}
|