100 lines
3.5 KiB
C++
100 lines
3.5 KiB
C++
/**
|
|
* @file hip9011_lookup.cpp
|
|
* @brief HIP9011-specific table lookups, the other part of implementation is in HIP9011.cpp
|
|
*
|
|
* @date Jan 4, 2015
|
|
* @author Andrey Belomutskiy, (c) 2012-2017
|
|
*/
|
|
|
|
#include "hip9011_lookup.h"
|
|
#include "interpolation.h"
|
|
|
|
/**
|
|
* These are HIP9011 magic values - integrator time constants in uS
|
|
*/
|
|
const int integratorValues[INT_LOOKUP_SIZE] = { 40, 45, 50, 55, 60, 65, 70, 75, 80, 90, 100, 110, 120, 130, 140, 150,
|
|
160, 180, 200, 220, 240, 260, 280, 300, 320, 360, 400, 440, 480, 520, 560, 600 };
|
|
|
|
const float gainLookupInReverseOrder[GAIN_LOOKUP_SIZE] = {
|
|
/* 00 */0.111, 0.118, 0.125, 0.129, 0.133, 0.138, 0.143, 0.148,
|
|
/* 08 */0.154, 0.160, 0.167, 0.174, 0.182, 0.190, 0.200, 0.211,
|
|
/* 16 */0.222, 0.236, 0.250, 0.258, 0.267, 0.276, 0.286, 0.296,
|
|
/* 24 */0.308, 0.320, 0.333, 0.348, 0.364, 0.381, 0.400, 0.421,
|
|
/* 32 */0.444, 0.471, 0.500, 0.548, 0.567, 0.586, 0.607, 0.630,
|
|
/* 40 */0.654, 0.680, 0.708, 0.739, 0.773, 0.810, 0.850, 0.895,
|
|
/* 48 */0.944, 1.000, 1.063, 1.143, 1.185, 1.231, 1.280, 1.333,
|
|
/* 56 */1.391, 1.455, 1.523, 1.600, 1.684, 1.778, 1.882, 2.0 };
|
|
|
|
const float bandFreqLookup[BAND_LOOKUP_SIZE] = { 1.22, 1.26, 1.31, 1.35, 1.4, 1.45, 1.51, 1.57, 1.63, 1.71, 1.78,
|
|
1.87, 1.96, 2.07, 2.18, 2.31, 2.46, 2.54, 2.62, 2.71, 2.81, 2.92, 3.03, 3.15, 3.28, 3.43, 3.59, 3.76, 3.95,
|
|
4.16, 4.39, 4.66, 4.95, 5.12, 5.29, 5.48, 5.68, 5.9, 6.12, 6.37, 6.64, 6.94, 7.27, 7.63, 8.02, 8.46, 8.95, 9.5,
|
|
10.12, 10.46, 10.83, 11.22, 11.65, 12.1, 12.6, 13.14, 13.72, 14.36, 15.07, 15.84, 16.71, 17.67, 18.76, 19.98 };
|
|
|
|
|
|
float rpmLookup[INT_LOOKUP_SIZE];
|
|
|
|
/**
|
|
*
|
|
* We know the set of possible integration times, we know the knock detection window width
|
|
*/
|
|
void prepareHip9011RpmLookup(float angleWindowWidth) {
|
|
/**
|
|
* out binary search method needs increasing order thus the reverse order here
|
|
*/
|
|
for (int i = 0; i < INT_LOOKUP_SIZE; i++) {
|
|
rpmLookup[i] = getRpmByAngleWindowAndTimeUs(integratorValues[INT_LOOKUP_SIZE - i - 1], angleWindowWidth);
|
|
}
|
|
}
|
|
|
|
|
|
/**
|
|
* 'TC is typically TINT/(2*Pi*VOUT)'
|
|
* Knock Sensor Training TPIC8101, page 24
|
|
*/
|
|
float getRpmByAngleWindowAndTimeUs(int timeUs, float angleWindowWidth) {
|
|
/**
|
|
* TINT = TC * 2 * PI * VOUT
|
|
*/
|
|
float integrationTimeUs = timeUs * 2 * PIF * DESIRED_OUTPUT_VALUE;
|
|
/**
|
|
* rpm = 60 seconds / time
|
|
* '60000000' because revolutions per MINUTE in uS conversion
|
|
*/
|
|
float windowWidthMult = angleWindowWidth / 360.0f;
|
|
return 60000000.0f / integrationTimeUs * windowWidthMult;
|
|
}
|
|
|
|
int getIntegrationIndexByRpm(float rpm) {
|
|
int i = findIndex(rpmLookup, INT_LOOKUP_SIZE, (rpm));
|
|
return i == -1 ? INT_LOOKUP_SIZE - 1 : INT_LOOKUP_SIZE - i - 1;
|
|
}
|
|
|
|
int getHip9011GainIndex(float gain) {
|
|
int i = GAIN_INDEX(gain);
|
|
// GAIN_LOOKUP_SIZE is returned for index which is too low
|
|
return i == GAIN_LOOKUP_SIZE ? GAIN_LOOKUP_SIZE - 1 : i;
|
|
}
|
|
|
|
/**
|
|
* @param frequency knock frequencey, in kHz
|
|
*/
|
|
int getHip9011BandIndex(float frequency) {
|
|
return findIndex(bandFreqLookup, BAND_LOOKUP_SIZE, frequency);
|
|
}
|
|
|
|
EXTERN_ENGINE;
|
|
|
|
void initEngineNoiseTable(DECLARE_ENGINE_PARAMETER_F) {
|
|
setRpmTableBin(engineConfiguration->knockNoiseRpmBins, ENGINE_NOISE_CURVE_SIZE);
|
|
|
|
engineConfiguration->knockNoise[0] = 2; // 800
|
|
engineConfiguration->knockNoise[1] = 2; // 1700
|
|
engineConfiguration->knockNoise[2] = 2; // 2600
|
|
engineConfiguration->knockNoise[3] = 2; // 3400
|
|
engineConfiguration->knockNoise[4] = 2; // 4300
|
|
engineConfiguration->knockNoise[5] = 2; // 5200
|
|
engineConfiguration->knockNoise[6] = 2; // 6100
|
|
engineConfiguration->knockNoise[7] = 2; // 7000
|
|
|
|
}
|