genericopenlibs/liboil/tsrc/testsuite/ref/src/mult8x8.c
author hgs
Thu, 05 Aug 2010 23:23:13 +0530
changeset 50 79045913e4e9
permissions -rw-r--r--
201031
Ignore whitespace changes - Everywhere: Within whitespace: At end of lines:
50
hgs
parents:
diff changeset
     1
// Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
hgs
parents:
diff changeset
     2
// All rights reserved.
hgs
parents:
diff changeset
     3
// This component and the accompanying materials are made available
hgs
parents:
diff changeset
     4
// under the terms of "Eclipse Public License v1.0"
hgs
parents:
diff changeset
     5
// which accompanies this distribution, and is available
hgs
parents:
diff changeset
     6
// at the URL "http://www.eclipse.org/legal/epl-v10.html".
hgs
parents:
diff changeset
     7
//
hgs
parents:
diff changeset
     8
// Initial Contributors:
hgs
parents:
diff changeset
     9
// Nokia Corporation - initial contribution.
hgs
parents:
diff changeset
    10
//
hgs
parents:
diff changeset
    11
// Contributors:
hgs
parents:
diff changeset
    12
//
hgs
parents:
diff changeset
    13
// Description:
hgs
parents:
diff changeset
    14
//
hgs
parents:
diff changeset
    15
hgs
parents:
diff changeset
    16
hgs
parents:
diff changeset
    17
hgs
parents:
diff changeset
    18
#ifdef HAVE_CONFIG_H
hgs
parents:
diff changeset
    19
#include "config.h"
hgs
parents:
diff changeset
    20
#endif
hgs
parents:
diff changeset
    21
hgs
parents:
diff changeset
    22
#include <liboil/liboil.h>
hgs
parents:
diff changeset
    23
#include <liboil/liboilfunction.h>
hgs
parents:
diff changeset
    24
#include <stdio.h>
hgs
parents:
diff changeset
    25
#include <string.h>
hgs
parents:
diff changeset
    26
#include <globals.h>
hgs
parents:
diff changeset
    27
hgs
parents:
diff changeset
    28
#define LOG_FILE "c:\\logs\\testsuite_mult8x8_log.txt"
hgs
parents:
diff changeset
    29
#include "std_log_result.h"
hgs
parents:
diff changeset
    30
#include "utils.h"
hgs
parents:
diff changeset
    31
#define LOG_FILENAME_LINE __FILE__, __LINE__
hgs
parents:
diff changeset
    32
#define MAX_SIZE 64
hgs
parents:
diff changeset
    33
#define MAX_SIZE1 10
hgs
parents:
diff changeset
    34
#define RES_SIZE 1
hgs
parents:
diff changeset
    35
hgs
parents:
diff changeset
    36
void create_xml(int result)
hgs
parents:
diff changeset
    37
{
hgs
parents:
diff changeset
    38
    if(result)
hgs
parents:
diff changeset
    39
        assert_failed = 1;
hgs
parents:
diff changeset
    40
    
hgs
parents:
diff changeset
    41
    testResultXml("testsuite_mult8x8");
hgs
parents:
diff changeset
    42
    close_log_file();
hgs
parents:
diff changeset
    43
}
hgs
parents:
diff changeset
    44
hgs
parents:
diff changeset
    45
hgs
parents:
diff changeset
    46
void test_mult8x8_s16()
hgs
parents:
diff changeset
    47
    {
hgs
parents:
diff changeset
    48
    int i;
hgs
parents:
diff changeset
    49
    int16_t mult1[MAX_SIZE],mult2[MAX_SIZE],res[MAX_SIZE],check[MAX_SIZE]={2,16,42,80,108,130,154,180,208,238,14,48,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0,0};
hgs
parents:
diff changeset
    50
    
hgs
parents:
diff changeset
    51
    for(i=0;i<MAX_SIZE;i++)
hgs
parents:
diff changeset
    52
        {
hgs
parents:
diff changeset
    53
        mult1[i]=i+1;
hgs
parents:
diff changeset
    54
        mult2[i]=i+2;
hgs
parents:
diff changeset
    55
        res[i]=0;
hgs
parents:
diff changeset
    56
        }
hgs
parents:
diff changeset
    57
    
hgs
parents:
diff changeset
    58
    oil_mult8x8_s16(res,mult1,mult2,1,3,2);
hgs
parents:
diff changeset
    59
    
hgs
parents:
diff changeset
    60
    for(i=0;i<MAX_SIZE;i++)
hgs
parents:
diff changeset
    61
    if(res[i] == check[i])
hgs
parents:
diff changeset
    62
          {
hgs
parents:
diff changeset
    63
          std_log(LOG_FILENAME_LINE,"oil_mult8x8_s16 successful, res[%d] = %d",i,res[i]);
hgs
parents:
diff changeset
    64
          }
hgs
parents:
diff changeset
    65
     else
hgs
parents:
diff changeset
    66
         {
hgs
parents:
diff changeset
    67
         assert_failed=1;
hgs
parents:
diff changeset
    68
         std_log(LOG_FILENAME_LINE,"oil_mult8x8_s16 unsuccessful,Expected =%d,Obtained =%d",check[i],res[i]);
hgs
parents:
diff changeset
    69
         }
hgs
parents:
diff changeset
    70
    }
hgs
parents:
diff changeset
    71
hgs
parents:
diff changeset
    72
void test_multsum_f32()
hgs
parents:
diff changeset
    73
    {
hgs
parents:
diff changeset
    74
    float mult1[MAX_SIZE1],mult2[MAX_SIZE1];
hgs
parents:
diff changeset
    75
    float res[RES_SIZE]={0},check[RES_SIZE]={404307968.00000000000000};
hgs
parents:
diff changeset
    76
    int i;
hgs
parents:
diff changeset
    77
    
hgs
parents:
diff changeset
    78
    for(i=0;i<MAX_SIZE1;i++)
hgs
parents:
diff changeset
    79
        {
hgs
parents:
diff changeset
    80
         mult1[i]=(i+0.1)*3;
hgs
parents:
diff changeset
    81
         mult2[i]=(i+2)*2;
hgs
parents:
diff changeset
    82
        }
hgs
parents:
diff changeset
    83
    oil_multsum_f32(res,mult1,3,mult2,1,MAX_SIZE1);
hgs
parents:
diff changeset
    84
    
hgs
parents:
diff changeset
    85
    if(comparefloats(res[0],check[0])==0)
hgs
parents:
diff changeset
    86
        {
hgs
parents:
diff changeset
    87
        std_log(LOG_FILENAME_LINE,"oil_multsum_f32 successful, res = %15.14f",res[0]);
hgs
parents:
diff changeset
    88
        }
hgs
parents:
diff changeset
    89
    else
hgs
parents:
diff changeset
    90
        {
hgs
parents:
diff changeset
    91
        assert_failed=1;
hgs
parents:
diff changeset
    92
        std_log(LOG_FILENAME_LINE,"oil_multsum_f32 unsuccessful,Expected =%15.14f,Obtained =%15.14f",check[0],res[0]);
hgs
parents:
diff changeset
    93
        }  
hgs
parents:
diff changeset
    94
    }
hgs
parents:
diff changeset
    95
hgs
parents:
diff changeset
    96
hgs
parents:
diff changeset
    97
void test_multsum_f64()
hgs
parents:
diff changeset
    98
    {
hgs
parents:
diff changeset
    99
    double mult1[MAX_SIZE1],mult2[MAX_SIZE1];
hgs
parents:
diff changeset
   100
    double res[RES_SIZE]={0},check[RES_SIZE]={111.60000000000001};
hgs
parents:
diff changeset
   101
    int i;
hgs
parents:
diff changeset
   102
    
hgs
parents:
diff changeset
   103
    for(i=0;i<MAX_SIZE1;i++)
hgs
parents:
diff changeset
   104
        {
hgs
parents:
diff changeset
   105
         mult1[i]=(i+1.1)*3;
hgs
parents:
diff changeset
   106
         mult2[i]=(i+2)*2;
hgs
parents:
diff changeset
   107
        }
hgs
parents:
diff changeset
   108
    oil_multsum_f64(res,mult1,3,mult2,2,MAX_SIZE1);
hgs
parents:
diff changeset
   109
    
hgs
parents:
diff changeset
   110
    if(comparefloats(res[0],check[0])==0)
hgs
parents:
diff changeset
   111
        {
hgs
parents:
diff changeset
   112
        std_log(LOG_FILENAME_LINE,"oil_multsum_f64 successful, res = %15.14f",res[0]);
hgs
parents:
diff changeset
   113
        }
hgs
parents:
diff changeset
   114
    else
hgs
parents:
diff changeset
   115
        {
hgs
parents:
diff changeset
   116
        assert_failed=1;
hgs
parents:
diff changeset
   117
        std_log(LOG_FILENAME_LINE,"oil_multsum_f64 unsuccessful,Expected =%15.14f,Obtained =%15.14f",check[0],res[0]);
hgs
parents:
diff changeset
   118
        }  
hgs
parents:
diff changeset
   119
    }
hgs
parents:
diff changeset
   120
hgs
parents:
diff changeset
   121
int main ()
hgs
parents:
diff changeset
   122
{
hgs
parents:
diff changeset
   123
  std_log(LOG_FILENAME_LINE,"Test started testsuite_mult8x8");
hgs
parents:
diff changeset
   124
  oil_init ();
hgs
parents:
diff changeset
   125
  
hgs
parents:
diff changeset
   126
  std_log(LOG_FILENAME_LINE,"oil_mult8x8_s16");
hgs
parents:
diff changeset
   127
  test_mult8x8_s16();
hgs
parents:
diff changeset
   128
 
hgs
parents:
diff changeset
   129
  std_log(LOG_FILENAME_LINE,"oil_multsum_f32");
hgs
parents:
diff changeset
   130
  test_multsum_f32();
hgs
parents:
diff changeset
   131
  
hgs
parents:
diff changeset
   132
  std_log(LOG_FILENAME_LINE,"oil_multsum_f64");
hgs
parents:
diff changeset
   133
  test_multsum_f64();
hgs
parents:
diff changeset
   134
  
hgs
parents:
diff changeset
   135
  if(assert_failed)
hgs
parents:
diff changeset
   136
         std_log(LOG_FILENAME_LINE,"Test Fail");
hgs
parents:
diff changeset
   137
  else
hgs
parents:
diff changeset
   138
         std_log(LOG_FILENAME_LINE,"Test Successful");
hgs
parents:
diff changeset
   139
   
hgs
parents:
diff changeset
   140
  create_xml(0);
hgs
parents:
diff changeset
   141
  return 0;
hgs
parents:
diff changeset
   142
}
hgs
parents:
diff changeset
   143