Update contrib.
2 * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
4 * This component and the accompanying materials are made available
5 * under the terms of "Eclipse Public License v1.0"
6 * which accompanies this distribution, and is available
7 * at the URL "http://www.eclipse.org/legal/epl-v10.html".
9 * Initial Contributors:
10 * Nokia Corporation - initial contribution.
19 #include <liboil/liboil.h>
20 #include <liboil/liboilfunction.h>
24 #include <liboil/globals.h>
26 #define LOG_FILE "c:\\logs\\testsuite_mas_log.txt"
27 #include "std_log_result.h"
28 #define LOG_FILENAME_LINE __FILE__, __LINE__
32 void create_xml(int result)
37 testResultXml("testsuite_mas");
41 void test_oil_mas10_u8()
43 uint8_t input1[2*SIZE];
44 int16_t input2[SIZE/2];
45 int16_t input3[SIZE/10];
47 uint8_t linux_output[] = {17,20,23,26,29,31,34,37,40,43,45,48,51,54,57,60,62,65,68,71};
50 for(i = 0; i < SIZE; i++)
59 for(j = SIZE; j < 2*SIZE; j++)
62 oil_mas10_u8(output, input1, input2, input3, SIZE);
64 for(i = 0; i < SIZE; i++)
66 if(output[i] != linux_output[i])
68 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
74 void test_oil_mas10_u8_l15()
76 uint8_t input1[2*SIZE];
77 int16_t input2[SIZE/2];
78 int16_t input3[SIZE/10];
80 uint8_t linux_output[] = {17,20,23,26,29,31,34,37,40,43,45,48,51,54,57,60,62,65,68,71};
83 for(i = 0; i < SIZE; i++)
92 for(j = SIZE; j < 2*SIZE; j++)
95 oil_mas10_u8_l15(output, input1, input2, input3, SIZE);
97 for(i = 0; i < SIZE; i++)
99 if(output[i] != linux_output[i])
101 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
107 void test_oil_mas10_u8_sym_l15()
109 uint8_t input1[2*SIZE];
110 int16_t input2[SIZE/2];
111 int16_t input3[SIZE/10];
112 uint8_t output[SIZE];
113 uint8_t linux_output[] = {17,20,23,26,29,31,34,37,40,43,45,48,51,54,57,60,62,65,68,71};
116 for(i = 0; i < SIZE; i++)
125 for(j = SIZE; j < 2*SIZE; j++)
128 oil_mas10_u8_sym_l15(output, input1, input2, input3, SIZE);
130 for(i = 0; i < SIZE; i++)
132 if(output[i] != linux_output[i])
134 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
140 void test_oil_mas12_addc_rshift_decim2_u8()
142 uint8_t input[2*SIZE + 12];
144 int16_t offsetshift[2];
145 uint8_t output[SIZE];
146 uint8_t linux_output[] = {31,39,48,56,64,72,81,89,97,105,114,122,130,138,147,155,163,171,180,188};
149 for(i = 0; i < SIZE; i++)
155 offsetshift[i] = i*5;
158 for(j = SIZE; j < 52; j++)
161 oil_mas12_addc_rshift_decim2_u8(output, input, taps, offsetshift, SIZE);
163 for(i = 0; i < SIZE; i++)
165 if(output[i] != linux_output[i])
167 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
173 void test_oil_mas2_across_add_s16()
175 int16_t input1[SIZE];
176 int16_t input2[SIZE];
177 int16_t input3[SIZE];
180 int16_t output[SIZE];
181 uint8_t linux_output[] = {3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22};
184 for(i = 0; i < SIZE; i++)
197 oil_mas2_across_add_s16(output, input1, input2, input3, input4, input5, SIZE);
199 for(i = 0; i < SIZE; i++)
201 if(output[i] != linux_output[i])
203 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
209 void test_oil_mas2_add_s16()
211 int16_t input1[SIZE];
212 int16_t input2[SIZE+1];
215 int16_t output[SIZE];
216 int16_t linux_output[] = {3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22};
219 for(i = 0; i <= SIZE; i++)
235 oil_mas2_add_s16(output, input1, input2, input3, input4, SIZE);
237 for(i = 0; i < SIZE; i++)
239 if(output[i] != linux_output[i])
241 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
247 void test_oil_mas4_across_add_s16()
249 int16_t input1[SIZE];
253 int16_t output[SIZE];
254 int16_t linux_output[] = {19,23,26,30,33,37,40,44,47,51,54,58,61,65,68,72,75,79,82,86};
257 for(i = 0; i < 100; i++)
277 oil_mas4_across_add_s16(output, input1, input2, 5, input3, input4, SIZE);
279 for(i = 0; i < SIZE; i++)
281 if(output[i] != linux_output[i])
283 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
289 void test_oil_mas4_add_s16()
291 int16_t input1[SIZE];
292 int16_t input2[SIZE+3];
295 int16_t output[SIZE];
296 int16_t linux_output[] = {3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22};
299 for(i = 0; i < SIZE+3; i++)
319 oil_mas4_add_s16(output, input1, input2, input3, input4, SIZE);
321 for(i = 0; i < SIZE; i++)
323 if(output[i] != linux_output[i])
325 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
331 void test_oil_mas8_across_add_s16()
333 int16_t input1[SIZE];
334 int16_t input2[SIZE*8];
337 int16_t output[SIZE];
338 int16_t linux_output[] = {139,150,161,172,183,194,205,216,227,238,249,260,271,282,294,305,316,327,338,349};
341 for(i = 0; i < SIZE*8; i++)
361 oil_mas8_across_add_s16(output, input1, input2, 5, input3, input4, SIZE);
363 for(i = 0; i < SIZE; i++)
365 if(output[i] != linux_output[i])
367 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
373 void test_oil_mas8_across_u8()
375 uint8_t input1[SIZE*8];
378 uint8_t output[SIZE];
379 int16_t linux_output[] = {35,36,38,39,41,43,44,46,48,49,51,52,54,56,57,59,61,62,64,65};
382 for(i = 0; i < SIZE*8; i++)
397 oil_mas8_across_u8(output, input1, 5, input2, input3, SIZE);
399 for(i = 0; i < SIZE; i++)
401 if(output[i] != linux_output[i])
403 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
409 void test_oil_mas8_add_s16()
411 int16_t input1[SIZE];
412 int16_t input2[SIZE+7];
415 int16_t output[SIZE];
416 int16_t linux_output[] = {3,4,5,7,8,9,10,11,12,13,15,16,17,18,19,20,21,23,24,25};
419 for(i = 0; i < SIZE+7; i++)
439 oil_mas8_add_s16(output, input1, input2, input3, input4, SIZE);
441 for(i = 0; i < SIZE; i++)
443 if(output[i] != linux_output[i])
445 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
451 void test_oil_mas8_addc_rshift_decim2_u8()
453 uint8_t input1[2*(SIZE+9)];
455 int16_t offsetshift[2];
456 uint8_t output[SIZE];
457 int16_t linux_output[] = {7,10,13,16,20,23,26,29,33,36,39,42,46,49,52,55,59,62,65,68};
460 for(i = 0; i < 2*(SIZE+9); i++)
471 offsetshift[i] = i*5;
475 oil_mas8_addc_rshift_decim2_u8(output, input1, taps, offsetshift, SIZE);
477 for(i = 0; i < SIZE; i++)
479 if(output[i] != linux_output[i])
481 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
488 void test_oil_mas8_u8()
490 uint8_t input1[SIZE+7];
493 uint8_t output[SIZE];
494 int16_t linux_output[] = {7,8,10,11,13,15,16,18,20,21,23,24,26,28,29,31,33,34,36,37};
497 for(i = 0; i < SIZE+7; i++)
512 oil_mas8_u8(output, input1, input2, input3, SIZE);
514 for(i = 0; i < SIZE; i++)
516 if(output[i] != linux_output[i])
518 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
524 void test_oil_mas8_u8_l15()
526 uint8_t input1[SIZE+7];
529 uint8_t output[SIZE];
530 int16_t linux_output[] = {7,8,10,11,13,15,16,18,20,21,23,24,26,28,29,31,33,34,36,37};
533 for(i = 0; i < SIZE+7; i++)
548 oil_mas8_u8_l15(output, input1, input2, input3, SIZE);
550 for(i = 0; i < SIZE; i++)
552 if(output[i] != linux_output[i])
554 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
560 void test_oil_mas8_u8_sym_l15()
562 uint8_t input1[SIZE+7];
565 uint8_t output[SIZE];
566 int16_t expected_output[] = {7,8,10,11,13,15,16,18,20,21,23,24,26,28,29,31,33,34,36,37};
569 for(i = 0; i < SIZE+7; i++)
584 oil_mas8_u8_sym_l15(output, input1, input2, input3, SIZE);
586 for(i = 0; i < SIZE; i++)
588 if(output[i] != expected_output[i])
590 std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,expected_output[i],output[i]);
596 int main (int argc, char *argv[])
600 std_log(LOG_FILENAME_LINE,"START oil_mas10_u8 TEST");
602 std_log(LOG_FILENAME_LINE,"END TEST\n");
604 std_log(LOG_FILENAME_LINE,"START oil_mas10_u8_l15 TEST");
605 test_oil_mas10_u8_l15();
606 std_log(LOG_FILENAME_LINE,"END TEST\n");
608 std_log(LOG_FILENAME_LINE,"START oil_mas10_u8_sym_l15 TEST");
609 test_oil_mas10_u8_sym_l15();
610 std_log(LOG_FILENAME_LINE,"END TEST\n");
612 std_log(LOG_FILENAME_LINE,"START oil_mas12_addc_rshift_decim2_u8 TEST");
613 test_oil_mas12_addc_rshift_decim2_u8();
614 std_log(LOG_FILENAME_LINE,"END TEST\n");
616 std_log(LOG_FILENAME_LINE,"START oil_mas2_across_add_s16 TEST");
617 test_oil_mas2_across_add_s16();
618 std_log(LOG_FILENAME_LINE,"END TEST\n");
620 std_log(LOG_FILENAME_LINE,"START oil_mas2_add_s16 TEST");
621 test_oil_mas2_add_s16();
622 std_log(LOG_FILENAME_LINE,"END TEST\n");
624 std_log(LOG_FILENAME_LINE,"START oil_mas4_across_add_s16 TEST");
625 test_oil_mas4_across_add_s16();
626 std_log(LOG_FILENAME_LINE,"END TEST\n");
628 std_log(LOG_FILENAME_LINE,"START oil_mas4_add_s16 TEST");
629 test_oil_mas4_add_s16();
630 std_log(LOG_FILENAME_LINE,"END TEST\n");
632 std_log(LOG_FILENAME_LINE,"START oil_mas8_across_add_s16 TEST");
633 test_oil_mas8_across_add_s16();
634 std_log(LOG_FILENAME_LINE,"END TEST\n");
636 std_log(LOG_FILENAME_LINE,"START oil_mas8_across_u8 TEST");
637 test_oil_mas8_across_u8();
638 std_log(LOG_FILENAME_LINE,"END TEST\n");
640 std_log(LOG_FILENAME_LINE,"START oil_mas8_add_s16 TEST");
641 test_oil_mas8_add_s16();
642 std_log(LOG_FILENAME_LINE,"END TEST\n");
644 std_log(LOG_FILENAME_LINE,"START oil_mas8_addc_rshift_decim2_u8 TEST");
645 test_oil_mas8_addc_rshift_decim2_u8();
646 std_log(LOG_FILENAME_LINE,"END TEST\n");
648 std_log(LOG_FILENAME_LINE,"START oil_mas8_u8 TEST");
650 std_log(LOG_FILENAME_LINE,"END TEST\n");
652 std_log(LOG_FILENAME_LINE,"START oil_mas8_u8_l15 TEST");
653 test_oil_mas8_u8_l15();
654 std_log(LOG_FILENAME_LINE,"END TEST\n");
656 std_log(LOG_FILENAME_LINE,"START oil_mas8_u8_sym_l15 TEST");
657 test_oil_mas8_u8_sym_l15(); //Getting different result than linux
658 std_log(LOG_FILENAME_LINE,"END TEST\n");
661 std_log(LOG_FILENAME_LINE,"Test Failed");
663 std_log(LOG_FILENAME_LINE,"Test Successful");