rusefi-full/unit_tests/test_basic_math/test_find_index.cpp

114 lines
2.7 KiB
C++
Raw Normal View History

2015-07-10 06:01:56 -07:00
/*
* test_find_index.cpp
*
* Created on: Oct 30, 2013
2018-01-20 17:42:19 -08:00
* @author Andrey Belomutskiy, (c) 2012-2018
2015-07-10 06:01:56 -07:00
*/
2018-09-16 19:39:46 -07:00
#include "global.h"
2015-07-10 06:01:56 -07:00
#include "engine_math.h"
#include "interpolation.h"
2018-03-04 20:08:32 -08:00
#include "unit_test_framework.h"
2015-07-10 06:01:56 -07:00
static int testIndex(const int expected, const float array[], int size, float value) {
assertEquals(expected, findIndex(array, size, value));
assertEquals(expected, findIndex2(array, size, value));
}
void testFindIndex(void) {
printf("*************************************************** testFindIndex\r\n");
/*
{
// in real life we only use powers of 2 for sizes
float array5[] = { 1, 2, 3, 4, 5 };
const int size5 = 5;
printf("To the right5\r\n");
testIndex(4, array5, size5, 10.0);
printf("Middle2\r\n");
testIndex(3, array5, size5, 4);
printf("Middle2\r\n");
testIndex(2, array5, size5, 3.1);
}
*/
{
float array4[] = { 1, 2, 3, 4 };
const int size4 = 4;
printf("To the left\r\n");
testIndex(-1, array4, size4, -1.0);
printf("To the right4\r\n");
testIndex(3, array4, size4, 10.0);
printf("On the edge\r\n");
testIndex(3, array4, size4, 4.0);
printf("Another1\r\n");
testIndex(2, array4, size4, 3.9);
printf("Another2\r\n");
testIndex(3, array4, size4, 4.1);
printf("Another3\r\n");
testIndex(1, array4, size4, 2);
printf("Left edge1\r\n");
testIndex(0, array4, size4, 1);
printf("Left edge2\r\n");
testIndex(0, array4, size4, 1.1);
printf("Middle\r\n");
testIndex(2, array4, size4, 3);
}
}
void testInterpolate2d(void) {
printf("*************************************************** testInterpolate2d\r\n");
float bins4[] = { 1, 2, 3, 4 };
float values4[] = { 1, 20, 30, 400 };
int size = 4;
int result;
printf("Left size\r\n");
2017-05-29 08:31:07 -07:00
result = interpolate2d("t", 0, bins4, values4, size);
2015-07-10 06:01:56 -07:00
assertEquals(1, result);
printf("Right size\r\n");
2017-05-29 08:31:07 -07:00
result = interpolate2d("t", 10, bins4, values4, size);
2015-07-10 06:01:56 -07:00
assertEquals(400, result);
printf("Middle1\r\n");
2017-05-29 08:31:07 -07:00
result = interpolate2d("t", 3, bins4, values4, size);
2015-07-10 06:01:56 -07:00
assertEquals(30, result);
printf("Middle1\r\n");
2017-05-29 08:31:07 -07:00
result = interpolate2d("t", 3.5, bins4, values4, size);
2015-07-10 06:01:56 -07:00
assertEquals(215, result);
}
void testSetTableValue(void) {
printf("*************************************************** testSetTableValue\r\n");
persistent_config_s config;
for (int i = 0; i < CLT_CURVE_SIZE; i++) {
config.cltFuelCorrBins[i] = -40 + i * 10;
config.cltFuelCorr[i] = 1;
}
assertEquals(1, config.cltFuelCorr[0]);
2017-06-11 12:12:41 -07:00
setCurveValue(config.cltFuelCorrBins, config.cltFuelCorr, CLT_CURVE_SIZE, -40, 1.5);
2015-07-10 06:01:56 -07:00
assertEquals(1.5, config.cltFuelCorr[0]);
2017-06-11 12:12:41 -07:00
setCurveValue(config.cltFuelCorrBins, config.cltFuelCorr, CLT_CURVE_SIZE, -50, 1.4);
2015-07-10 06:01:56 -07:00
assertEquals(1.4, config.cltFuelCorr[0]);
}