359 lines
12 KiB
C++
359 lines
12 KiB
C++
#include "pch.h"
|
|
|
|
#include "defaults.h"
|
|
#include "table_helper.h"
|
|
#include "mazda_miata_vvt.h"
|
|
|
|
static void setBosch02880155868(injector_s& cfg) {
|
|
// http://www.boschdealer.com/specsheets/0280155868cs.jpg
|
|
cfg.battLagCorrBins[0] = 6;
|
|
cfg.battLagCorr[0] = 3.371;
|
|
|
|
cfg.battLagCorrBins[1] = 8;
|
|
cfg.battLagCorr[1] = 1.974;
|
|
|
|
cfg.battLagCorrBins[2] = 10;
|
|
cfg.battLagCorr[2] = 1.383;
|
|
|
|
cfg.battLagCorrBins[3] = 11;
|
|
cfg.battLagCorr[3] = 1.194;
|
|
|
|
cfg.battLagCorrBins[4] = 12;
|
|
cfg.battLagCorr[4] = 1.04;
|
|
|
|
cfg.battLagCorrBins[5] = 13;
|
|
cfg.battLagCorr[5] = 0.914;
|
|
|
|
cfg.battLagCorrBins[6] = 14;
|
|
cfg.battLagCorr[6] = 0.797;
|
|
|
|
cfg.battLagCorrBins[7] = 15;
|
|
cfg.battLagCorr[7] = 0.726;
|
|
}
|
|
|
|
static void setDefaultWarmupFuelEnrichment() {
|
|
static const float bins[] =
|
|
{
|
|
-40,
|
|
-30,
|
|
-20,
|
|
-10,
|
|
0,
|
|
10,
|
|
20,
|
|
30,
|
|
40,
|
|
50,
|
|
60,
|
|
70,
|
|
80,
|
|
90,
|
|
100,
|
|
110
|
|
};
|
|
|
|
copyArray(config->cltFuelCorrBins, bins);
|
|
|
|
static const float values[] =
|
|
{
|
|
1.50,
|
|
1.50,
|
|
1.42,
|
|
1.36,
|
|
1.28,
|
|
1.19,
|
|
1.12,
|
|
1.10,
|
|
1.06,
|
|
1.06,
|
|
1.03,
|
|
1.01,
|
|
1,
|
|
1,
|
|
1,
|
|
1
|
|
};
|
|
|
|
copyArray(config->cltFuelCorr, values);
|
|
}
|
|
|
|
static void setDefaultVETable() {
|
|
setRpmTableBin(config->veRpmBins);
|
|
#if (IGN_LOAD_COUNT == DEFAULT_IGN_LOAD_COUNT) && (IGN_RPM_COUNT == DEFAULT_IGN_RPM_COUNT)
|
|
static const float hardCodedveTable[16][16] = {
|
|
{49.300, 49.300, 49.400, 49.600, 50.200, 51.400, 52.600, 53.800, 54.400, 54.600, 54.400, 53.700, 52.800, 51.800, 50.900, 50.000, },
|
|
{49.600, 50.500, 51.500, 54.100, 57.500, 60.700, 62.900, 64.400, 65.000, 65.000, 64.500, 63.500, 62.300, 61.100, 60.000, 58.800, },
|
|
{50.300, 52.400, 54.300, 58.500, 62.700, 66.100, 68.200, 69.700, 70.200, 70.100, 69.500, 68.400, 67.100, 65.800, 64.500, 63.300, },
|
|
{51.400, 55.200, 58.200, 63.500, 68.000, 71.400, 73.500, 74.900, 75.300, 75.200, 74.500, 73.300, 71.800, 70.400, 69.000, 67.700, },
|
|
{54.300, 60.900, 64.900, 70.700, 75.100, 78.300, 80.300, 81.700, 82.100, 81.900, 81.100, 79.700, 78.100, 76.500, 75.000, 73.500, },
|
|
{56.400, 64.400, 68.700, 74.500, 78.700, 81.800, 83.800, 85.100, 85.500, 85.300, 84.400, 83.000, 81.300, 79.600, 78.000, 76.400, },
|
|
{60.700, 70.200, 74.500, 79.900, 83.800, 86.800, 88.900, 90.200, 90.600, 90.300, 89.400, 87.800, 86.000, 84.200, 82.500, 80.800, },
|
|
{65.800, 76.000, 80.000, 85.000, 88.800, 91.800, 93.900, 95.200, 95.600, 95.300, 94.300, 92.600, 90.700, 88.800, 87.000, 85.200, },
|
|
{69.400, 79.100, 82.900, 87.800, 91.700, 94.800, 97.000, 98.300, 98.800, 98.400, 97.400, 95.600, 93.500, 91.500, 89.600, 87.700, },
|
|
{73.000, 82.200, 85.900, 90.700, 94.600, 97.800, 100.000, 101.500, 101.900, 101.600, 100.400, 98.500, 96.400, 94.200, 92.200, 90.200, },
|
|
{76.600, 85.300, 88.800, 93.500, 97.400, 100.700, 103.100, 104.600, 105.100, 104.700, 103.500, 101.500, 99.200, 96.900, 94.800, 92.600, },
|
|
{80.300, 88.500, 91.800, 96.400, 100.300, 103.700, 106.200, 107.800, 108.200, 107.800, 106.500, 104.400, 102.000, 99.700, 97.400, 95.100, },
|
|
{83.900, 91.600, 94.700, 99.200, 103.200, 106.700, 109.200, 110.900, 111.400, 110.900, 109.600, 107.400, 104.800, 102.400, 99.900, 97.600, },
|
|
{87.500, 94.700, 97.600, 102.000, 106.100, 109.700, 112.300, 114.000, 114.500, 114.100, 112.600, 110.300, 107.700, 105.100, 102.500, 100.100, },
|
|
{91.100, 97.800, 100.600, 104.900, 108.900, 112.600, 115.300, 117.200, 117.700, 117.200, 115.700, 113.300, 110.500, 107.800, 105.100, 102.500, },
|
|
{94.700, 100.900, 103.500, 107.700, 111.800, 115.600, 118.400, 120.300, 120.800, 120.300, 118.700, 116.200, 113.300, 110.500, 107.700, 105.000, },
|
|
};
|
|
copyTable(config->veTable, hardCodedveTable);
|
|
#else
|
|
setTable(config->veTable, 80);
|
|
#endif
|
|
|
|
setRpmTableBin(config->baroCorrRpmBins);
|
|
setLinearCurve(config->baroCorrPressureBins, 75, 105, 1);
|
|
|
|
// Default baro table is all 1.0, we can't recommend a reasonable default here
|
|
setTable(config->baroCorrTable, 1);
|
|
|
|
// Give default axes for cylinder trim tables
|
|
copyArray(config->fuelTrimRpmBins, { 1000, 3000, 5000, 7000 });
|
|
copyArray(config->fuelTrimLoadBins, { 20, 50, 80, 100 });
|
|
|
|
// Default axes for VE blends
|
|
for (size_t i = 0; i < efi::size(config->veBlends); i++) {
|
|
auto& blend = config->veBlends[i];
|
|
setLinearCurve(blend.loadBins, 0, 100, 10);
|
|
setLinearCurve(blend.rpmBins, 0, 7000);
|
|
|
|
setLinearCurve(blend.blendBins, 0, 100);
|
|
setLinearCurve(blend.blendValues, 0, 100);
|
|
}
|
|
}
|
|
|
|
static void setDefaultFuelCutParameters() {
|
|
engineConfiguration->coastingFuelCutEnabled = false;
|
|
engineConfiguration->coastingFuelCutRpmLow = 1300;
|
|
engineConfiguration->coastingFuelCutRpmHigh = 1500;
|
|
engineConfiguration->coastingFuelCutTps = 2;
|
|
engineConfiguration->coastingFuelCutMap = 30;
|
|
engineConfiguration->coastingFuelCutClt = 60;
|
|
}
|
|
|
|
static void setDefaultStftSettings() {
|
|
auto& cfg = engineConfiguration->stft;
|
|
|
|
// Default to disabled
|
|
engineConfiguration->fuelClosedLoopCorrectionEnabled = false;
|
|
|
|
// Default to proportional mode (for wideband sensors)
|
|
engineConfiguration->stftIgnoreErrorMagnitude = false;
|
|
|
|
// 60 second startup delay - some O2 sensors are slow to warm up.
|
|
cfg.startupDelay = 60;
|
|
|
|
// Only correct in [12.0, 17.0]
|
|
cfg.minAfr = 12;
|
|
cfg.maxAfr = 17;
|
|
|
|
// Above 60 deg C
|
|
cfg.minClt = 60;
|
|
|
|
// 0.5% deadband
|
|
cfg.deadband = 0.5f;
|
|
|
|
// Sensible region defaults
|
|
cfg.maxIdleRegionRpm = 1000;
|
|
cfg.maxOverrunLoad = 35;
|
|
cfg.minPowerLoad = 85;
|
|
|
|
// Sensible cell defaults
|
|
for (size_t i = 0; i < efi::size(cfg.cellCfgs); i++) {
|
|
// 30 second time constant - nice and slow
|
|
cfg.cellCfgs[i].timeConstant = 30;
|
|
|
|
/// Allow +-5%
|
|
cfg.cellCfgs[i].maxAdd = 5;
|
|
cfg.cellCfgs[i].maxRemove = -5;
|
|
}
|
|
}
|
|
|
|
static const uint8_t tpsTpsTable[TPS_TPS_ACCEL_TABLE][TPS_TPS_ACCEL_TABLE] = {
|
|
/* Generated by TS2C on Tue Apr 18 21:29:16 EDT 2017*/
|
|
{/* 0 0 *//* 0 0.0*/0, /* 1 10.0*/0, /* 2 20.0*/0, /* 3 35.0*/0, /* 4 50.0*/0, /* 5 65.0*/0, /* 6 80.0*/0, /* 7 100.0*/0, },
|
|
{/* 1 10 *//* 0 0.0*/10, /* 1 10.0*/0, /* 2 20.0*/0, /* 3 35.0*/0, /* 4 50.0*/0, /* 5 65.0*/0, /* 6 80.0*/0, /* 7 100.0*/0, },
|
|
{/* 2 20 *//* 0 0.0*/17, /* 1 10.0*/10, /* 2 20.0*/0, /* 3 35.0*/0, /* 4 50.0*/0, /* 5 65.0*/0, /* 6 80.0*/0, /* 7 100.0*/0, },
|
|
{/* 3 35 *//* 0 0.0*/23, /* 1 10.0*/17, /* 2 20.0*/10, /* 3 35.0*/0, /* 4 50.0*/0, /* 5 65.0*/0, /* 6 80.0*/0, /* 7 100.0*/0, },
|
|
{/* 4 50 *//* 0 0.0*/28, /* 1 10.0*/23, /* 2 20.0*/17, /* 3 35.0*/10, /* 4 50.0*/0, /* 5 65.0*/0, /* 6 80.0*/0, /* 7 100.0*/0, },
|
|
{/* 5 65 *//* 0 0.0*/32, /* 1 10.0*/28, /* 2 20.0*/23, /* 3 35.0*/17, /* 4 50.0*/10, /* 5 65.0*/0, /* 6 80.0*/0, /* 7 100.0*/0, },
|
|
{/* 6 80 *//* 0 0.0*/35, /* 1 10.0*/32, /* 2 20.0*/28, /* 3 35.0*/23, /* 4 50.0*/17, /* 5 65.0*/10, /* 6 80.0*/0, /* 7 100.0*/0, },
|
|
{/* 7 100 *//* 0 0.0*/37, /* 1 10.0*/35, /* 2 20.0*/32, /* 3 35.0*/28, /* 4 50.0*/23, /* 5 65.0*/17, /* 6 80.0*/10, /* 7 100.0*/0, },
|
|
};
|
|
|
|
static void setMazdaMiataNbTpsTps() {
|
|
setLinearCurve(config->tpsTpsAccelFromRpmBins, 0, 100, 10);
|
|
setLinearCurve(config->tpsTpsAccelToRpmBins, 0, 100, 10);
|
|
copyTable(config->tpsTpsAccelTable, tpsTpsTable);
|
|
}
|
|
|
|
static void setDefaultLambdaTable() {
|
|
static constexpr float mapBins[] = {
|
|
30, 40, 50, 60, 70, 80, 90, 100, 110, 120, 130, 150, 175, 200, 225, 250
|
|
};
|
|
copyArray(config->lambdaLoadBins, mapBins);
|
|
|
|
setRpmTableBin(config->lambdaRpmBins);
|
|
|
|
static constexpr float rowValues[] = {
|
|
1, 1, 1, 1, // 30, 40, 50, 60 kpa
|
|
1, 0.95, 0.92, 0.90, // 70, 80, 90, 100 kpa
|
|
0.89, 0.88, 0.86, 0.84, // 110, 120, 130, 150 kpa
|
|
0.8, 0.77, 0.75, 0.73, // 175, 200, 225, 250 kpa
|
|
};
|
|
|
|
// Set each row to the corresponding value from rowValues
|
|
for (size_t i = 0; i < efi::size(config->lambdaTable); i++) {
|
|
for (size_t j = 0; j < efi::size(config->lambdaTable[i]); j++) {
|
|
config->lambdaTable[i][j] = rowValues[i];
|
|
}
|
|
}
|
|
}
|
|
|
|
void setGdiWallWetting() {
|
|
engineConfiguration->wwaeTau = 0;
|
|
engineConfiguration->wwaeBeta = 0;
|
|
}
|
|
|
|
void setDefaultWallWetting() {
|
|
#if !EFI_UNIT_TEST
|
|
// todo: this is a reasonable default for what kinds of engines exactly?
|
|
engineConfiguration->wwaeTau = 0.3;
|
|
engineConfiguration->wwaeBeta = 0.3;
|
|
#endif // EFI_UNIT_TEST
|
|
|
|
// linear reasonable bins
|
|
setLinearCurve(config->wwCltBins, -40, 100, 1);
|
|
setLinearCurve(config->wwMapBins, 10, 80, 1);
|
|
|
|
// These values are derived from the GM factory tune for a gen3 LS engine
|
|
// Who knows if they're good for anything else, but at least they look nice?
|
|
static constexpr float tauClt[] = {
|
|
1.45, 1.30, 1.17, 1.05, 0.90, 0.82, 0.75, 0.70
|
|
};
|
|
copyArray(config->wwTauCltValues, tauClt);
|
|
|
|
static constexpr float tauMap[] = {
|
|
0.38, 0.55, 0.69, 0.86, 0.90, 0.95, 0.97, 1.00
|
|
};
|
|
copyArray(config->wwTauMapValues, tauMap);
|
|
|
|
static constexpr float betaClt[] = {
|
|
0.73, 0.66, 0.57, 0.46, 0.38, 0.31, 0.24, 0.19
|
|
};
|
|
copyArray(config->wwBetaCltValues, betaClt);
|
|
|
|
static constexpr float betaMap[] = {
|
|
0.21, 0.40, 0.60, 0.79, 0.85, 0.90, 0.95, 1.00
|
|
};
|
|
copyArray(config->wwBetaMapValues, betaMap);
|
|
}
|
|
|
|
static void setDefaultLambdaProtection() {
|
|
engineConfiguration->lambdaProtectionEnable = false;
|
|
|
|
engineConfiguration->lambdaProtectionMinLoad = 60;
|
|
engineConfiguration->lambdaProtectionMinRpm = 2500;
|
|
engineConfiguration->lambdaProtectionMinTps = 50;
|
|
engineConfiguration->lambdaProtectionTimeout = 0.5f;
|
|
|
|
engineConfiguration->lambdaProtectionRestoreLoad = 30;
|
|
engineConfiguration->lambdaProtectionRestoreRpm = 2000;
|
|
engineConfiguration->lambdaProtectionRestoreTps = 20;
|
|
}
|
|
|
|
static void setDefaultPriming() {
|
|
// These defaults are reasonable for ~500cc cylinders
|
|
static constexpr int8_t primeBins[] = { -40, -20, 0, 20, 40, 60, 80, 100 };
|
|
static constexpr uint16_t primeValues[] = { 755, 605, 265, 140, 75, 50, 45, 40 };
|
|
|
|
copyArray(engineConfiguration->primeBins, primeBins);
|
|
copyArray(engineConfiguration->primeValues, primeValues);
|
|
}
|
|
|
|
void setDefaultFuel() {
|
|
// Base injection configuration
|
|
engineConfiguration->isInjectionEnabled = true;
|
|
engineConfiguration->injectionMode = IM_SEQUENTIAL;
|
|
|
|
/**
|
|
* By the way http://users.erols.com/srweiss/tableifc.htm has a LOT of data
|
|
*/
|
|
engineConfiguration->injector.flow = 200;
|
|
engineConfiguration->injectorSecondary.flow = 200;
|
|
engineConfiguration->stoichRatioPrimary = STOICH_RATIO;
|
|
|
|
// 9.0 = E100 pure ethanol
|
|
engineConfiguration->stoichRatioSecondary = 9.0f;
|
|
|
|
// Injector deadtime
|
|
setBosch02880155868(engineConfiguration->injector);
|
|
setBosch02880155868(engineConfiguration->injectorSecondary);
|
|
|
|
// Tables
|
|
setFuelTablesLoadBin(10, 160);
|
|
setRpmTableBin(config->injPhaseRpmBins);
|
|
|
|
setRpmTableBin(config->tpsTspCorrValuesBins);
|
|
setLinearCurve(config->tpsTspCorrValues, 1, 1);
|
|
|
|
setDefaultVETable();
|
|
setDefaultLambdaTable();
|
|
|
|
setLinearCurve(config->injectorStagingLoadBins, 0, 100, 10);
|
|
setRpmTableBin(config->injectorStagingRpmBins);
|
|
|
|
setRpmTableBin(config->mapEstimateRpmBins);
|
|
setLinearCurve(config->mapEstimateTpsBins, 0, 100);
|
|
setTable(config->mapEstimateTable, 60);
|
|
|
|
setTable(config->injectionPhase, PORT_INJECTION_OFFSET);
|
|
|
|
// Charge temperature estimation
|
|
engineConfiguration->tChargeMinRpmMinTps = 0.25;
|
|
engineConfiguration->tChargeMinRpmMaxTps = 0.25;
|
|
engineConfiguration->tChargeMaxRpmMinTps = 0.25;
|
|
engineConfiguration->tChargeMaxRpmMaxTps = 0.9;
|
|
engineConfiguration->tChargeMode = TCHARGE_MODE_RPM_TPS;
|
|
engineConfiguration->tChargeAirCoefMin = 0.098f;
|
|
engineConfiguration->tChargeAirCoefMax = 0.902f;
|
|
engineConfiguration->tChargeAirFlowMax = 153.6f;
|
|
engineConfiguration->tChargeAirIncrLimit = 1.0f;
|
|
engineConfiguration->tChargeAirDecrLimit = 12.5f;
|
|
|
|
// CLT correction table
|
|
setDefaultWarmupFuelEnrichment();
|
|
|
|
// IAT correction table
|
|
// TODO
|
|
|
|
// Closed loop fuel correction
|
|
setDefaultStftSettings();
|
|
|
|
// Decel fuel cut
|
|
setDefaultFuelCutParameters();
|
|
|
|
engineConfiguration->tpsAccelEnrichmentThreshold = 40; // TPS % change, per engine cycle
|
|
|
|
setDefaultWallWetting();
|
|
|
|
// TPS/TPS AE curve
|
|
setMazdaMiataNbTpsTps();
|
|
|
|
// Some reasonable reference pressure that many vehicles use
|
|
engineConfiguration->fuelReferencePressure = 300;
|
|
|
|
// Lambda protection defaults
|
|
setDefaultLambdaProtection();
|
|
|
|
setDefaultPriming();
|
|
|
|
// Cut at 110% instantly
|
|
engineConfiguration->maxInjectorDutyInstant = 110;
|
|
// Cut at 96% after 0.5 second
|
|
engineConfiguration->maxInjectorDutySustained = 96;
|
|
engineConfiguration->maxInjectorDutySustainedTimeout = 0.5f;
|
|
}
|