Revert "License conversion from Flora to Apache 2.0"
[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 Flora License, Version 1.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://floralicense.org/license/
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 #include <iostream>
18
19 #include <stdlib.h>
20 #include <dali/dali.h>
21 #include <dali-test-suite-utils.h>
22
23 using namespace Dali;
24
25 void utc_dali_math_utils_startup(void)
26 {
27   test_return_value = TET_UNDEF;
28 }
29
30 void utc_dali_math_utils_cleanup(void)
31 {
32   test_return_value = TET_PASS;
33 }
34
35
36 // Positive test case for a method
37 int UtcDaliMathUtilsNextPowerOfTwo(void)
38 {
39   Dali::TestApplication testApp;
40
41   DALI_TEST_EQUALS(NextPowerOfTwo(0), 1u, TEST_LOCATION);
42   DALI_TEST_EQUALS(NextPowerOfTwo(1), 1u, TEST_LOCATION);
43   DALI_TEST_EQUALS(NextPowerOfTwo(2), 2u, TEST_LOCATION);
44   DALI_TEST_EQUALS(NextPowerOfTwo(3), 4u, TEST_LOCATION);
45   DALI_TEST_EQUALS(NextPowerOfTwo(4), 4u, TEST_LOCATION);
46   DALI_TEST_EQUALS(NextPowerOfTwo(5), 8u, TEST_LOCATION);
47   DALI_TEST_EQUALS(NextPowerOfTwo(6), 8u, TEST_LOCATION);
48   DALI_TEST_EQUALS(NextPowerOfTwo(7), 8u, TEST_LOCATION);
49   DALI_TEST_EQUALS(NextPowerOfTwo(8), 8u, TEST_LOCATION);
50   DALI_TEST_EQUALS(NextPowerOfTwo(255), 256u, TEST_LOCATION);
51   DALI_TEST_EQUALS(NextPowerOfTwo(256), 256u, TEST_LOCATION);
52   DALI_TEST_EQUALS(NextPowerOfTwo(257), 512u, TEST_LOCATION);
53   DALI_TEST_EQUALS(NextPowerOfTwo(511), 512u, TEST_LOCATION);
54   DALI_TEST_EQUALS(NextPowerOfTwo(512), 512u, TEST_LOCATION);
55   DALI_TEST_EQUALS(NextPowerOfTwo(513), 1024u, TEST_LOCATION);
56   DALI_TEST_EQUALS(NextPowerOfTwo(768), 1024u, TEST_LOCATION);
57   DALI_TEST_EQUALS(NextPowerOfTwo(1023), 1024u, TEST_LOCATION);
58   DALI_TEST_EQUALS(NextPowerOfTwo(1024), 1024u, TEST_LOCATION);
59   DALI_TEST_EQUALS(NextPowerOfTwo(1025), 2048u, TEST_LOCATION);
60   END_TEST;
61 }
62
63
64 // Positive test case for a method
65 int UtcDaliMathUtilsIsPowerOfTwo(void)
66 {
67   Dali::TestApplication testApp;
68
69   DALI_TEST_EQUALS(IsPowerOfTwo(0), false, TEST_LOCATION);
70
71   DALI_TEST_EQUALS(IsPowerOfTwo(1), true, TEST_LOCATION);
72   DALI_TEST_EQUALS(IsPowerOfTwo(2), true, TEST_LOCATION);
73   DALI_TEST_EQUALS(IsPowerOfTwo(3), false, TEST_LOCATION);
74   DALI_TEST_EQUALS(IsPowerOfTwo(4), true, TEST_LOCATION);
75   DALI_TEST_EQUALS(IsPowerOfTwo(5), false, TEST_LOCATION);
76   DALI_TEST_EQUALS(IsPowerOfTwo(6), false, TEST_LOCATION);
77   DALI_TEST_EQUALS(IsPowerOfTwo(7), false, TEST_LOCATION);
78   DALI_TEST_EQUALS(IsPowerOfTwo(8), true, TEST_LOCATION);
79   DALI_TEST_EQUALS(IsPowerOfTwo(255), false, TEST_LOCATION);
80   DALI_TEST_EQUALS(IsPowerOfTwo(256), true, TEST_LOCATION);
81   DALI_TEST_EQUALS(IsPowerOfTwo(257), false, TEST_LOCATION);
82   DALI_TEST_EQUALS(IsPowerOfTwo(511), false, TEST_LOCATION);
83   DALI_TEST_EQUALS(IsPowerOfTwo(512), true, TEST_LOCATION);
84   DALI_TEST_EQUALS(IsPowerOfTwo(513), false, TEST_LOCATION);
85   DALI_TEST_EQUALS(IsPowerOfTwo(768), false, TEST_LOCATION);
86   DALI_TEST_EQUALS(IsPowerOfTwo(1023), false, TEST_LOCATION);
87   DALI_TEST_EQUALS(IsPowerOfTwo(1024), true, TEST_LOCATION);
88   DALI_TEST_EQUALS(IsPowerOfTwo(1025), false, TEST_LOCATION);
89   END_TEST;
90 }
91
92
93
94 // Positive test case for a method
95 int UtcDaliMathUtilsGetRangedEpsilon(void)
96 {
97   Dali::TestApplication testApp;
98
99   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
100   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
101   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 0.099f),  Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
102   DALI_TEST_EQUALS(GetRangedEpsilon(0.099f,  0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
103   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 0.5f),  Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
104   DALI_TEST_EQUALS(GetRangedEpsilon(0.99f, 0.5f),  Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
105   DALI_TEST_EQUALS(GetRangedEpsilon(0.99f, 0.98f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
106   DALI_TEST_EQUALS(GetRangedEpsilon(1.05f, 0.99f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
107   DALI_TEST_EQUALS(GetRangedEpsilon(1.99f, 1.05f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
108
109   DALI_TEST_EQUALS(GetRangedEpsilon(2.0f,  1.99f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
110   DALI_TEST_EQUALS(GetRangedEpsilon(0.05f, 2.0f),  Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
111   DALI_TEST_EQUALS(GetRangedEpsilon(1.0f,  3.0f),  Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
112   DALI_TEST_EQUALS(GetRangedEpsilon(9.99f, 0.5f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
113   DALI_TEST_EQUALS(GetRangedEpsilon(9.99f, 1.5f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
114   DALI_TEST_EQUALS(GetRangedEpsilon(9.99f, 9.99f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
115   DALI_TEST_EQUALS(GetRangedEpsilon(9.99f, 10.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
116   DALI_TEST_EQUALS(GetRangedEpsilon(19.99f, 10.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
117
118   DALI_TEST_EQUALS(GetRangedEpsilon(20.0f, 10.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
119   DALI_TEST_EQUALS(GetRangedEpsilon(20.0f, 30.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
120   DALI_TEST_EQUALS(GetRangedEpsilon(80.0f, 90.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
121   DALI_TEST_EQUALS(GetRangedEpsilon(180.0f, 190.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
122   DALI_TEST_EQUALS(GetRangedEpsilon(185.0f, 190.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
123   DALI_TEST_EQUALS(GetRangedEpsilon(199.0f, 199.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
124
125   DALI_TEST_EQUALS(GetRangedEpsilon(200.0f, 190.0f), Dali::Math::MACHINE_EPSILON_1000, TEST_LOCATION);
126   DALI_TEST_EQUALS(GetRangedEpsilon(0.005f, 1999.0f), Dali::Math::MACHINE_EPSILON_1000, TEST_LOCATION);
127   DALI_TEST_EQUALS(GetRangedEpsilon(2000.0f, 190.0f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
128   DALI_TEST_EQUALS(GetRangedEpsilon(0.005f, 19999.0f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
129
130   DALI_TEST_EQUALS(GetRangedEpsilon(1e07f, 0.99e09f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
131
132
133   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
134   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
135   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -0.099f),  Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
136   DALI_TEST_EQUALS(GetRangedEpsilon(-0.099f, - 0.02f), Dali::Math::MACHINE_EPSILON_0, TEST_LOCATION);
137   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -0.5f),  Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
138   DALI_TEST_EQUALS(GetRangedEpsilon(-0.99f, -0.5f),  Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
139   DALI_TEST_EQUALS(GetRangedEpsilon(-0.99f, -0.98f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
140   DALI_TEST_EQUALS(GetRangedEpsilon(-1.05f, -0.99f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
141   DALI_TEST_EQUALS(GetRangedEpsilon(-1.99f, -1.05f), Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
142
143   DALI_TEST_EQUALS(GetRangedEpsilon(-2.0f, - 1.99f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
144   DALI_TEST_EQUALS(GetRangedEpsilon(-0.05f, -2.0f),  Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
145   DALI_TEST_EQUALS(GetRangedEpsilon(-1.0f, - 3.0f),  Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
146   DALI_TEST_EQUALS(GetRangedEpsilon(-9.99f, -0.5f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
147   DALI_TEST_EQUALS(GetRangedEpsilon(-9.99f, -1.5f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
148   DALI_TEST_EQUALS(GetRangedEpsilon(-9.99f, -9.99f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
149   DALI_TEST_EQUALS(GetRangedEpsilon(-9.99f, -10.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
150   DALI_TEST_EQUALS(GetRangedEpsilon(-19.99f, -10.0f), Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
151
152   DALI_TEST_EQUALS(GetRangedEpsilon(-20.0f, -10.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
153   DALI_TEST_EQUALS(GetRangedEpsilon(-20.0f, -30.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
154   DALI_TEST_EQUALS(GetRangedEpsilon(-80.0f, -90.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
155   DALI_TEST_EQUALS(GetRangedEpsilon(-180.0f, -190.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
156   DALI_TEST_EQUALS(GetRangedEpsilon(-185.0f, -190.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
157   DALI_TEST_EQUALS(GetRangedEpsilon(-199.0f, -199.0f), Dali::Math::MACHINE_EPSILON_100, TEST_LOCATION);
158
159   DALI_TEST_EQUALS(GetRangedEpsilon(-200.0f, -190.0f), Dali::Math::MACHINE_EPSILON_1000, TEST_LOCATION);
160   DALI_TEST_EQUALS(GetRangedEpsilon(-0.005f, -1999.0f), Dali::Math::MACHINE_EPSILON_1000, TEST_LOCATION);
161   DALI_TEST_EQUALS(GetRangedEpsilon(-2000.0f, -190.0f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
162   DALI_TEST_EQUALS(GetRangedEpsilon(-0.005f, -19999.0f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
163
164   DALI_TEST_EQUALS(GetRangedEpsilon(-1e07f, -0.99e09f), Dali::Math::MACHINE_EPSILON_10000, TEST_LOCATION);
165
166
167   END_TEST;
168 }
169
170 // Positive test case for a method
171 int UtcDaliMathUtilsRound(void)
172 {
173   Dali::TestApplication testApp;
174
175   DALI_TEST_EQUALS(Round(1.00001, 4), 1.0f, TEST_LOCATION);
176   DALI_TEST_EQUALS(Round(0.99999f, 4), 1.0f, TEST_LOCATION);
177   DALI_TEST_EQUALS(Round(-1.00001, 4), -1.0f, TEST_LOCATION);
178   DALI_TEST_EQUALS(Round(-0.99999f, 4), -1.0f, TEST_LOCATION);
179   END_TEST;
180 }
181
182 // Positive test case for a method
183 int UtcDaliMathUtilsClamp(void)
184 {
185   Dali::TestApplication testApp;
186
187   //floats
188   DALI_TEST_EQUALS(Clamp(-1.0f, 0.0f, 1.0f), 0.0f, TEST_LOCATION);
189   DALI_TEST_EQUALS(Clamp(0.0f, -1.0f, 1.0f), 0.0f, TEST_LOCATION);
190   DALI_TEST_EQUALS(Clamp(1.0f, 0.0f, 1.0f), 1.0f, TEST_LOCATION);
191   DALI_TEST_EQUALS(Clamp(2.0f, 0.0f, 1.0f), 1.0f, TEST_LOCATION);
192
193   // integers
194   DALI_TEST_EQUALS(Clamp(-10, 0, 10), 0, TEST_LOCATION);
195   DALI_TEST_EQUALS(Clamp(0, -10, 10), 0, TEST_LOCATION);
196   DALI_TEST_EQUALS(Clamp(20, 0, 10), 10, TEST_LOCATION);
197
198   float value=-10.0f, min=-2.0f, max=4.0f;
199   ClampInPlace(value, min, max);
200   DALI_TEST_EQUALS(value, min, 0.001, TEST_LOCATION);
201
202   value = 10.0f;
203   ClampInPlace(value, min, max);
204   DALI_TEST_EQUALS(value, max, 0.001, TEST_LOCATION);
205
206   value = 3.0f;
207   ClampInPlace(value, min, max);
208   DALI_TEST_EQUALS(value, 3.0f, 0.001, TEST_LOCATION);
209   END_TEST;
210 }
211
212 // Positive test case for a method
213 int UtcDaliMathUtilsWrapInDomain(void)
214 {
215   Dali::TestApplication testApp;
216
217   DALI_TEST_EQUALS(WrapInDomain(0.0f, 0.0f, 0.0f), 0.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
218   DALI_TEST_EQUALS(WrapInDomain(-5.0f, 0.0f, 0.0f), 0.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
219   DALI_TEST_EQUALS(WrapInDomain(5.0f, 0.0f, 0.0f), 0.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
220   DALI_TEST_EQUALS(WrapInDomain(0.0f, 0.0f, 10.0f), 0.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
221   DALI_TEST_EQUALS(WrapInDomain(-5.0f, 0.0f, 10.0f), 5.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
222   DALI_TEST_EQUALS(WrapInDomain(5.0f, 0.0f, 10.0f), 5.0f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
223   DALI_TEST_EQUALS(WrapInDomain(-2.5f, 0.0f, 10.0f), 7.5f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
224   DALI_TEST_EQUALS(WrapInDomain(2.5f, 0.0f, 10.0f), 2.5f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
225   DALI_TEST_EQUALS(WrapInDomain(2.5f, 0.0f, 1.0f), 0.5f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
226   DALI_TEST_EQUALS(WrapInDomain(2.5f, -2.0f, -1.0f), -1.5f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
227   DALI_TEST_EQUALS(WrapInDomain(-2.9f, -2.0f, -1.0f), -1.9f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
228   DALI_TEST_EQUALS(WrapInDomain(-1.1f, -2.0f, -1.0f), -1.1f, Dali::Math::MACHINE_EPSILON_1, TEST_LOCATION);
229   END_TEST;
230 }
231
232 // Positive test case for a method
233 int UtcDaliMathUtilsShortestDistanceInDomain(void)
234 {
235   Dali::TestApplication testApp;
236
237   DALI_TEST_EQUALS(ShortestDistanceInDomain(1.0f, 8.0f, 0.0f, 10.0f), -3.0f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
238   DALI_TEST_EQUALS(ShortestDistanceInDomain(5.0f, 8.0f, 0.0f, 10.0f), 3.0f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
239   DALI_TEST_EQUALS(ShortestDistanceInDomain(5.0f, 8.0f, 4.0f, 9.0f), -2.0f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
240   DALI_TEST_EQUALS(ShortestDistanceInDomain(8.0f, 5.0f, 4.0f, 9.0f), 2.0f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
241   DALI_TEST_EQUALS(ShortestDistanceInDomain(0.65f, 0.1f, -1.0f, 1.0f), -0.55f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
242   DALI_TEST_EQUALS(ShortestDistanceInDomain(0.95f, -0.9f, -1.0f, 1.0f), 0.15f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
243   DALI_TEST_EQUALS(ShortestDistanceInDomain(0.0f, -0.9f, -1.0f, 1.0f), -0.9f, Dali::Math::MACHINE_EPSILON_10, TEST_LOCATION);
244   END_TEST;
245 }
246
247 int UtcDaliMathUtilsEquals(void)
248 {
249   float v=0.0f;
250
251   DALI_TEST_CHECK(EqualsZero(v));
252
253   v  = Math::PI;
254   v -= (Math::PI_2 * 2.0f);
255   DALI_TEST_CHECK(EqualsZero(v));
256
257   float w=100.0f;
258   float x=w+1e-8f;
259   DALI_TEST_CHECK( Equals(w, x, GetRangedEpsilon( w, x )) );
260   END_TEST;
261 }