2015-07-10 06:01:56 -07:00
|
|
|
/*
|
2018-08-19 07:53:25 -07:00
|
|
|
* @file test_interpolation_3d.cpp
|
|
|
|
*
|
2015-07-10 06:01:56 -07:00
|
|
|
* Created on: Oct 17, 2013
|
2020-01-13 18:57:43 -08:00
|
|
|
* @author Andrey Belomutskiy, (c) 2012-2020
|
2015-07-10 06:01:56 -07:00
|
|
|
*/
|
|
|
|
|
2021-08-03 19:05:01 -07:00
|
|
|
#include "pch.h"
|
|
|
|
|
2015-07-10 06:01:56 -07:00
|
|
|
#include <stdlib.h>
|
|
|
|
|
|
|
|
#include "interpolation.h"
|
|
|
|
|
|
|
|
float rpmBins[5] = { 100, 200, 300, 400, 500 };
|
|
|
|
float mafBins[4] = { 1, 2, 3, 4 };
|
|
|
|
|
2021-05-20 12:31:16 -07:00
|
|
|
float map[4][5] = {
|
|
|
|
{ 1, 2, 3, 4, 4},
|
|
|
|
{ 2, 3, 4, 200, 200 },
|
|
|
|
{ 3, 4, 200, 500, 500 },
|
|
|
|
{ 4, 5, 300, 600, 600 },
|
|
|
|
};
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
static float getValue(float rpm, float maf) {
|
2021-06-03 11:30:25 -07:00
|
|
|
Map3D<5, 4, float, float> x;
|
2021-05-20 12:31:16 -07:00
|
|
|
x.init(map, mafBins, rpmBins);
|
|
|
|
|
|
|
|
return x.getValue(rpm, maf);
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|
|
|
|
|
2021-06-18 19:53:22 -07:00
|
|
|
#define EXPECT_NEAR_M4(a, b) EXPECT_NEAR(a, b, 1e-4)
|
|
|
|
|
2017-04-11 11:34:30 -07:00
|
|
|
static void newTestToComfirmInterpolation() {
|
|
|
|
// here's how the table loos like:
|
|
|
|
//
|
|
|
|
//__RPM_
|
2017-04-11 11:47:17 -07:00
|
|
|
//__300_|_10|200|
|
2017-04-11 11:34:30 -07:00
|
|
|
//__200_|__3|__4|
|
|
|
|
//______|__2|__3|_LOAD
|
|
|
|
|
2021-05-20 12:31:16 -07:00
|
|
|
map[1][2] = 10;
|
2017-04-11 11:47:17 -07:00
|
|
|
|
2017-04-11 11:34:30 -07:00
|
|
|
|
|
|
|
// let's start by testing corners
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(3, getValue(/*rpm*/200, 2));
|
|
|
|
EXPECT_NEAR_M4(4, getValue(/*rpm*/200, 3)) << "low rpm high load";
|
2017-04-11 11:34:30 -07:00
|
|
|
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(10, getValue(/*rpm*/300, 2));
|
|
|
|
EXPECT_NEAR_M4(200, getValue(/*rpm*/300, 3));
|
2017-04-11 11:34:30 -07:00
|
|
|
|
|
|
|
// now testing middles of cell sides
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(3.5, getValue(/*rpm*/200, 2.5)) << "low rpm middle";
|
|
|
|
EXPECT_NEAR_M4(105, getValue(/*rpm*/300, 2.5)) << "high rpm";
|
2017-04-11 11:34:30 -07:00
|
|
|
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(6.5, getValue(/*rpm*/250, 2)) << "low load middle";
|
|
|
|
EXPECT_NEAR_M4(102, getValue(/*rpm*/250, 3));
|
2017-04-11 11:34:30 -07:00
|
|
|
|
2017-04-11 11:47:17 -07:00
|
|
|
// slowly go from middle side towards center
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(16.05, getValue(/*rpm*/250, 2.1)) << "middle @ 2.1";
|
|
|
|
EXPECT_NEAR_M4(25.6, getValue(/*rpm*/250, 2.2)) << "middle @ 2.2";
|
|
|
|
EXPECT_NEAR_M4(35.15, getValue(/*rpm*/250, 2.3)) << "middle @ 2.3";
|
2017-04-11 11:34:30 -07:00
|
|
|
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(54.25, getValue(/*rpm*/250, 2.5)) << "middle cell";
|
2018-08-19 07:53:25 -07:00
|
|
|
|
|
|
|
// issue #604: interpolation outside of the table
|
2018-08-19 08:27:59 -07:00
|
|
|
// X above the range
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(230, getValue(/*rpm*/800, 2.1)) << "800 @ 2.1";
|
|
|
|
EXPECT_NEAR_M4(290, getValue(/*rpm*/800, 2.3)) << "800 @ 2.3";
|
|
|
|
EXPECT_NEAR_M4(530, getValue(/*rpm*/800, 3.3)) << "800 @ 3.3";
|
2018-08-19 08:27:59 -07:00
|
|
|
|
|
|
|
// X below the range
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(2.1, getValue(/*rpm*/-810, 2.1)) << "-810 @ 2.1";
|
|
|
|
EXPECT_NEAR_M4(2.3, getValue(/*rpm*/-820, 2.3)) << "-820 @ 2.3";
|
2018-08-19 08:27:59 -07:00
|
|
|
|
|
|
|
// Y above the range
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(330, getValue(/*rpm*/310, 12.1)) << "310 @ 12.1";
|
|
|
|
EXPECT_NEAR_M4(360, getValue(/*rpm*/320, 12.3)) << "320 @ 12.3";
|
2018-08-19 08:27:59 -07:00
|
|
|
|
|
|
|
// Y below the range
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(3.1, getValue(/*rpm*/310, -12.1)) << "310 @ -12.1";
|
|
|
|
EXPECT_NEAR_M4(3.2, getValue(/*rpm*/320, -12.3)) << "320 @ -12.3";
|
2017-04-11 11:34:30 -07:00
|
|
|
}
|
|
|
|
|
2019-01-14 12:31:56 -08:00
|
|
|
TEST(misc, testInterpolate3d) {
|
2015-07-10 06:01:56 -07:00
|
|
|
printf("*** no interpolation here 1\r\n");
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(2, getValue(100, 2));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
printf("*** no interpolation here 2\r\n");
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(5, getValue(200, 4));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
printf("*** rpm interpolated value expected1\r\n");
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(2.5, getValue(150, 2));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
printf("*** rpm interpolated value expected2\r\n");
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(102, getValue(250, 3));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
printf("*** both rpm and maf interpolated value expected\r\n");
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(361, getValue(335.3, 3.551));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
printf("*** both rpm and maf interpolated value expected 2\r\n");
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(203.6, getValue(410.01, 2.012));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
printf("*** both rpm and maf interpolated value expected 3\r\n");
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(600, getValue(1000000, 1000));
|
2015-07-10 06:01:56 -07:00
|
|
|
|
|
|
|
printf("*** both rpm and maf interpolated value expected 4\r\n");
|
|
|
|
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(4, getValue(410.01, -1));
|
2018-08-19 08:27:59 -07:00
|
|
|
|
|
|
|
|
2021-06-18 19:53:22 -07:00
|
|
|
EXPECT_NEAR_M4(1, getValue(-1, -1));
|
2017-04-11 11:34:30 -07:00
|
|
|
|
|
|
|
newTestToComfirmInterpolation();
|
2015-07-10 06:01:56 -07:00
|
|
|
}
|