os/ossrv/genericopenlibs/liboil/tsrc/testsuite/composite/src/composite.c
author sl@SLION-WIN7.fritz.box
Fri, 15 Jun 2012 03:10:57 +0200
changeset 0 bde4ae8d615e
permissions -rw-r--r--
First public contribution.
sl@0
     1
/*
sl@0
     2
* Copyright (c) 2010 Nokia Corporation and/or its subsidiary(-ies).
sl@0
     3
* All rights reserved.
sl@0
     4
* This component and the accompanying materials are made available
sl@0
     5
* under the terms of "Eclipse Public License v1.0"
sl@0
     6
* which accompanies this distribution, and is available
sl@0
     7
* at the URL "http://www.eclipse.org/legal/epl-v10.html".
sl@0
     8
*
sl@0
     9
* Initial Contributors:
sl@0
    10
* Nokia Corporation - initial contribution.
sl@0
    11
*
sl@0
    12
* Contributors:
sl@0
    13
*
sl@0
    14
* Description: 
sl@0
    15
*
sl@0
    16
*/
sl@0
    17
sl@0
    18
sl@0
    19
#include <liboil/liboil.h>
sl@0
    20
#include <liboil/liboilfunction.h>
sl@0
    21
#include <stdio.h>
sl@0
    22
#include <stdlib.h>
sl@0
    23
sl@0
    24
#include <liboil/globals.h>
sl@0
    25
sl@0
    26
#define LOG_FILE "c:\\logs\\testsuite_composite_log.txt"
sl@0
    27
#include "std_log_result.h"
sl@0
    28
#define LOG_FILENAME_LINE __FILE__, __LINE__
sl@0
    29
sl@0
    30
#define SIZE    20
sl@0
    31
sl@0
    32
void create_xml(int result)
sl@0
    33
{
sl@0
    34
    if(result)
sl@0
    35
        assert_failed = 1;
sl@0
    36
    
sl@0
    37
    testResultXml("testsuite_composite");
sl@0
    38
    close_log_file();
sl@0
    39
}
sl@0
    40
sl@0
    41
void test_oil_composite_add_argb()
sl@0
    42
    {
sl@0
    43
    uint32_t input[SIZE];
sl@0
    44
    uint32_t output[SIZE];
sl@0
    45
    int i = 0;
sl@0
    46
    
sl@0
    47
    for(i = 0; i< SIZE; i++)
sl@0
    48
        {
sl@0
    49
        input[i] = i*10;
sl@0
    50
        output[i] = i;
sl@0
    51
        }
sl@0
    52
    
sl@0
    53
    oil_composite_add_argb(output, input, SIZE);
sl@0
    54
    
sl@0
    55
    for(i = 0; i<SIZE; i++)
sl@0
    56
        {
sl@0
    57
        if(output[i] != i+input[i])
sl@0
    58
            {
sl@0
    59
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,i+input[i],output[i]);
sl@0
    60
            assert_failed = 1;
sl@0
    61
            }
sl@0
    62
        }
sl@0
    63
    }
sl@0
    64
sl@0
    65
void test_oil_composite_add_argb_const_src()
sl@0
    66
    {
sl@0
    67
    uint32_t constant = 50;
sl@0
    68
    uint32_t output[SIZE];
sl@0
    69
    int i = 0;
sl@0
    70
    
sl@0
    71
    for(i = 0; i< SIZE; i++)
sl@0
    72
        {
sl@0
    73
        output[i] = i;
sl@0
    74
        }
sl@0
    75
    
sl@0
    76
    oil_composite_add_argb_const_src(output, &constant, SIZE);
sl@0
    77
    
sl@0
    78
    for(i = 0; i<SIZE; i++)
sl@0
    79
        {
sl@0
    80
        if(output[i] != i+constant)
sl@0
    81
            {
sl@0
    82
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,i+constant,output[i]);
sl@0
    83
            assert_failed = 1;
sl@0
    84
            }
sl@0
    85
        }
sl@0
    86
    }
sl@0
    87
sl@0
    88
void test_oil_composite_add_u8()
sl@0
    89
    {
sl@0
    90
    uint8_t input[SIZE];
sl@0
    91
    uint8_t output[SIZE];
sl@0
    92
    int i = 0;
sl@0
    93
    
sl@0
    94
    for(i = 0; i< SIZE; i++)
sl@0
    95
        {
sl@0
    96
        input[i] = i*10;
sl@0
    97
        output[i] = i;
sl@0
    98
        }
sl@0
    99
    
sl@0
   100
    oil_composite_add_u8(output, input, SIZE);
sl@0
   101
    
sl@0
   102
    for(i = 0; i<SIZE; i++)
sl@0
   103
        {
sl@0
   104
        if(output[i] != i+input[i])
sl@0
   105
            {
sl@0
   106
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,i+input[i],output[i]);
sl@0
   107
            assert_failed = 1;
sl@0
   108
            }
sl@0
   109
        }
sl@0
   110
    }
sl@0
   111
sl@0
   112
void test_oil_composite_add_u8_const_src()
sl@0
   113
    {
sl@0
   114
    uint8_t constant = 50;
sl@0
   115
    uint8_t output[SIZE];
sl@0
   116
    int i = 0;
sl@0
   117
    
sl@0
   118
    for(i = 0; i< SIZE; i++)
sl@0
   119
        {
sl@0
   120
        output[i] = i;
sl@0
   121
        }
sl@0
   122
    
sl@0
   123
    oil_composite_add_u8_const_src(output, &constant, SIZE);
sl@0
   124
    
sl@0
   125
    for(i = 0; i<SIZE; i++)
sl@0
   126
        {
sl@0
   127
        if(output[i] != i+constant)
sl@0
   128
            {
sl@0
   129
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,i+constant,output[i]);
sl@0
   130
            assert_failed = 1;
sl@0
   131
            }
sl@0
   132
        }
sl@0
   133
    }
sl@0
   134
sl@0
   135
void test_oil_composite_in_argb()
sl@0
   136
    {
sl@0
   137
    uint32_t input[SIZE];
sl@0
   138
    uint8_t mask[SIZE];
sl@0
   139
    uint32_t output[SIZE];
sl@0
   140
    int i = 0;
sl@0
   141
    uint32_t linux_output[] = {0,0,0,0,0,0,0,0,1,1,1,1,1,1,2,2,2,2,3,3};
sl@0
   142
    
sl@0
   143
    for(i = 0; i< SIZE; i++)
sl@0
   144
        {
sl@0
   145
        input[i] = i;
sl@0
   146
        mask[i] = i*2;
sl@0
   147
        }
sl@0
   148
    
sl@0
   149
    oil_composite_in_argb(output, input, mask, SIZE);
sl@0
   150
    
sl@0
   151
    for(i = 0; i < SIZE; i++)
sl@0
   152
        {
sl@0
   153
        if(output[i] != linux_output[i])
sl@0
   154
            {
sl@0
   155
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   156
            assert_failed = 1;
sl@0
   157
            }
sl@0
   158
        }
sl@0
   159
    }
sl@0
   160
sl@0
   161
void test_oil_composite_in_argb_const_mask()
sl@0
   162
    {
sl@0
   163
    uint32_t input[SIZE];
sl@0
   164
    uint8_t constant = 50;
sl@0
   165
    uint32_t output[SIZE];
sl@0
   166
    uint32_t linux_output[] = {0,0,0,1,1,1,1,1,2,2,2,2,2,3,3,3,3,3,4,4};
sl@0
   167
    int i = 0; 
sl@0
   168
    
sl@0
   169
    for(i = 0; i < SIZE; i++)
sl@0
   170
        {
sl@0
   171
        input[i] = i;
sl@0
   172
        }
sl@0
   173
    
sl@0
   174
    oil_composite_in_argb_const_mask(output, input, &constant, SIZE);
sl@0
   175
    
sl@0
   176
    for(i = 0; i < SIZE; i++)
sl@0
   177
        {
sl@0
   178
        if(output[i] != linux_output[i])
sl@0
   179
            {
sl@0
   180
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   181
            assert_failed = 1;
sl@0
   182
            }
sl@0
   183
        }
sl@0
   184
    }
sl@0
   185
sl@0
   186
void test_oil_composite_in_argb_const_src()
sl@0
   187
    {
sl@0
   188
    uint32_t constant = 50;
sl@0
   189
    uint8_t mask[SIZE];
sl@0
   190
    uint32_t output[SIZE];
sl@0
   191
    uint32_t linux_output[] = {0,0,1,1,2,2,2,3,3,4,4,4,5,5,5,6,6,7,7,7};
sl@0
   192
    int i = 0; 
sl@0
   193
    
sl@0
   194
    for(i = 0; i< SIZE; i++)
sl@0
   195
        {
sl@0
   196
        mask[i] = i*2;
sl@0
   197
        }
sl@0
   198
    
sl@0
   199
    oil_composite_in_argb_const_src(output, &constant, mask, SIZE);
sl@0
   200
    
sl@0
   201
    for(i = 0; i < SIZE; i++)
sl@0
   202
        {
sl@0
   203
        if(output[i] != linux_output[i])
sl@0
   204
            {
sl@0
   205
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   206
            assert_failed = 1;
sl@0
   207
            }
sl@0
   208
        }
sl@0
   209
    }
sl@0
   210
sl@0
   211
void test_oil_composite_in_over_argb()
sl@0
   212
    {
sl@0
   213
    uint32_t input[SIZE];
sl@0
   214
    uint8_t mask[SIZE];
sl@0
   215
    uint32_t output[SIZE];
sl@0
   216
    uint32_t linux_output[] = {0,10,20,30,40,50,60,70,81,91,101,111,121,131,142,152,162,172,183,193};
sl@0
   217
    int i = 0;
sl@0
   218
    
sl@0
   219
    for(i = 0; i< SIZE; i++)
sl@0
   220
        {
sl@0
   221
        input[i] = i;
sl@0
   222
        mask[i] = i*2;
sl@0
   223
        output[i] = i*10;
sl@0
   224
        }
sl@0
   225
    
sl@0
   226
    oil_composite_in_over_argb(output, input, mask, SIZE);
sl@0
   227
    
sl@0
   228
    for(i = 0; i < SIZE; i++)
sl@0
   229
        {
sl@0
   230
        if(output[i] != linux_output[i])
sl@0
   231
            {
sl@0
   232
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   233
            assert_failed = 1;
sl@0
   234
            }
sl@0
   235
        }
sl@0
   236
    }
sl@0
   237
sl@0
   238
void test_oil_composite_in_over_argb_const_mask()
sl@0
   239
    {
sl@0
   240
    uint32_t input[SIZE];
sl@0
   241
    uint8_t constant = 50;
sl@0
   242
    uint32_t output[SIZE];
sl@0
   243
    uint32_t linux_output[] = {0,10,20,31,41,51,61,71,82,92,102,112,122,133,143,153,163,173,184,194};
sl@0
   244
    int i = 0;
sl@0
   245
    
sl@0
   246
    for(i = 0; i< SIZE; i++)
sl@0
   247
        {
sl@0
   248
        input[i] = i;
sl@0
   249
        output[i] = i*10;
sl@0
   250
        }
sl@0
   251
    
sl@0
   252
    oil_composite_in_over_argb_const_mask(output, input, &constant, SIZE);
sl@0
   253
    
sl@0
   254
    for(i = 0; i < SIZE; i++)
sl@0
   255
        {
sl@0
   256
        if(output[i] != linux_output[i])
sl@0
   257
            {
sl@0
   258
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   259
            assert_failed = 1;
sl@0
   260
            }
sl@0
   261
        }
sl@0
   262
    }
sl@0
   263
sl@0
   264
void test_oil_composite_in_over_argb_const_src()
sl@0
   265
    {
sl@0
   266
    //uint32_t * i_n, const uint32_t * s1_1, const uint8_t * s2_n, int n
sl@0
   267
    uint32_t constant = 50;
sl@0
   268
    uint8_t mask[SIZE];
sl@0
   269
    uint32_t output[SIZE];
sl@0
   270
    uint32_t linux_output[] = {0,10,21,31,42,52,62,73,83,94,104,114,125,135,145,156,166,177,187,197};
sl@0
   271
    int i = 0;
sl@0
   272
    
sl@0
   273
    for(i = 0; i< SIZE; i++)
sl@0
   274
        {
sl@0
   275
        mask[i] = i*2;
sl@0
   276
        output[i] = i*10;
sl@0
   277
        }
sl@0
   278
    
sl@0
   279
    oil_composite_in_over_argb_const_src(output, &constant, mask, SIZE);
sl@0
   280
    
sl@0
   281
    for(i = 0; i < SIZE; i++)
sl@0
   282
        {
sl@0
   283
        if(output[i] != linux_output[i])
sl@0
   284
            {
sl@0
   285
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   286
            assert_failed = 1;
sl@0
   287
            }
sl@0
   288
        }
sl@0
   289
    }
sl@0
   290
sl@0
   291
void test_oil_composite_over_argb()
sl@0
   292
    {
sl@0
   293
    uint32_t input[SIZE];
sl@0
   294
    uint32_t output[SIZE];
sl@0
   295
    uint32_t linux_output[] = {0,11,22,33,44,55,66,77,88,99,110,121,132,143,154,165,176,187,198,209};
sl@0
   296
    int i = 0;
sl@0
   297
    
sl@0
   298
    for(i = 0; i< SIZE; i++)
sl@0
   299
        {
sl@0
   300
        input[i] = i;
sl@0
   301
        output[i] = i*10;
sl@0
   302
        }
sl@0
   303
    
sl@0
   304
    oil_composite_over_argb(output, input, SIZE);
sl@0
   305
    
sl@0
   306
    for(i = 0; i < SIZE; i++)
sl@0
   307
        {
sl@0
   308
        if(output[i] != linux_output[i])
sl@0
   309
            {
sl@0
   310
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   311
            assert_failed = 1;
sl@0
   312
            }
sl@0
   313
        }
sl@0
   314
    }
sl@0
   315
sl@0
   316
void test_oil_composite_over_argb_const_src()
sl@0
   317
    {
sl@0
   318
    uint32_t constant = 50;
sl@0
   319
    uint32_t output[SIZE];
sl@0
   320
    uint32_t linux_output[] = {50,60,70,80,90,100,110,120,130,140,150,160,170,180,190,200,210,220,230,240};
sl@0
   321
    int i = 0;
sl@0
   322
    
sl@0
   323
    for(i = 0; i< SIZE; i++)
sl@0
   324
        {
sl@0
   325
        output[i] = i*10;
sl@0
   326
        }
sl@0
   327
    
sl@0
   328
    oil_composite_over_argb_const_src(output, &constant, SIZE);
sl@0
   329
    
sl@0
   330
    for(i = 0; i < SIZE; i++)
sl@0
   331
        {
sl@0
   332
        if(output[i] != linux_output[i])
sl@0
   333
            {
sl@0
   334
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   335
            assert_failed = 1;
sl@0
   336
            }
sl@0
   337
        }
sl@0
   338
    }
sl@0
   339
sl@0
   340
void test_oil_composite_over_u8()
sl@0
   341
    {
sl@0
   342
    uint8_t input[SIZE];
sl@0
   343
    uint8_t output[SIZE];
sl@0
   344
    uint32_t linux_output[] = {0,11,22,33,43,54,65,75,85,96,106,116,126,136,146,156,166,176,185,195};
sl@0
   345
    int i = 0;
sl@0
   346
    
sl@0
   347
    for(i = 0; i< SIZE; i++)
sl@0
   348
        {
sl@0
   349
        input[i] = i;
sl@0
   350
        output[i] = i*10;
sl@0
   351
        }
sl@0
   352
    
sl@0
   353
    oil_composite_over_u8(output, input, SIZE);
sl@0
   354
    
sl@0
   355
    for(i = 0; i < SIZE; i++)
sl@0
   356
        {
sl@0
   357
        if(output[i] != linux_output[i])
sl@0
   358
            {
sl@0
   359
            std_log(LOG_FILENAME_LINE, "output[%d]: expected value - %d, actual value - %d", i,linux_output[i],output[i]);
sl@0
   360
            assert_failed = 1;
sl@0
   361
            }
sl@0
   362
        }
sl@0
   363
    }
sl@0
   364
sl@0
   365
int main (int argc, char *argv[])
sl@0
   366
    {
sl@0
   367
    oil_init();
sl@0
   368
    
sl@0
   369
    std_log(LOG_FILENAME_LINE,"START oil_composite_add_argb TEST");
sl@0
   370
    test_oil_composite_add_argb();
sl@0
   371
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   372
    
sl@0
   373
    std_log(LOG_FILENAME_LINE,"START oil_composite_add_argb_const_src TEST");
sl@0
   374
    test_oil_composite_add_argb_const_src();
sl@0
   375
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   376
    
sl@0
   377
    std_log(LOG_FILENAME_LINE,"START oil_composite_add_u8 TEST");
sl@0
   378
    test_oil_composite_add_u8();
sl@0
   379
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   380
    
sl@0
   381
    std_log(LOG_FILENAME_LINE,"START oil_composite_add_u8_const_src TEST");
sl@0
   382
    test_oil_composite_add_u8_const_src();
sl@0
   383
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   384
    
sl@0
   385
    std_log(LOG_FILENAME_LINE,"START oil_composite_in_argb TEST");
sl@0
   386
    test_oil_composite_in_argb();
sl@0
   387
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   388
    
sl@0
   389
    std_log(LOG_FILENAME_LINE,"START oil_composite_in_argb_const_mask TEST");
sl@0
   390
    test_oil_composite_in_argb_const_mask();
sl@0
   391
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   392
    
sl@0
   393
    std_log(LOG_FILENAME_LINE,"START oil_composite_in_argb_const_src TEST");
sl@0
   394
    test_oil_composite_in_argb_const_src();
sl@0
   395
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   396
    
sl@0
   397
    std_log(LOG_FILENAME_LINE,"START oil_composite_in_over_argb TEST");
sl@0
   398
    test_oil_composite_in_over_argb();
sl@0
   399
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   400
    
sl@0
   401
    std_log(LOG_FILENAME_LINE,"START oil_composite_in_over_argb_const_mask TEST");
sl@0
   402
    test_oil_composite_in_over_argb_const_mask();
sl@0
   403
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   404
    
sl@0
   405
    std_log(LOG_FILENAME_LINE,"START oil_composite_add_argb TEST");
sl@0
   406
    test_oil_composite_in_over_argb_const_src();
sl@0
   407
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   408
  
sl@0
   409
    std_log(LOG_FILENAME_LINE,"START oil_composite_over_argb TEST");
sl@0
   410
    test_oil_composite_over_argb();
sl@0
   411
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   412
    
sl@0
   413
    std_log(LOG_FILENAME_LINE,"START oil_composite_over_argb_const_src TEST");
sl@0
   414
    test_oil_composite_over_argb_const_src();
sl@0
   415
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   416
    
sl@0
   417
    std_log(LOG_FILENAME_LINE,"START oil_composite_over_u8 TEST");
sl@0
   418
    test_oil_composite_over_u8();
sl@0
   419
    std_log(LOG_FILENAME_LINE,"END TEST");
sl@0
   420
    
sl@0
   421
    if(assert_failed)
sl@0
   422
      std_log(LOG_FILENAME_LINE,"Test Failed");
sl@0
   423
    else
sl@0
   424
      std_log(LOG_FILENAME_LINE,"Test Successful");
sl@0
   425
    create_xml(0);
sl@0
   426
    return 0;
sl@0
   427
    }
sl@0
   428