Formatting automated-tests
[platform/core/uifw/dali-core.git] / automated-tests / src / dali / utc-Dali-MathUtils.cpp
1 /*
2  * Copyright (c) 2014 Samsung Electronics Co., Ltd.
3  *
4  * Licensed under the Apache License, Version 2.0 (the "License");
5  * you may not use this file except in compliance with the License.
6  * You may obtain a copy of the License at
7  *
8  * http://www.apache.org/licenses/LICENSE-2.0
9  *
10  * Unless required by applicable law or agreed to in writing, software
11  * distributed under the License is distributed on an "AS IS" BASIS,
12  * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
13  * See the License for the specific language governing permissions and
14  * limitations under the License.
15  *
16  */
17
18 #include <dali-test-suite-utils.h>
19 #include <dali/public-api/dali-core.h>
20 #include <stdlib.h>
21
22 #include <iostream>
23
24 using namespace Dali;
25
26 void utc_dali_math_utils_startup(void)
27 {
28   test_return_value = TET_UNDEF;
29 }
30
31 void utc_dali_math_utils_cleanup(void)
32 {
33   test_return_value = TET_PASS;
34 }
35
36 int UtcDaliMathUtilsIsPowerOfTwo(void)
37 {
38   Dali::TestApplication testApp;
39   DALI_TEST_EQUALS(IsPowerOfTwo(0), false, TEST_LOCATION);
40
41   DALI_TEST_EQUALS(IsPowerOfTwo(1), true, TEST_LOCATION);
42   DALI_TEST_EQUALS(IsPowerOfTwo(2), true, TEST_LOCATION);
43   DALI_TEST_EQUALS(IsPowerOfTwo(3), false, TEST_LOCATION);
44   DALI_TEST_EQUALS(IsPowerOfTwo(4), true, TEST_LOCATION);
45   DALI_TEST_EQUALS(IsPowerOfTwo(5), false, TEST_LOCATION);
46   DALI_TEST_EQUALS(IsPowerOfTwo(6), false, TEST_LOCATION);
47   DALI_TEST_EQUALS(IsPowerOfTwo(7), false, TEST_LOCATION);
48   DALI_TEST_EQUALS(IsPowerOfTwo(8), true, TEST_LOCATION);
49   DALI_TEST_EQUALS(IsPowerOfTwo(255), false, TEST_LOCATION);
50   DALI_TEST_EQUALS(IsPowerOfTwo(256), true, TEST_LOCATION);
51   DALI_TEST_EQUALS(IsPowerOfTwo(257), false, TEST_LOCATION);
52   DALI_TEST_EQUALS(IsPowerOfTwo(511), false, TEST_LOCATION);
53   DALI_TEST_EQUALS(IsPowerOfTwo(512), true, TEST_LOCATION);
54   DALI_TEST_EQUALS(IsPowerOfTwo(513), false, TEST_LOCATION);
55   DALI_TEST_EQUALS(IsPowerOfTwo(768), false, TEST_LOCATION);
56   DALI_TEST_EQUALS(IsPowerOfTwo(1023), false, TEST_LOCATION);
57   DALI_TEST_EQUALS(IsPowerOfTwo(1024), true, TEST_LOCATION);
58   DALI_TEST_EQUALS(IsPowerOfTwo(1025), false, TEST_LOCATION);
59
60   END_TEST;
61 }
62
63 int UtcDaliMathUtilsNextPowerOfTwoP(void)
64 {
65   Dali::TestApplication testApp;
66
67   DALI_TEST_EQUALS(NextPowerOfTwo(0), 1u, TEST_LOCATION);
68   DALI_TEST_EQUALS(NextPowerOfTwo(1), 1u, TEST_LOCATION);
69   DALI_TEST_EQUALS(NextPowerOfTwo(2), 2u, TEST_LOCATION);
70   DALI_TEST_EQUALS(NextPowerOfTwo(3), 4u, TEST_LOCATION);
71   DALI_TEST_EQUALS(NextPowerOfTwo(4), 4u, TEST_LOCATION);
72   DALI_TEST_EQUALS(NextPowerOfTwo(5), 8u, TEST_LOCATION);
73   DALI_TEST_EQUALS(NextPowerOfTwo(6), 8u, TEST_LOCATION);
74   DALI_TEST_EQUALS(NextPowerOfTwo(7), 8u, TEST_LOCATION);
75   DALI_TEST_EQUALS(NextPowerOfTwo(8), 8u, TEST_LOCATION);
76   DALI_TEST_EQUALS(NextPowerOfTwo(255), 256u, TEST_LOCATION);
77   DALI_TEST_EQUALS(NextPowerOfTwo(256), 256u, TEST_LOCATION);
78   DALI_TEST_EQUALS(NextPowerOfTwo(257), 512u, TEST_LOCATION);
79   DALI_TEST_EQUALS(NextPowerOfTwo(511), 512u, TEST_LOCATION);
80   DALI_TEST_EQUALS(NextPowerOfTwo(512), 512u, TEST_LOCATION);
81   DALI_TEST_EQUALS(NextPowerOfTwo(513), 1024u, TEST_LOCATION);
82   DALI_TEST_EQUALS(NextPowerOfTwo(768), 1024u, TEST_LOCATION);
83   DALI_TEST_EQUALS(NextPowerOfTwo(1023), 1024u, TEST_LOCATION);
84   DALI_TEST_EQUALS(NextPowerOfTwo(1024), 1024u, TEST_LOCATION);
85   DALI_TEST_EQUALS(NextPowerOfTwo(1025), 2048u, TEST_LOCATION);
86   END_TEST;
87 }
88
89 int UtcDaliMathUtilsNextPowerOfTwoN(void)
90 {
91   Dali::TestApplication testApp;
92
93   try
94   {
95     NextPowerOfTwo((1u << (sizeof(unsigned) * 8 - 1)) + 1);
96     tet_result(TET_FAIL);
97   }
98   catch(Dali::DaliException& e)
99   {
100     DALI_TEST_PRINT_ASSERT(e);
101     DALI_TEST_ASSERT(e, "Return type cannot represent the next power of two greater than the argument.", TEST_LOCATION);
102   }
103   catch(...)
104   {
105     tet_printf("Assertion test failed - wrong Exception\n");
106     tet_result(TET_FAIL);
107   }
108
109   END_TEST;
110 }
111
112 int UtcDaliMathUtilsClampP(void)
113 {
114   Dali::TestApplication testApp;
115
116   //floats
117   DALI_TEST_EQUALS(Clamp(-1.0f, 0.0f, 1.0f), 0.0f, TEST_LOCATION);
118   DALI_TEST_EQUALS(Clamp(0.0f, -1.0f, 1.0f), 0.0f, TEST_LOCATION);
119   DALI_TEST_EQUALS(Clamp(1.0f, 0.0f, 1.0f), 1.0f, TEST_LOCATION);
120   DALI_TEST_EQUALS(Clamp(2.0f, 0.0f, 1.0f), 1.0f, TEST_LOCATION);
121
122   // integers
123   DALI_TEST_EQUALS(Clamp(-10, 0, 10), 0, TEST_LOCATION);
124   DALI_TEST_EQUALS(Clamp(0, -10, 10), 0, TEST_LOCATION);
125   DALI_TEST_EQUALS(Clamp(20, 0, 10), 10, TEST_LOCATION);
126
127   float value = -10.0f, min = -2.0f, max = 4.0f;
128   ClampInPlace(value, min, max);
129   DALI_TEST_EQUALS(value, min, 0.001, TEST_LOCATION);
130
131   value = 10.0f;
132   ClampInPlace(value, min, max);
133   DALI_TEST_EQUALS(value, max, 0.001, TEST_LOCATION);
134
135   value = 3.0f;
136   ClampInPlace(value, min, max);
137   DALI_TEST_EQUALS(value, 3.0f, 0.001, TEST_LOCATION);
138   END_TEST;
139 }
140
141 int UtcDaliMathUtilsClampInPlaceP(void)
142 {
143   Dali::TestApplication testApp;
144
145   float value = -10.0f, min = -2.0f, max = 4.0f;
146   ClampInPlace(value, min, max);
147   DALI_TEST_EQUALS(value, min, 0.001, TEST_LOCATION);
148
149   value = 10.0f;
150   ClampInPlace(value, min, max);
151   DALI_TEST_EQUALS(value, max, 0.001, TEST_LOCATION);
152
153   value = 3.0f;
154   ClampInPlace(value, min, max);
155   DALI_TEST_EQUALS(value, 3.0f, 0.001, TEST_LOCATION);
156   END_TEST;
157 }
158
159 int UtcDaliMathUtilsLerpP(void)
160 {
161   Dali::TestApplication testApp;
162
163   float offset = 0.0f, low = -2.0f, high = 4.0f;
164   DALI_TEST_EQUALS(Lerp(offset, low, high), low, 0.001, TEST_LOCATION);
165   offset = 1.0f;
166   DALI_TEST_EQUALS(Lerp(offset, low, high), high, 0.001, TEST_LOCATION);
167   offset = 0.5f;
168   DALI_TEST_EQUALS(Lerp(offset, low, high), 1.0f, 0.001, TEST_LOCATION);
169
170   END_TEST;
171 }
172
173 int UtcDaliMathUtilsGetRangedEpsilonP(void)
174 {
175   Dali::TestApplication testApp;
176
177   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
178   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
179   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 0.099f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
180   DALI_TEST_EQUALS(GetRangedEpsilon(0.099f, 0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
181   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 0.5f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
182   DALI_TEST_EQUALS(GetRangedEpsilon(0.99f, 0.5f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
183   DALI_TEST_EQUALS(GetRangedEpsilon(0.99f, 0.98f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
184   DALI_TEST_EQUALS(GetRangedEpsilon(1.05f, 0.99f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
185   DALI_TEST_EQUALS(GetRangedEpsilon(1.99f, 1.05f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
186
187   DALI_TEST_EQUALS(GetRangedEpsilon(2.0f, 1.99f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
188   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 2.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
189   DALI_TEST_EQUALS(GetRangedEpsilon(1.0f, 3.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
190   DALI_TEST_EQUALS(GetRangedEpsilon(9.99f, 0.5f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
191   DALI_TEST_EQUALS(GetRangedEpsilon(9.99f, 1.5f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
192   DALI_TEST_EQUALS(GetRangedEpsilon(9.99f, 9.99f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
193   DALI_TEST_EQUALS(GetRangedEpsilon(9.99f, 10.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
194   DALI_TEST_EQUALS(GetRangedEpsilon(19.99f, 10.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
195
196   DALI_TEST_EQUALS(GetRangedEpsilon(20.0f, 10.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
197   DALI_TEST_EQUALS(GetRangedEpsilon(20.0f, 30.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
198   DALI_TEST_EQUALS(GetRangedEpsilon(80.0f, 90.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
199   DALI_TEST_EQUALS(GetRangedEpsilon(180.0f, 190.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
200   DALI_TEST_EQUALS(GetRangedEpsilon(185.0f, 190.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
201   DALI_TEST_EQUALS(GetRangedEpsilon(199.0f, 199.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
202
203   DALI_TEST_EQUALS(GetRangedEpsilon(200.0f, 190.0f), Dali::Math::MACHINE_EPSILON_1000, TEST_LOCATION);
204   DALI_TEST_EQUALS(GetRangedEpsilon(0.005f, 1999.0f), Dali::Math::MACHINE_EPSILON_1000, TEST_LOCATION);
205   DALI_TEST_EQUALS(GetRangedEpsilon(2000.0f, 190.0f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
206   DALI_TEST_EQUALS(GetRangedEpsilon(0.005f, 19999.0f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
207
208   DALI_TEST_EQUALS(GetRangedEpsilon(1e07f, 0.99e09f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
209
210   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
211   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
212   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -0.099f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
213   DALI_TEST_EQUALS(GetRangedEpsilon(-0.099f, -0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
214   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -0.5f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
215   DALI_TEST_EQUALS(GetRangedEpsilon(-0.99f, -0.5f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
216   DALI_TEST_EQUALS(GetRangedEpsilon(-0.99f, -0.98f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
217   DALI_TEST_EQUALS(GetRangedEpsilon(-1.05f, -0.99f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
218   DALI_TEST_EQUALS(GetRangedEpsilon(-1.99f, -1.05f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
219
220   DALI_TEST_EQUALS(GetRangedEpsilon(-2.0f, -1.99f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
221   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -2.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
222   DALI_TEST_EQUALS(GetRangedEpsilon(-1.0f, -3.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
223   DALI_TEST_EQUALS(GetRangedEpsilon(-9.99f, -0.5f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
224   DALI_TEST_EQUALS(GetRangedEpsilon(-9.99f, -1.5f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
225   DALI_TEST_EQUALS(GetRangedEpsilon(-9.99f, -9.99f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
226   DALI_TEST_EQUALS(GetRangedEpsilon(-9.99f, -10.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
227   DALI_TEST_EQUALS(GetRangedEpsilon(-19.99f, -10.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
228
229   DALI_TEST_EQUALS(GetRangedEpsilon(-20.0f, -10.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
230   DALI_TEST_EQUALS(GetRangedEpsilon(-20.0f, -30.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
231   DALI_TEST_EQUALS(GetRangedEpsilon(-80.0f, -90.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
232   DALI_TEST_EQUALS(GetRangedEpsilon(-180.0f, -190.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
233   DALI_TEST_EQUALS(GetRangedEpsilon(-185.0f, -190.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
234   DALI_TEST_EQUALS(GetRangedEpsilon(-199.0f, -199.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
235
236   DALI_TEST_EQUALS(GetRangedEpsilon(-200.0f, -190.0f), Dali::Math::MACHINE_EPSILON_1000, TEST_LOCATION);
237   DALI_TEST_EQUALS(GetRangedEpsilon(-0.005f, -1999.0f), Dali::Math::MACHINE_EPSILON_1000, TEST_LOCATION);
238   DALI_TEST_EQUALS(GetRangedEpsilon(-2000.0f, -190.0f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
239   DALI_TEST_EQUALS(GetRangedEpsilon(-0.005f, -19999.0f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
240
241   DALI_TEST_EQUALS(GetRangedEpsilon(-1e07f, -0.99e09f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
242
243   END_TEST;
244 }
245
246 int UtcDaliMathUtilsWrapInDomainP(void)
247 {
248   Dali::TestApplication testApp;
249
250   DALI_TEST_EQUALS(WrapInDomain(0.0f, 0.0f, 0.0f), 0.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
251   DALI_TEST_EQUALS(WrapInDomain(-5.0f, 0.0f, 0.0f), 0.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
252   DALI_TEST_EQUALS(WrapInDomain(5.0f, 0.0f, 0.0f), 0.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
253   DALI_TEST_EQUALS(WrapInDomain(0.0f, 0.0f, 10.0f), 0.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
254   DALI_TEST_EQUALS(WrapInDomain(-5.0f, 0.0f, 10.0f), 5.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
255   DALI_TEST_EQUALS(WrapInDomain(5.0f, 0.0f, 10.0f), 5.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
256   DALI_TEST_EQUALS(WrapInDomain(-2.5f, 0.0f, 10.0f), 7.5f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
257   DALI_TEST_EQUALS(WrapInDomain(2.5f, 0.0f, 10.0f), 2.5f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
258   DALI_TEST_EQUALS(WrapInDomain(2.5f, 0.0f, 1.0f), 0.5f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
259   DALI_TEST_EQUALS(WrapInDomain(2.5f, -2.0f, -1.0f), -1.5f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
260   DALI_TEST_EQUALS(WrapInDomain(-2.9f, -2.0f, -1.0f), -1.9f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
261   DALI_TEST_EQUALS(WrapInDomain(-1.1f, -2.0f, -1.0f), -1.1f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
262   END_TEST;
263 }
264
265 int UtcDaliMathUtilsShortestDistanceInDomainP(void)
266 {
267   Dali::TestApplication testApp;
268
269   DALI_TEST_EQUALS(ShortestDistanceInDomain(1.0f, 8.0f, 0.0f, 10.0f), -3.0f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
270   DALI_TEST_EQUALS(ShortestDistanceInDomain(5.0f, 8.0f, 0.0f, 10.0f), 3.0f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
271   DALI_TEST_EQUALS(ShortestDistanceInDomain(5.0f, 8.0f, 4.0f, 9.0f), -2.0f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
272   DALI_TEST_EQUALS(ShortestDistanceInDomain(8.0f, 5.0f, 4.0f, 9.0f), 2.0f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
273   DALI_TEST_EQUALS(ShortestDistanceInDomain(0.65f, 0.1f, -1.0f, 1.0f), -0.55f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
274   DALI_TEST_EQUALS(ShortestDistanceInDomain(0.95f, -0.9f, -1.0f, 1.0f), 0.15f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
275   DALI_TEST_EQUALS(ShortestDistanceInDomain(0.0f, -0.9f, -1.0f, 1.0f), -0.9f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
276   END_TEST;
277 }
278
279 int UtcDaliMathUtilsEqualsZeroP(void)
280 {
281   float v = 0.0f;
282
283   DALI_TEST_CHECK(EqualsZero(v));
284
285   v = Math::PI;
286   v -= (Math::PI_2 * 2.0f);
287   DALI_TEST_CHECK(EqualsZero(v));
288
289   END_TEST;
290 }
291
292 int UtcDaliMathUtilsEquals01P(void)
293 {
294   float w = 100.0f;
295   float x = w + 1e-8f;
296   DALI_TEST_CHECK(Equals(w, x, GetRangedEpsilon(w, x)));
297   END_TEST;
298 }
299
300 int UtcDaliMathUtilsEquals02P(void)
301 {
302   float w = 100.0f;
303   float x = w + 1e-8f;
304   DALI_TEST_CHECK(Equals(w, x));
305   END_TEST;
306 }
307
308 int UtcDaliMathUtilsRoundP(void)
309 {
310   Dali::TestApplication testApp;
311
312   DALI_TEST_EQUALS(Round(1.00001, 4), 1.0f, TEST_LOCATION);
313   DALI_TEST_EQUALS(Round(0.99999f, 4), 1.0f, TEST_LOCATION);
314   DALI_TEST_EQUALS(Round(-1.00001, 4), -1.0f, TEST_LOCATION);
315   DALI_TEST_EQUALS(Round(-0.99999f, 4), -1.0f, TEST_LOCATION);
316   END_TEST;
317 }