First public contribution.
1 // Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
2 // All rights reserved.
3 // This component and the accompanying materials are made available
4 // under the terms of "Eclipse Public License v1.0"
5 // which accompanies this distribution, and is available
6 // at the URL "http://www.eclipse.org/legal/epl-v10.html".
8 // Initial Contributors:
9 // Nokia Corporation - initial contribution.
22 #include <liboil/liboil.h>
23 #include <liboil/liboilfunction.h>
28 #define LOG_FILE "c:\\logs\\testsuite_diff_log.txt"
29 #include "std_log_result.h"
31 #define LOG_FILENAME_LINE __FILE__, __LINE__
39 void create_xml(int result)
44 testResultXml("testsuite_diff");
49 void test_average_s16_u8(void)
52 int16_t dest[MAX_SIZE];
53 uint8_t src1[MAX_SIZE],src2[MAX_SIZE], src3[MAX_SIZE];
54 int16_t check[MAX_SIZE] = {0,2,3,5,6,8,9,11,5,6,8,9,11,12,14,15,9,11,12,14,15,17,18,20,14,15,17,18,20,21,23,24,18,20,21,23,24,26,27,29,23,24,26,27,29,30,32,33,27,29,30,32,33,35,36,38,32,33,35,36,38,39,41,42};
55 for(i=0;i<MAX_SIZE;i++)
61 std_log(LOG_FILENAME_LINE,"src1[%d] = %d, src2[%d] = %d, src3[%d]=%d ", i,src1[i],i,src2[i],i,src3[i]);
64 oil_diff8x8_average_s16_u8 (dest,src1,2,src2,1,src3,1);
66 for(i=0;i<MAX_SIZE;i++)
68 if(dest[i] == check[i])
70 std_log(LOG_FILENAME_LINE,"oil_diff8x8_average_s16_u8 successful, dest[%d]=%d",i,dest[i]);
75 std_log(LOG_FILENAME_LINE,"oil_diff8x8_average_s16_u8 unsuccessful,Expected =%d,Obtained =%d",check[i],dest[i]);
82 void test_diff_const128_s16_u8()
85 int16_t dest[MAX_SIZE];
86 uint8_t src1[MAX_SIZE];
87 int16_t check[MAX_SIZE]= {-28,-18,-8,2,12,22,32,42,-18,-8,2,12,22,32,42,52,-8,2,12,22,32,42,52,62,2,12,22,32,42,52,62,72,12,22,32,42,52,62,72,82,22,32,42,52,62,72,82,92,32,42,52,62,72,82,92,102,42,52,62,72,82,92,102,112};
88 for(i=0;i<MAX_SIZE;i++)
92 std_log(LOG_FILENAME_LINE,"src1[%d] = %d", i,src1[i]);
95 oil_diff8x8_const128_s16_u8(dest,src1,1);
97 for(i=0;i<MAX_SIZE;i++)
99 if(dest[i]== check[i])
101 std_log(LOG_FILENAME_LINE,"oil_diff8x8_const128_s16_u8 successful,dest[%d]=%d",i,dest[i]);
106 std_log(LOG_FILENAME_LINE,"oil_diff8x8_const128_s16_u8 unsuccessful,Expected =%d,Obtained =%d",check[i],dest[i]);
112 void test_diff8x8_s16_u8()
115 uint8_t src1[MAX_SIZE], src2[MAX_SIZE];
116 int16_t dest[MAX_SIZE],check[MAX_SIZE]= {3,4,5,6,7,8,9,10,7,8,9,10,11,12,13,14,11,12,13,14,15,16,17,18,15,16,17,18,19,20,21,22,19,20,21,22,23,24,25,26,23,24,25,26,27,28,29,30,27,28,29,30,31,32,33,34,31,32,33,34,35,36,37,38};
117 for(i=0;i<MAX_SIZE;i++)
122 std_log(LOG_FILENAME_LINE,"src1[%d]=%d, src2[%d]=%d", i,src1[i],i,src2[i]);
125 oil_diff8x8_s16_u8(dest,src1,2,src2,1);
127 for(i=0;i<MAX_SIZE;i++)
129 if(dest[i]== check[i])
131 std_log(LOG_FILENAME_LINE,"oil_diff8x8_s16_u8 successful, dest[%d]=%d", i,dest[i]);
136 std_log(LOG_FILENAME_LINE,"oil_diff8x8_s16_u8 unsuccessful,Expected =%d,Obtained =%d",check[i],dest[i]);
141 void test_squaresum_f32()
144 float fsrc1[MAX_SIZE1];
145 float fdest[RES_SIZE]={0},fcheck[RES_SIZE]= {1140.00000000000000};
147 for(i=0;i<MAX_SIZE1;i++)
150 std_log(LOG_FILENAME_LINE,"fsrc1[%d]=%15.14f", i,fsrc1[i]);
153 oil_squaresum_f32(fdest,fsrc1,MAX_SIZE1);
155 if(comparefloats(fdest[0],fcheck[0])==0)
157 std_log(LOG_FILENAME_LINE,"oil_squaresum_f32 successful, fdest = %15.14f", fdest[0]);
162 std_log(LOG_FILENAME_LINE,"oil_squaresum_f32 unsuccessful,Expected =%15.14f,Obtained =%15.14f",fcheck[0],fdest[0]);
167 void test_diff_squaresum_f32()
170 float fsrc1[MAX_SIZE1], fsrc2[MAX_SIZE1];
171 float fdest[RES_SIZE]={0},fcheck[RES_SIZE]= {930.00000000000000};
173 for(i=0;i<MAX_SIZE1;i++)
177 std_log(LOG_FILENAME_LINE,"fsrc1[%d]=%15.14f, fsrc2[%d]=%15.14f", i,fsrc1[i],i,fsrc2[i]);
180 oil_diffsquaresum_f32(fdest,fsrc1,4,fsrc2,2,MAX_SIZE1);
182 if(comparefloats(fdest[0],fcheck[0])==0)
184 std_log(LOG_FILENAME_LINE,"oil_diffsquaresum_f32 successful, fdest= %15.14f", fdest[0]);
189 std_log(LOG_FILENAME_LINE,"oil_diffsquaresum_f32 unsuccessful,Expected =%15.14f,Obtained =%15.14f",fcheck[0],fdest[0]);
194 void test_squaresum_f64()
197 double dsrc1[MAX_SIZE1];
198 double ddest[RES_SIZE]={0},dcheck[RES_SIZE]={19668.00000000000000};
200 for(i=0;i<MAX_SIZE1;i++)
203 std_log(LOG_FILENAME_LINE,"dsrc1[%d]=%15.14f", i,dsrc1[i]);
206 oil_squaresum_f64(ddest,dsrc1,MAX_SIZE1);
208 if(comparefloats(ddest[0],dcheck[0])==0)
210 std_log(LOG_FILENAME_LINE,"oil_squaresum_f64 successful, ddest=%15.14f", ddest[0]);
215 std_log(LOG_FILENAME_LINE,"oil_squaresum_f64 unsuccessful,Expected =%15.14f,Obtained =%15.14f",dcheck[0],ddest[0]);
220 void test_diff_squaresum_f64()
223 double dsrc1[MAX_SIZE1], dsrc2[MAX_SIZE1];
224 double ddest[RES_SIZE]={0},dcheck[RES_SIZE]= {539.25000000000000};
226 for(i=0;i<MAX_SIZE1;i++)
230 std_log(LOG_FILENAME_LINE,"dsrc1[%d]=%15.14f, dsrc2[%d]=%15.14f", i,dsrc1[i],i,dsrc2[i]);
233 oil_diffsquaresum_f64(ddest,dsrc1,4,dsrc2,2,MAX_SIZE1);
235 if(comparefloats(ddest[0],dcheck[0])==0)
237 std_log(LOG_FILENAME_LINE,"oil_diffsquaresum_f64 successful, ddest= %15.14f", ddest[0]);
242 std_log(LOG_FILENAME_LINE,"oil_diffsquaresum_f64 unsuccessful,Expected =%15.14f,Obtained =%15.14f",dcheck[0],ddest[0]);
246 void test_squaresum_shifted_s16()
248 int16_t arr1[MAX_SIZE2];
249 uint32_t res[RES_SIZE]={0},check[RES_SIZE]={526};
252 for(i=0;i<MAX_SIZE2;i++)
257 oil_squaresum_shifted_s16(res,arr1,MAX_SIZE2);
261 std_log(LOG_FILENAME_LINE,"oil_squaresum_shifted_s16 successful, res= %d",res[0]);
266 std_log(LOG_FILENAME_LINE,"oil_squaresum_shifted_s16 unsuccessful,Expected =%d,Obtained =%d",check[0],res[0]);
273 double arr[MAX_SIZE2];
274 double res[RES_SIZE]={0},check[RES_SIZE]={40.0};
277 for(i=0;i<MAX_SIZE2;i++)
280 oil_sum_f64(res,arr,2,MAX_SIZE2);
282 if(comparefloats(res[0],check[0])==0)
284 std_log(LOG_FILENAME_LINE,"oil_sum_f64 successful, res= %15.14f",res[0]);
289 std_log(LOG_FILENAME_LINE,"oil_sum_f64 unsuccessful,Expected =%15.14f,Obtained =%15.14f",check[0],res[0]);
295 int16_t arr1[MAX_SIZE2], arr2[MAX_SIZE2],sum[MAX_SIZE2];
296 int res[MAX_SIZE2]={0,4,8,12,16,20,24,28,32,36,40,44,48,52,56};
299 for(i=0;i<MAX_SIZE2;i++)
306 oil_addc_s16(sum,arr1,arr2,MAX_SIZE2);
308 for(i=0;i<MAX_SIZE2;i++)
312 std_log(LOG_FILENAME_LINE,"oil_addc_s16 successful,sum[%d]=%d",i,sum[i]);
317 std_log(LOG_FILENAME_LINE,"oil_addc_s16 unsuccessful,Expected =%d,Obtained =%d",res[i],sum[i]);
323 void test_addc_rshift_s16()
325 int16_t arr1[MAX_SIZE2],arr2[MAX_SIZE2],sum[MAX_SIZE2];
326 int res[MAX_SIZE2]={0,0,1,1,2,2,3,3,4,4,5,5,6,6,7};
329 for(i=0;i<MAX_SIZE2;i++)
336 oil_addc_rshift_s16(sum,arr1,arr2,MAX_SIZE2);
338 for(i=0;i<MAX_SIZE2;i++)
342 std_log(LOG_FILENAME_LINE,"oil_addc_rshift_s16 successful,sum[%d]=%d", sum[i]);
347 std_log(LOG_FILENAME_LINE,"oil_addc_rshift_s16 unsuccessful,Expected =%d,Obtained =%d",res[i],sum[i]);
355 std_log(LOG_FILENAME_LINE,"Test started testsuite_diff");
358 std_log(LOG_FILENAME_LINE,"AVERAGE TEST");
359 test_average_s16_u8();
361 std_log(LOG_FILENAME_LINE,"DIFF8X8 TEST");
362 test_diff8x8_s16_u8();
364 std_log(LOG_FILENAME_LINE,"DIFF_CONST128 TEST");
365 test_diff_const128_s16_u8();
367 std_log(LOG_FILENAME_LINE,"SQUARESUM_F32 TEST");
368 test_squaresum_f32();
370 std_log(LOG_FILENAME_LINE,"DIFF_SQUARESUM32 TEST");
371 test_diff_squaresum_f32();
373 std_log(LOG_FILENAME_LINE,"SQUARESUM_F64 TEST");
374 test_squaresum_f64();
376 std_log(LOG_FILENAME_LINE,"DIFF_SQUARESUM64 TEST");
377 test_diff_squaresum_f64();
379 std_log(LOG_FILENAME_LINE,"SHIFT_SQUARESUM TEST");
380 test_squaresum_shifted_s16();
382 std_log(LOG_FILENAME_LINE,"SUM_F64 TEST");
385 std_log(LOG_FILENAME_LINE,"ADDC_16 TEST");
388 std_log(LOG_FILENAME_LINE,"ADDC_16_RSHIFT TEST");
389 test_addc_rshift_s16();
392 std_log(LOG_FILENAME_LINE,"Test Fail");
394 std_log(LOG_FILENAME_LINE,"Test Successful");