os/ossrv/genericopenlibs/liboil/src/ref/error8x8.c
author sl
Tue, 10 Jun 2014 14:32:02 +0200
changeset 1 260cb5ec6c19
permissions -rw-r--r--
Update contrib.
sl@0
     1
/*
sl@0
     2
 * LIBOIL - Library of Optimized Inner Loops
sl@0
     3
 * Copyright (c) 2003,2004 David A. Schleef <ds@schleef.org>
sl@0
     4
 * All rights reserved.
sl@0
     5
 *
sl@0
     6
 * Redistribution and use in source and binary forms, with or without
sl@0
     7
 * modification, are permitted provided that the following conditions
sl@0
     8
 * are met:
sl@0
     9
 * 1. Redistributions of source code must retain the above copyright
sl@0
    10
 *    notice, this list of conditions and the following disclaimer.
sl@0
    11
 * 2. Redistributions in binary form must reproduce the above copyright
sl@0
    12
 *    notice, this list of conditions and the following disclaimer in the
sl@0
    13
 *    documentation and/or other materials provided with the distribution.
sl@0
    14
 * 
sl@0
    15
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
sl@0
    16
 * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
sl@0
    17
 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
sl@0
    18
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT,
sl@0
    19
 * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
sl@0
    20
 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
sl@0
    21
 * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
sl@0
    22
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT,
sl@0
    23
 * STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING
sl@0
    24
 * IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
sl@0
    25
 * POSSIBILITY OF SUCH DAMAGE.
sl@0
    26
 */
sl@0
    27
//Portions Copyright (c)  2008-2009 Nokia Corporation and/or its subsidiary(-ies). All rights reserved. 
sl@0
    28
sl@0
    29
#ifdef HAVE_CONFIG_H
sl@0
    30
#include "config.h"
sl@0
    31
#endif
sl@0
    32
sl@0
    33
#include <liboil/liboilfunction.h>
sl@0
    34
sl@0
    35
sl@0
    36
/**
sl@0
    37
 * oil_err_intra8x8_u8:
sl@0
    38
 * @d_1:
sl@0
    39
 * @s1_8x8:
sl@0
    40
 * @ss1:
sl@0
    41
 *
sl@0
    42
 * Calculates the sum of squared differences from the mean over
sl@0
    43
 * @s1_8x8 and places the result in @d_1.  This result is 64 times
sl@0
    44
 * the variance of the mean of @s1_8x8.
sl@0
    45
 */
sl@0
    46
OIL_DEFINE_CLASS (err_intra8x8_u8,
sl@0
    47
    "uint32_t *d_1, uint8_t *s1_8x8, int ss1");
sl@0
    48
/**
sl@0
    49
 * oil_err_inter8x8_u8:
sl@0
    50
 * @d_1:
sl@0
    51
 * @s1_8x8:
sl@0
    52
 * @ss1:
sl@0
    53
 * @s2_8x8:
sl@0
    54
 * @ss2:
sl@0
    55
 *
sl@0
    56
 * Calculates an intermediate 8x8 block where each element is the
sl@0
    57
 * difference between @s1_8x8 and @s2_8x8.
sl@0
    58
 * The sum of squares of the difference of each element in the 
sl@0
    59
 * intermediate block and the mean of the intermediate block is
sl@0
    60
 * placed into @d_1.  This result is
sl@0
    61
 * equal to 64 times the variance of the mean of the intermediate block.
sl@0
    62
 */
sl@0
    63
OIL_DEFINE_CLASS (err_inter8x8_u8,
sl@0
    64
    "uint32_t *d_1, uint8_t *s1_8x8, int ss1, uint8_t *s2_8x8, int ss2");
sl@0
    65
/**
sl@0
    66
 * oil_err_inter8x8_u8_avg:
sl@0
    67
 * @d_1:
sl@0
    68
 * @s1_8x8:
sl@0
    69
 * @ss1:
sl@0
    70
 * @s2_8x8:
sl@0
    71
 * @s3_8x8:
sl@0
    72
 * @ss2:
sl@0
    73
 *
sl@0
    74
 * Calculates an intermediate 8x8 block where each element is the
sl@0
    75
 * difference between @s1_8x8 and the average of @s2_8x8 and @s3_8x8.
sl@0
    76
 * The sum of squares of the difference of each element in the 
sl@0
    77
 * intermediate block and the mean of the intermediate block is
sl@0
    78
 * placed into @d_1.
sl@0
    79
 * This result is 64 times the variance of the mean of the intermediate
sl@0
    80
 * block.
sl@0
    81
 *
sl@0
    82
 * FIXME: This function is broken, since the reference function uses
sl@0
    83
 * @ss2 as the stride for both @s2_8x8 and @s3_8x8.
sl@0
    84
 */
sl@0
    85
OIL_DEFINE_CLASS (err_inter8x8_u8_avg,
sl@0
    86
    "uint32_t *d_1, uint8_t *s1_8x8, int ss1, uint8_t *s2_8x8, uint8_t *s3_8x8, int ss2");
sl@0
    87
sl@0
    88
#define DSP_OP_AVG(a,b) ((((int)(a)) + ((int)(b)))/2)
sl@0
    89
#define DSP_OP_DIFF(a,b) (((int)(a)) - ((int)(b)))
sl@0
    90
sl@0
    91
static void
sl@0
    92
err_intra8x8_u8_ref (uint32_t *dest, uint8_t *src1, int ss1)
sl@0
    93
{
sl@0
    94
  uint32_t  i;
sl@0
    95
  uint32_t  xsum=0;
sl@0
    96
  uint32_t  xxsum=0;
sl@0
    97
sl@0
    98
  for (i=8; i; i--) {
sl@0
    99
    /* Examine alternate pixel locations. */
sl@0
   100
    xsum += src1[0];
sl@0
   101
    xxsum += src1[0]*src1[0];
sl@0
   102
    xsum += src1[1];
sl@0
   103
    xxsum += src1[1]*src1[1];
sl@0
   104
    xsum += src1[2];
sl@0
   105
    xxsum += src1[2]*src1[2];
sl@0
   106
    xsum += src1[3];
sl@0
   107
    xxsum += src1[3]*src1[3];
sl@0
   108
    xsum += src1[4];
sl@0
   109
    xxsum += src1[4]*src1[4];
sl@0
   110
    xsum += src1[5];
sl@0
   111
    xxsum += src1[5]*src1[5];
sl@0
   112
    xsum += src1[6];
sl@0
   113
    xxsum += src1[6]*src1[6];
sl@0
   114
    xsum += src1[7];
sl@0
   115
    xxsum += src1[7]*src1[7];
sl@0
   116
sl@0
   117
    /* Step to next row of block. */
sl@0
   118
    src1 += ss1;
sl@0
   119
  }
sl@0
   120
  /* Compute population variance as mis-match metric. */
sl@0
   121
  *dest = (((xxsum<<6) - xsum*xsum ));
sl@0
   122
}
sl@0
   123
OIL_DEFINE_IMPL_REF (err_intra8x8_u8_ref, err_intra8x8_u8);
sl@0
   124
sl@0
   125
static void
sl@0
   126
err_inter8x8_u8_ref (uint32_t *dest, uint8_t *src1, int ss1, uint8_t *src2, int ss2)
sl@0
   127
{
sl@0
   128
  uint32_t  i;
sl@0
   129
  uint32_t  xsum=0;
sl@0
   130
  uint32_t  xxsum=0;
sl@0
   131
  int32_t   diff;
sl@0
   132
sl@0
   133
  for (i=8; i; i--) {
sl@0
   134
    diff = DSP_OP_DIFF (src1[0], src2[0]);
sl@0
   135
    xsum += diff;
sl@0
   136
    xxsum += diff*diff;
sl@0
   137
sl@0
   138
    diff = DSP_OP_DIFF (src1[1], src2[1]);
sl@0
   139
    xsum += diff;
sl@0
   140
    xxsum += diff*diff;
sl@0
   141
sl@0
   142
    diff = DSP_OP_DIFF (src1[2], src2[2]);
sl@0
   143
    xsum += diff;
sl@0
   144
    xxsum += diff*diff;
sl@0
   145
sl@0
   146
    diff = DSP_OP_DIFF (src1[3], src2[3]);
sl@0
   147
    xsum += diff;
sl@0
   148
    xxsum += diff*diff;
sl@0
   149
        
sl@0
   150
    diff = DSP_OP_DIFF (src1[4], src2[4]);
sl@0
   151
    xsum += diff;
sl@0
   152
    xxsum += diff*diff;
sl@0
   153
        
sl@0
   154
    diff = DSP_OP_DIFF (src1[5], src2[5]);
sl@0
   155
    xsum += diff;
sl@0
   156
    xxsum += diff*diff;
sl@0
   157
        
sl@0
   158
    diff = DSP_OP_DIFF (src1[6], src2[6]);
sl@0
   159
    xsum += diff;
sl@0
   160
    xxsum += diff*diff;
sl@0
   161
        
sl@0
   162
    diff = DSP_OP_DIFF (src1[7], src2[7]);
sl@0
   163
    xsum += diff;
sl@0
   164
    xxsum += diff*diff;
sl@0
   165
        
sl@0
   166
    /* Step to next row of block. */
sl@0
   167
    src1 += ss1;
sl@0
   168
    src2 += ss2;
sl@0
   169
  }
sl@0
   170
sl@0
   171
  /* Compute and return population variance as mis-match metric. */
sl@0
   172
  *dest = (((xxsum<<6) - xsum*xsum));
sl@0
   173
}
sl@0
   174
OIL_DEFINE_IMPL_REF (err_inter8x8_u8_ref, err_inter8x8_u8);
sl@0
   175
sl@0
   176
static void
sl@0
   177
err_inter8x8_u8_avg_ref (uint32_t *dest, uint8_t *src1, int ss1, uint8_t *src2, uint8_t *src3, int ss2)
sl@0
   178
{
sl@0
   179
  uint32_t  i;
sl@0
   180
  uint32_t  xsum=0;
sl@0
   181
  uint32_t  xxsum=0;
sl@0
   182
  int32_t   diff;
sl@0
   183
sl@0
   184
  for (i=8; i; i--) {
sl@0
   185
    diff = DSP_OP_DIFF(src1[0], DSP_OP_AVG (src2[0], src3[0]));
sl@0
   186
    xsum += diff;
sl@0
   187
    xxsum += diff*diff;
sl@0
   188
sl@0
   189
    diff = DSP_OP_DIFF(src1[1], DSP_OP_AVG (src2[1], src3[1]));
sl@0
   190
    xsum += diff;
sl@0
   191
    xxsum += diff*diff;
sl@0
   192
sl@0
   193
    diff = DSP_OP_DIFF(src1[2], DSP_OP_AVG (src2[2], src3[2]));
sl@0
   194
    xsum += diff;
sl@0
   195
    xxsum += diff*diff;
sl@0
   196
sl@0
   197
    diff = DSP_OP_DIFF(src1[3], DSP_OP_AVG (src2[3], src3[3]));
sl@0
   198
    xsum += diff;
sl@0
   199
    xxsum += diff*diff;
sl@0
   200
sl@0
   201
    diff = DSP_OP_DIFF(src1[4], DSP_OP_AVG (src2[4], src3[4]));
sl@0
   202
    xsum += diff;
sl@0
   203
    xxsum += diff*diff;
sl@0
   204
sl@0
   205
    diff = DSP_OP_DIFF(src1[5], DSP_OP_AVG (src2[5], src3[5]));
sl@0
   206
    xsum += diff;
sl@0
   207
    xxsum += diff*diff;
sl@0
   208
sl@0
   209
    diff = DSP_OP_DIFF(src1[6], DSP_OP_AVG (src2[6], src3[6]));
sl@0
   210
    xsum += diff;
sl@0
   211
    xxsum += diff*diff;
sl@0
   212
sl@0
   213
    diff = DSP_OP_DIFF(src1[7], DSP_OP_AVG (src2[7], src3[7]));
sl@0
   214
    xsum += diff;
sl@0
   215
    xxsum += diff*diff;
sl@0
   216
sl@0
   217
    /* Step to next row of block. */
sl@0
   218
    src1 += ss1;
sl@0
   219
    src2 += ss2;
sl@0
   220
    src3 += ss2;
sl@0
   221
  }
sl@0
   222
sl@0
   223
  /* Compute and return population variance as mis-match metric. */
sl@0
   224
  *dest = (((xxsum<<6) - xsum*xsum));
sl@0
   225
}
sl@0
   226
sl@0
   227
OIL_DEFINE_IMPL_REF (err_inter8x8_u8_avg_ref, err_inter8x8_u8_avg);
sl@0
   228
sl@0
   229
sl@0
   230
#ifdef	__SYMBIAN32__
sl@0
   231
 
sl@0
   232
OilFunctionClass* __oil_function_class_err_intra8x8_u8() {
sl@0
   233
		return &_oil_function_class_err_intra8x8_u8;
sl@0
   234
}
sl@0
   235
#endif
sl@0
   236
sl@0
   237
#ifdef	__SYMBIAN32__
sl@0
   238
 
sl@0
   239
OilFunctionClass* __oil_function_class_err_inter8x8_u8() {
sl@0
   240
		return &_oil_function_class_err_inter8x8_u8;
sl@0
   241
}
sl@0
   242
#endif
sl@0
   243
sl@0
   244
#ifdef	__SYMBIAN32__
sl@0
   245
 
sl@0
   246
OilFunctionClass* __oil_function_class_err_inter8x8_u8_avg() {
sl@0
   247
		return &_oil_function_class_err_inter8x8_u8_avg;
sl@0
   248
}
sl@0
   249
#endif
sl@0
   250
sl@0
   251
sl@0
   252
sl@0
   253
#ifdef	__SYMBIAN32__
sl@0
   254
 
sl@0
   255
OilFunctionImpl* __oil_function_impl_err_intra8x8_u8_ref() {
sl@0
   256
		return &_oil_function_impl_err_intra8x8_u8_ref;
sl@0
   257
}
sl@0
   258
#endif
sl@0
   259
sl@0
   260
#ifdef	__SYMBIAN32__
sl@0
   261
 
sl@0
   262
OilFunctionImpl* __oil_function_impl_err_inter8x8_u8_ref() {
sl@0
   263
		return &_oil_function_impl_err_inter8x8_u8_ref;
sl@0
   264
}
sl@0
   265
#endif
sl@0
   266
sl@0
   267
#ifdef	__SYMBIAN32__
sl@0
   268
 
sl@0
   269
OilFunctionImpl* __oil_function_impl_err_inter8x8_u8_avg_ref() {
sl@0
   270
		return &_oil_function_impl_err_inter8x8_u8_avg_ref;
sl@0
   271
}
sl@0
   272
#endif
sl@0
   273
sl@0
   274
sl@0
   275
sl@0
   276
#ifdef	__SYMBIAN32__
sl@0
   277
 
sl@0
   278
EXPORT_C void** _oil_function_class_ptr_err_intra8x8_u8 ()	{
sl@0
   279
	oil_function_class_ptr_err_intra8x8_u8 = __oil_function_class_err_intra8x8_u8();
sl@0
   280
	return &oil_function_class_ptr_err_intra8x8_u8->func;
sl@0
   281
	}
sl@0
   282
#endif
sl@0
   283
sl@0
   284
#ifdef	__SYMBIAN32__
sl@0
   285
 
sl@0
   286
EXPORT_C void** _oil_function_class_ptr_err_inter8x8_u8 ()	{
sl@0
   287
	oil_function_class_ptr_err_inter8x8_u8 = __oil_function_class_err_inter8x8_u8();
sl@0
   288
	return &oil_function_class_ptr_err_inter8x8_u8->func;
sl@0
   289
	}
sl@0
   290
#endif
sl@0
   291
sl@0
   292
#ifdef	__SYMBIAN32__
sl@0
   293
 
sl@0
   294
EXPORT_C void** _oil_function_class_ptr_err_inter8x8_u8_avg ()	{
sl@0
   295
	oil_function_class_ptr_err_inter8x8_u8_avg = __oil_function_class_err_inter8x8_u8_avg();
sl@0
   296
	return &oil_function_class_ptr_err_inter8x8_u8_avg->func;
sl@0
   297
	}
sl@0
   298
#endif
sl@0
   299