diff options
author | Konstantin Käfer <mail@kkaefer.com> | 2014-05-20 12:05:25 +0200 |
---|---|---|
committer | Konstantin Käfer <mail@kkaefer.com> | 2014-05-20 12:05:25 +0200 |
commit | f86fd2f610d1598f66859c6f50668ab5fa404cb2 (patch) | |
tree | 3d9010589862f0b78632ca0e33bdc58dec7fcca8 /test/functions.cpp | |
parent | e0381a782c5d8a9cb1a3931eff886d6f84491196 (diff) | |
download | qtlocation-mapboxgl-f86fd2f610d1598f66859c6f50668ab5fa404cb2.tar.gz |
add function tests
Diffstat (limited to 'test/functions.cpp')
-rw-r--r-- | test/functions.cpp | 157 |
1 files changed, 157 insertions, 0 deletions
diff --git a/test/functions.cpp b/test/functions.cpp new file mode 100644 index 0000000000..87c9a9b9e1 --- /dev/null +++ b/test/functions.cpp @@ -0,0 +1,157 @@ +#include <iostream> +#include "gtest/gtest.h" + +#include <llmr/style/properties.hpp> + +using namespace llmr; + + +TEST(Function, Null) { + EXPECT_EQ(0.0f, llmr::functions::null(0, { })); + EXPECT_EQ(0.0f, llmr::functions::null(0, { 3 })); + EXPECT_EQ(0.0f, llmr::functions::null(0, { 3, 4 })); + EXPECT_EQ(0.0f, llmr::functions::null(4, { })); + EXPECT_EQ(0.0f, llmr::functions::null(4, { 3 })); + EXPECT_EQ(0.0f, llmr::functions::null(4, { 3, 4 })); + EXPECT_EQ(0.0f, llmr::functions::null(22, { })); + EXPECT_EQ(0.0f, llmr::functions::null(22, { 3 })); + EXPECT_EQ(0.0f, llmr::functions::null(22, { 3, 4 })); +} + + +TEST(Function, Constant) { + EXPECT_EQ(2.0f, llmr::functions::constant(0, { 2 })); + EXPECT_EQ(3.8f, llmr::functions::constant(0, { 3.8 })); + EXPECT_EQ(22.0f, llmr::functions::constant(0, { 22 })); + EXPECT_EQ(2.0f, llmr::functions::constant(4, { 2 })); + EXPECT_EQ(3.8f, llmr::functions::constant(4, { 3.8 })); + EXPECT_EQ(22.0f, llmr::functions::constant(4, { 22 })); + EXPECT_EQ(2.0f, llmr::functions::constant(22, { 2 })); + EXPECT_EQ(3.8f, llmr::functions::constant(22, { 3.8 })); + EXPECT_EQ(22.0f, llmr::functions::constant(22, { 22 })); + + EXPECT_EQ(0.0f, llmr::functions::constant(0, { })); + EXPECT_EQ(0.0f, llmr::functions::constant(4, { })); + EXPECT_EQ(0.0f, llmr::functions::constant(22, { })); + + EXPECT_EQ(4.0f, llmr::functions::constant(0, { 4.0f, 63.2f })); + EXPECT_EQ(4.0f, llmr::functions::constant(4, { 4.0f, 63.2f })); + EXPECT_EQ(4.0f, llmr::functions::constant(22, { 4.0f, 63.2f })); +} + + +TEST(Function, Min) { + EXPECT_EQ(0, llmr::functions::min(0, { 2 })); + EXPECT_EQ(0, llmr::functions::min(1.98, { 2 })); + EXPECT_EQ(1, llmr::functions::min(2, { 2 })); + EXPECT_EQ(1, llmr::functions::min(22, { 2 })); + + EXPECT_EQ(0, llmr::functions::min(0, { })); + EXPECT_EQ(0, llmr::functions::min(1.98, { })); + EXPECT_EQ(0, llmr::functions::min(2, { })); + EXPECT_EQ(0, llmr::functions::min(22, { })); + + EXPECT_EQ(0, llmr::functions::min(0, { 2, 8, 13 })); + EXPECT_EQ(0, llmr::functions::min(1.98, { 2, 8, 13 })); + EXPECT_EQ(1, llmr::functions::min(2, { 2, 8, 13 })); + EXPECT_EQ(1, llmr::functions::min(22, { 2, 8, 13 })); +} + + +TEST(Function, Max) { + EXPECT_EQ(1, llmr::functions::max(0, { 2 })); + EXPECT_EQ(1, llmr::functions::max(2, { 2 })); + EXPECT_EQ(0, llmr::functions::max(2.01, { 2 })); + EXPECT_EQ(0, llmr::functions::max(22, { 2 })); + + EXPECT_EQ(0, llmr::functions::max(0, { })); + EXPECT_EQ(0, llmr::functions::max(2, { })); + EXPECT_EQ(0, llmr::functions::max(2.01, { })); + EXPECT_EQ(0, llmr::functions::max(22, { })); + + EXPECT_EQ(1, llmr::functions::max(0, { 2, 8, 13 })); + EXPECT_EQ(1, llmr::functions::max(2, { 2, 8, 13 })); + EXPECT_EQ(0, llmr::functions::max(2.01, { 2, 8, 13 })); + EXPECT_EQ(0, llmr::functions::max(22, { 2, 8, 13 })); +} + + +TEST(Function, Stops) { + // Explicit constant slope in fringe regions. + std::vector<float> slope_1 = { 0, 1.5, /**/ 6, 1.5, /**/ 8, 3, /**/ 22, 3 }; + EXPECT_EQ(1.5, llmr::functions::stops(0, slope_1)); + EXPECT_EQ(1.5, llmr::functions::stops(4, slope_1)); + EXPECT_EQ(1.5, llmr::functions::stops(6, slope_1)); + ASSERT_FLOAT_EQ(2.12132, llmr::functions::stops(7, slope_1)); + EXPECT_EQ(3.0, llmr::functions::stops(8, slope_1)); + EXPECT_EQ(3.0, llmr::functions::stops(9, slope_1)); + EXPECT_EQ(3.0, llmr::functions::stops(15, slope_1)); + EXPECT_EQ(3.0, llmr::functions::stops(22, slope_1)); + + + // Test constant values in fringe regions. + std::vector<float> slope_2 = { 6, 1.5, /**/ 8, 3 }; + EXPECT_EQ(1.5, llmr::functions::stops(0, slope_2)); + EXPECT_EQ(1.5, llmr::functions::stops(4, slope_2)); + EXPECT_EQ(1.5, llmr::functions::stops(6, slope_2)); + ASSERT_FLOAT_EQ(2.12132, llmr::functions::stops(7, slope_2)); + EXPECT_EQ(3.0, llmr::functions::stops(8, slope_2)); + EXPECT_EQ(3.0, llmr::functions::stops(9, slope_2)); + EXPECT_EQ(3.0, llmr::functions::stops(15, slope_2)); + EXPECT_EQ(3.0, llmr::functions::stops(22, slope_2)); + + + // Test uneven number of values. + std::vector<float> slope_3 = { 6, 1.5, 8 }; + EXPECT_EQ(0, llmr::functions::stops(2, slope_3)); + EXPECT_EQ(0, llmr::functions::stops(6, slope_3)); + EXPECT_EQ(0, llmr::functions::stops(12, slope_3)); + + + // Test no values. + std::vector<float> slope_4 = { }; + EXPECT_EQ(1, llmr::functions::stops(2, slope_4)); + EXPECT_EQ(1, llmr::functions::stops(6, slope_4)); + EXPECT_EQ(1, llmr::functions::stops(12, slope_4)); +} + + +TEST(Function, Linear) { + std::vector<float> slope_1 = { /* z_base */ 4, /* val */ 7.5, /* slope */ 2, /* min */ 7.5, /* max */ 20 }; + ASSERT_FLOAT_EQ(7.5, llmr::functions::linear(3, slope_1)); + ASSERT_FLOAT_EQ(7.5, llmr::functions::linear(4, slope_1)); + ASSERT_FLOAT_EQ(8.5, llmr::functions::linear(4.5, slope_1)); + ASSERT_FLOAT_EQ(9.5, llmr::functions::linear(5, slope_1)); + ASSERT_FLOAT_EQ(11.5, llmr::functions::linear(6, slope_1)); + ASSERT_FLOAT_EQ(19.5, llmr::functions::linear(10, slope_1)); + ASSERT_FLOAT_EQ(20, llmr::functions::linear(11, slope_1)); + ASSERT_FLOAT_EQ(20, llmr::functions::linear(20, slope_1)); + + // Invalid number of arguments ==> 0 + std::vector<float> slope_2 = { }; + ASSERT_FLOAT_EQ(0, llmr::functions::linear(3, slope_2)); + ASSERT_FLOAT_EQ(0, llmr::functions::linear(8, slope_2)); + ASSERT_FLOAT_EQ(0, llmr::functions::linear(10, slope_2)); +} + + +TEST(Function, Exponential) { + std::vector<float> slope_1 = { /* z_base */ 4, /* val */ 7.5, /* slope */ 2, /* min */ 7.5, /* max */ 20 }; + ASSERT_FLOAT_EQ(8.6428576, llmr::functions::exponential(3, slope_1)); // 7.5 + 1.75^(3 - 4) * 2 + ASSERT_FLOAT_EQ(9.5, llmr::functions::exponential(4, slope_1)); // 7.5 + 1.75^(4 - 4) * 2 + ASSERT_FLOAT_EQ(10.145751, llmr::functions::exponential(4.5, slope_1)); // 7.5 + 1.75^(4.5 - 4) * 2 + ASSERT_FLOAT_EQ(11, llmr::functions::exponential(5, slope_1)); // 7.5 + 1.75^(5 - 4) * 2 + ASSERT_FLOAT_EQ(13.625, llmr::functions::exponential(6, slope_1)); // 7.5 + 1.75^(6 - 4) * 2 + ASSERT_FLOAT_EQ(18.21875, llmr::functions::exponential(7, slope_1)); // 7.5 + 1.75^(7 - 4) * 2 + ASSERT_FLOAT_EQ(20, llmr::functions::exponential(8, slope_1)); // 7.5 + 1.75^(8 - 4) * 2 ==> clamped to 20 + ASSERT_FLOAT_EQ(20, llmr::functions::exponential(20, slope_1)); // 7.5 + 1.75^(20 - 4) * 2 ==> clamped to 20 + + // Invalid number of arguments ==> 0 + std::vector<float> slope_2 = { }; + ASSERT_FLOAT_EQ(0, llmr::functions::exponential(3, slope_2)); + ASSERT_FLOAT_EQ(0, llmr::functions::exponential(8, slope_2)); + ASSERT_FLOAT_EQ(0, llmr::functions::exponential(10, slope_2)); +} + + + |