/** * @file table_helper.h * * @date Jul 6, 2014 * @author Andrey Belomutskiy, (c) 2012-2016 */ #ifndef TABLE_HELPER_H_ #define TABLE_HELPER_H_ #include #include "error_handling.h" #include "interpolation.h" #include "efilib.h" // 'random' value to be sure we are not treating any non-zero trash as TRUE #define MAGIC_TRUE_VALUE 153351512 template class Map3D { public: Map3D(const char*name); void init(float table[RPM_BIN_SIZE][LOAD_BIN_SIZE], float loadBins[LOAD_BIN_SIZE], float rpmBins[RPM_BIN_SIZE]); float getValue(float x, float rpm); void setAll(float value); private: float *pointers[LOAD_BIN_SIZE]; float *loadBins; float *rpmBins; int initialized; const char *name; }; template class Table2D { public: Table2D(); void preCalc(float *bin, float *values); float aTable[SIZE]; float bTable[SIZE]; float *bin; }; template Table2D::Table2D() { bin = NULL; } template void Table2D::preCalc(float *bin, float *values) { this->bin = bin; for (int i = 0; i < SIZE - 1; i++) { float x1 = bin[i]; float x2 = bin[i + 1]; if (x1 == x2) { warning(OBD_PCM_Processor_Fault, "preCalc: Same x1 and x2 in interpolate: %f/%f", x1, x2); return; } float y1 = values[i]; float y2 = values[i + 1]; aTable[i] = INTERPOLATION_A(x1, y1, x2, y2); bTable[i] = y1 - aTable[i] * x1; } } template void Map3D::init(float table[RPM_BIN_SIZE][LOAD_BIN_SIZE], float loadBins[LOAD_BIN_SIZE], float rpmBins[RPM_BIN_SIZE]) { for (int k = 0; k < LOAD_BIN_SIZE; k++) { pointers[k] = table[k]; } initialized = MAGIC_TRUE_VALUE; this->loadBins = loadBins; this->rpmBins = rpmBins; } template float Map3D::getValue(float x, float rpm) { efiAssert(initialized == MAGIC_TRUE_VALUE, "map not initialized", NAN); if (cisnan(x)) { warning(OBD_PCM_Processor_Fault, "%s: x is NaN", name); return NAN; } return interpolate3d(x, loadBins, LOAD_BIN_SIZE, rpm, rpmBins, RPM_BIN_SIZE, pointers); } template Map3D::Map3D(const char *name) { this->name = name; initialized = 0; memset(&pointers, 0, sizeof(pointers)); loadBins = NULL; rpmBins = NULL; } template void Map3D::setAll(float value) { efiAssertVoid(initialized == MAGIC_TRUE_VALUE, "map not initialized"); for (int l = 0; l < LOAD_BIN_SIZE; l++) { for (int r = 0; r < RPM_BIN_SIZE; r++) { pointers[l][r] = value; } } } typedef Map3D ign_Map3D_t; typedef Map3D fuel_Map3D_t; typedef Map3D baroCorr_Map3D_t; void setTableBin(float array[], int size, float l, float r); void setTableBin2(float array[], int size, float l, float r, float precision); void setRpmTableBin(float array[], int size); #endif /* TABLE_HELPER_H_ */