summaryrefslogtreecommitdiff
path: root/test/functions.cpp
blob: 87c9a9b9e1e3e1f0116c2d75f3868de98ee8ca4c (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
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));
}