sl@0: /* sl@0: * Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies). sl@0: * All rights reserved. sl@0: * This component and the accompanying materials are made available sl@0: * under the terms of "Eclipse Public License v1.0" sl@0: * which accompanies this distribution, and is available sl@0: * at the URL "http://www.eclipse.org/legal/epl-v10.html". sl@0: * sl@0: * Initial Contributors: sl@0: * Nokia Corporation - initial contribution. sl@0: * sl@0: * Contributors: sl@0: * sl@0: * Description: sl@0: * sl@0: */ sl@0: sl@0: sl@0: #include sl@0: #include sl@0: #include sl@0: #include sl@0: sl@0: #include sl@0: sl@0: #define LOG_FILE "c:\\logs\\testsuite_mas_log.txt" sl@0: #include "std_log_result.h" sl@0: #define LOG_FILENAME_LINE __FILE__, __LINE__ sl@0: sl@0: #define SIZE 20 sl@0: sl@0: void create_xml(int result) sl@0: { sl@0: if(result) sl@0: assert_failed = 1; sl@0: sl@0: testResultXml("testsuite_mas"); sl@0: close_log_file(); sl@0: } sl@0: sl@0: void test_oil_mas10_u8() sl@0: { sl@0: uint8_t input1[2*SIZE]; sl@0: int16_t input2[SIZE/2]; sl@0: int16_t input3[SIZE/10]; sl@0: uint8_t output[SIZE]; sl@0: uint8_t linux_output[] = {17,20,23,26,29,31,34,37,40,43,45,48,51,54,57,60,62,65,68,71}; sl@0: int i,j; sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: input1[i] = i; sl@0: if(i < SIZE/2) sl@0: input2[i] = i*2; sl@0: if(i < SIZE/10) sl@0: input3[i] = i*5; sl@0: } sl@0: sl@0: for(j = SIZE; j < 2*SIZE; j++) sl@0: input1[j] = j; sl@0: sl@0: oil_mas10_u8(output, input1, input2, input3, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas10_u8_l15() sl@0: { sl@0: uint8_t input1[2*SIZE]; sl@0: int16_t input2[SIZE/2]; sl@0: int16_t input3[SIZE/10]; sl@0: uint8_t output[SIZE]; sl@0: uint8_t linux_output[] = {17,20,23,26,29,31,34,37,40,43,45,48,51,54,57,60,62,65,68,71}; sl@0: int i,j; sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: input1[i] = i; sl@0: if(i < SIZE/2) sl@0: input2[i] = i*2; sl@0: if(i < SIZE/10) sl@0: input3[i] = i*5; sl@0: } sl@0: sl@0: for(j = SIZE; j < 2*SIZE; j++) sl@0: input1[j] = j; sl@0: sl@0: oil_mas10_u8_l15(output, input1, input2, input3, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas10_u8_sym_l15() sl@0: { sl@0: uint8_t input1[2*SIZE]; sl@0: int16_t input2[SIZE/2]; sl@0: int16_t input3[SIZE/10]; sl@0: uint8_t output[SIZE]; sl@0: uint8_t linux_output[] = {17,20,23,26,29,31,34,37,40,43,45,48,51,54,57,60,62,65,68,71}; sl@0: int i,j; sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: input1[i] = i; sl@0: if(i < SIZE/2) sl@0: input2[i] = i*2; sl@0: if(i < SIZE/10) sl@0: input3[i] = i*5; sl@0: } sl@0: sl@0: for(j = SIZE; j < 2*SIZE; j++) sl@0: input1[j] = j; sl@0: sl@0: oil_mas10_u8_sym_l15(output, input1, input2, input3, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas12_addc_rshift_decim2_u8() sl@0: { sl@0: uint8_t input[2*SIZE + 12]; sl@0: int16_t taps[12]; sl@0: int16_t offsetshift[2]; sl@0: uint8_t output[SIZE]; sl@0: uint8_t linux_output[] = {31,39,48,56,64,72,81,89,97,105,114,122,130,138,147,155,163,171,180,188}; sl@0: int i,j; sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: input[i] = i; sl@0: if(i < 12) sl@0: taps[i] = i*2; sl@0: if(i < 2) sl@0: offsetshift[i] = i*5; sl@0: } sl@0: sl@0: for(j = SIZE; j < 52; j++) sl@0: input[j] = j; sl@0: sl@0: oil_mas12_addc_rshift_decim2_u8(output, input, taps, offsetshift, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas2_across_add_s16() sl@0: { sl@0: int16_t input1[SIZE]; sl@0: int16_t input2[SIZE]; sl@0: int16_t input3[SIZE]; sl@0: int16_t input4[2]; sl@0: int16_t input5[2]; sl@0: int16_t output[SIZE]; sl@0: uint8_t linux_output[] = {3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22}; sl@0: int i; sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: input1[i] = i+3; sl@0: input2[i] = i*2; sl@0: input3[i] = i*5; sl@0: sl@0: if(i < 2) sl@0: { sl@0: input4[i] = i+10; sl@0: input5[i] = i+20; sl@0: } sl@0: } sl@0: sl@0: oil_mas2_across_add_s16(output, input1, input2, input3, input4, input5, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas2_add_s16() sl@0: { sl@0: int16_t input1[SIZE]; sl@0: int16_t input2[SIZE+1]; sl@0: int16_t input3[2]; sl@0: int16_t input4[2]; sl@0: int16_t output[SIZE]; sl@0: int16_t linux_output[] = {3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22}; sl@0: int i; sl@0: sl@0: for(i = 0; i <= SIZE; i++) sl@0: { sl@0: input2[i] = i*2; sl@0: sl@0: if(i < SIZE) sl@0: { sl@0: input1[i] = i+3; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input3[i] = i*5; sl@0: input4[i] = i+10; sl@0: } sl@0: } sl@0: sl@0: oil_mas2_add_s16(output, input1, input2, input3, input4, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas4_across_add_s16() sl@0: { sl@0: int16_t input1[SIZE]; sl@0: int16_t input2[100]; sl@0: int16_t input3[4]; sl@0: int16_t input4[2]; sl@0: int16_t output[SIZE]; sl@0: int16_t linux_output[] = {19,23,26,30,33,37,40,44,47,51,54,58,61,65,68,72,75,79,82,86}; sl@0: int i; sl@0: sl@0: for(i = 0; i < 100; i++) sl@0: { sl@0: input2[i] = i; sl@0: sl@0: if(i < SIZE) sl@0: { sl@0: input1[i] = i+3; sl@0: } sl@0: sl@0: if(i < 4) sl@0: { sl@0: input3[i] = i*5; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input4[i] = i+10; sl@0: } sl@0: } sl@0: sl@0: oil_mas4_across_add_s16(output, input1, input2, 5, input3, input4, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas4_add_s16() sl@0: { sl@0: int16_t input1[SIZE]; sl@0: int16_t input2[SIZE+3]; sl@0: int16_t input3[4]; sl@0: int16_t input4[2]; sl@0: int16_t output[SIZE]; sl@0: int16_t linux_output[] = {3,4,5,6,7,8,9,10,11,12,13,14,15,16,17,18,19,20,21,22}; sl@0: int i; sl@0: sl@0: for(i = 0; i < SIZE+3; i++) sl@0: { sl@0: input2[i] = i; sl@0: sl@0: if(i < SIZE) sl@0: { sl@0: input1[i] = i+3; sl@0: } sl@0: sl@0: if(i < 4) sl@0: { sl@0: input3[i] = i*5; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input4[i] = i+10; sl@0: } sl@0: } sl@0: sl@0: oil_mas4_add_s16(output, input1, input2, input3, input4, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas8_across_add_s16() sl@0: { sl@0: int16_t input1[SIZE]; sl@0: int16_t input2[SIZE*8]; sl@0: int16_t input3[8]; sl@0: int16_t input4[2]; sl@0: int16_t output[SIZE]; sl@0: int16_t linux_output[] = {139,150,161,172,183,194,205,216,227,238,249,260,271,282,294,305,316,327,338,349}; sl@0: int i; sl@0: sl@0: for(i = 0; i < SIZE*8; i++) sl@0: { sl@0: input2[i] = i; sl@0: sl@0: if(i < SIZE) sl@0: { sl@0: input1[i] = i+3; sl@0: } sl@0: sl@0: if(i < 8) sl@0: { sl@0: input3[i] = i*5; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input4[i] = i+10; sl@0: } sl@0: } sl@0: sl@0: oil_mas8_across_add_s16(output, input1, input2, 5, input3, input4, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas8_across_u8() sl@0: { sl@0: uint8_t input1[SIZE*8]; sl@0: int16_t input2[8]; sl@0: int16_t input3[2]; sl@0: uint8_t output[SIZE]; sl@0: int16_t linux_output[] = {35,36,38,39,41,43,44,46,48,49,51,52,54,56,57,59,61,62,64,65}; sl@0: int i; sl@0: sl@0: for(i = 0; i < SIZE*8; i++) sl@0: { sl@0: input1[i] = i; sl@0: sl@0: if(i < 8) sl@0: { sl@0: input2[i] = i+3; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input3[i] = i*5; sl@0: } sl@0: } sl@0: sl@0: oil_mas8_across_u8(output, input1, 5, input2, input3, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas8_add_s16() sl@0: { sl@0: int16_t input1[SIZE]; sl@0: int16_t input2[SIZE+7]; sl@0: int16_t input3[8]; sl@0: int16_t input4[2]; sl@0: int16_t output[SIZE]; sl@0: int16_t linux_output[] = {3,4,5,7,8,9,10,11,12,13,15,16,17,18,19,20,21,23,24,25}; sl@0: int i; sl@0: sl@0: for(i = 0; i < SIZE+7; i++) sl@0: { sl@0: input2[i] = i; sl@0: sl@0: if(i < SIZE) sl@0: { sl@0: input1[i] = i+3; sl@0: } sl@0: sl@0: if(i < 8) sl@0: { sl@0: input3[i] = i*5; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input4[i] = i*10; sl@0: } sl@0: } sl@0: sl@0: oil_mas8_add_s16(output, input1, input2, input3, input4, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas8_addc_rshift_decim2_u8() sl@0: { sl@0: uint8_t input1[2*(SIZE+9)]; sl@0: int16_t taps[8]; sl@0: int16_t offsetshift[2]; sl@0: uint8_t output[SIZE]; sl@0: int16_t linux_output[] = {7,10,13,16,20,23,26,29,33,36,39,42,46,49,52,55,59,62,65,68}; sl@0: int i; sl@0: sl@0: for(i = 0; i < 2*(SIZE+9); i++) sl@0: { sl@0: input1[i] = i; sl@0: sl@0: if(i < 8) sl@0: { sl@0: taps[i] = i+3; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: offsetshift[i] = i*5; sl@0: } sl@0: } sl@0: sl@0: oil_mas8_addc_rshift_decim2_u8(output, input1, taps, offsetshift, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: sl@0: } sl@0: sl@0: void test_oil_mas8_u8() sl@0: { sl@0: uint8_t input1[SIZE+7]; sl@0: int16_t input2[8]; sl@0: int16_t input3[2]; sl@0: uint8_t output[SIZE]; sl@0: int16_t linux_output[] = {7,8,10,11,13,15,16,18,20,21,23,24,26,28,29,31,33,34,36,37}; sl@0: int i; sl@0: sl@0: for(i = 0; i < SIZE+7; i++) sl@0: { sl@0: input1[i] = i; sl@0: sl@0: if(i < 8) sl@0: { sl@0: input2[i] = i+3; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input3[i] = i*5; sl@0: } sl@0: } sl@0: sl@0: oil_mas8_u8(output, input1, input2, input3, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas8_u8_l15() sl@0: { sl@0: uint8_t input1[SIZE+7]; sl@0: int16_t input2[8]; sl@0: int16_t input3[2]; sl@0: uint8_t output[SIZE]; sl@0: int16_t linux_output[] = {7,8,10,11,13,15,16,18,20,21,23,24,26,28,29,31,33,34,36,37}; sl@0: int i; sl@0: sl@0: for(i = 0; i < SIZE+7; i++) sl@0: { sl@0: input1[i] = i; sl@0: sl@0: if(i < 8) sl@0: { sl@0: input2[i] = i+3; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input3[i] = i*5; sl@0: } sl@0: } sl@0: sl@0: oil_mas8_u8_l15(output, input1, input2, input3, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != linux_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: void test_oil_mas8_u8_sym_l15() sl@0: { sl@0: uint8_t input1[SIZE+7]; sl@0: int16_t input2[8]; sl@0: int16_t input3[2]; sl@0: uint8_t output[SIZE]; sl@0: int16_t expected_output[] = {7,8,10,11,13,15,16,18,20,21,23,24,26,28,29,31,33,34,36,37}; sl@0: int i; sl@0: sl@0: for(i = 0; i < SIZE+7; i++) sl@0: { sl@0: input1[i] = i; sl@0: sl@0: if(i < 8) sl@0: { sl@0: input2[i] = i+3; sl@0: } sl@0: sl@0: if(i < 2) sl@0: { sl@0: input3[i] = i*5; sl@0: } sl@0: } sl@0: sl@0: oil_mas8_u8_sym_l15(output, input1, input2, input3, SIZE); sl@0: sl@0: for(i = 0; i < SIZE; i++) sl@0: { sl@0: if(output[i] != expected_output[i]) sl@0: { sl@0: std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,expected_output[i],output[i]); sl@0: assert_failed = 1; sl@0: } sl@0: } sl@0: } sl@0: sl@0: int main (int argc, char *argv[]) sl@0: { sl@0: oil_init (); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas10_u8 TEST"); sl@0: test_oil_mas10_u8(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas10_u8_l15 TEST"); sl@0: test_oil_mas10_u8_l15(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas10_u8_sym_l15 TEST"); sl@0: test_oil_mas10_u8_sym_l15(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas12_addc_rshift_decim2_u8 TEST"); sl@0: test_oil_mas12_addc_rshift_decim2_u8(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas2_across_add_s16 TEST"); sl@0: test_oil_mas2_across_add_s16(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas2_add_s16 TEST"); sl@0: test_oil_mas2_add_s16(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas4_across_add_s16 TEST"); sl@0: test_oil_mas4_across_add_s16(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas4_add_s16 TEST"); sl@0: test_oil_mas4_add_s16(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas8_across_add_s16 TEST"); sl@0: test_oil_mas8_across_add_s16(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas8_across_u8 TEST"); sl@0: test_oil_mas8_across_u8(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas8_add_s16 TEST"); sl@0: test_oil_mas8_add_s16(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas8_addc_rshift_decim2_u8 TEST"); sl@0: test_oil_mas8_addc_rshift_decim2_u8(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas8_u8 TEST"); sl@0: test_oil_mas8_u8(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas8_u8_l15 TEST"); sl@0: test_oil_mas8_u8_l15(); sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: std_log(LOG_FILENAME_LINE,"START oil_mas8_u8_sym_l15 TEST"); sl@0: test_oil_mas8_u8_sym_l15(); //Getting different result than linux sl@0: std_log(LOG_FILENAME_LINE,"END TEST\n"); sl@0: sl@0: if(assert_failed) sl@0: std_log(LOG_FILENAME_LINE,"Test Failed"); sl@0: else sl@0: std_log(LOG_FILENAME_LINE,"Test Successful"); sl@0: sl@0: create_xml(0); sl@0: return 0; sl@0: } sl@0: