Home | History | Annotate | Download | only in common
      1 /*
      2  *  Copyright (c) 2010 The WebM project authors. All Rights Reserved.
      3  *
      4  *  Use of this source code is governed by a BSD-style license
      5  *  that can be found in the LICENSE file in the root of the source
      6  *  tree. An additional intellectual property rights grant can be found
      7  *  in the file PATENTS.  All contributing project authors may
      8  *  be found in the AUTHORS file in the root of the source tree.
      9  */
     10 
     11 
     12 #include "vpx_config.h"
     13 #include "vp8_rtcd.h"
     14 #include "blockd.h"
     15 
     16 void vp8_intra4x4_predict_c(unsigned char *Above,
     17                             unsigned char *yleft, int left_stride,
     18                             int           _b_mode,
     19                             unsigned char *dst, int dst_stride,
     20                             unsigned char top_left)
     21 {
     22     int i, r, c;
     23     B_PREDICTION_MODE b_mode = (B_PREDICTION_MODE)_b_mode;
     24     unsigned char Left[4];
     25     Left[0] = yleft[0];
     26     Left[1] = yleft[left_stride];
     27     Left[2] = yleft[2 * left_stride];
     28     Left[3] = yleft[3 * left_stride];
     29 
     30     switch (b_mode)
     31     {
     32     case B_DC_PRED:
     33     {
     34         int expected_dc = 0;
     35 
     36         for (i = 0; i < 4; i++)
     37         {
     38             expected_dc += Above[i];
     39             expected_dc += Left[i];
     40         }
     41 
     42         expected_dc = (expected_dc + 4) >> 3;
     43 
     44         for (r = 0; r < 4; r++)
     45         {
     46             for (c = 0; c < 4; c++)
     47             {
     48                 dst[c] = expected_dc;
     49             }
     50 
     51             dst += dst_stride;
     52         }
     53     }
     54     break;
     55     case B_TM_PRED:
     56     {
     57         /* prediction similar to true_motion prediction */
     58         for (r = 0; r < 4; r++)
     59         {
     60             for (c = 0; c < 4; c++)
     61             {
     62                 int pred = Above[c] - top_left + Left[r];
     63 
     64                 if (pred < 0)
     65                     pred = 0;
     66 
     67                 if (pred > 255)
     68                     pred = 255;
     69 
     70                 dst[c] = pred;
     71             }
     72 
     73             dst += dst_stride;
     74         }
     75     }
     76     break;
     77 
     78     case B_VE_PRED:
     79     {
     80 
     81         unsigned int ap[4];
     82         ap[0] = (top_left  + 2 * Above[0] + Above[1] + 2) >> 2;
     83         ap[1] = (Above[0] + 2 * Above[1] + Above[2] + 2) >> 2;
     84         ap[2] = (Above[1] + 2 * Above[2] + Above[3] + 2) >> 2;
     85         ap[3] = (Above[2] + 2 * Above[3] + Above[4] + 2) >> 2;
     86 
     87         for (r = 0; r < 4; r++)
     88         {
     89             for (c = 0; c < 4; c++)
     90             {
     91 
     92                 dst[c] = ap[c];
     93             }
     94 
     95             dst += dst_stride;
     96         }
     97 
     98     }
     99     break;
    100 
    101 
    102     case B_HE_PRED:
    103     {
    104 
    105         unsigned int lp[4];
    106         lp[0] = (top_left + 2 * Left[0] + Left[1] + 2) >> 2;
    107         lp[1] = (Left[0] + 2 * Left[1] + Left[2] + 2) >> 2;
    108         lp[2] = (Left[1] + 2 * Left[2] + Left[3] + 2) >> 2;
    109         lp[3] = (Left[2] + 2 * Left[3] + Left[3] + 2) >> 2;
    110 
    111         for (r = 0; r < 4; r++)
    112         {
    113             for (c = 0; c < 4; c++)
    114             {
    115                 dst[c] = lp[r];
    116             }
    117 
    118             dst += dst_stride;
    119         }
    120     }
    121     break;
    122     case B_LD_PRED:
    123     {
    124         unsigned char *ptr = Above;
    125         dst[0 * dst_stride + 0] = (ptr[0] + ptr[1] * 2 + ptr[2] + 2) >> 2;
    126         dst[0 * dst_stride + 1] =
    127             dst[1 * dst_stride + 0] = (ptr[1] + ptr[2] * 2 + ptr[3] + 2) >> 2;
    128         dst[0 * dst_stride + 2] =
    129             dst[1 * dst_stride + 1] =
    130                 dst[2 * dst_stride + 0] = (ptr[2] + ptr[3] * 2 + ptr[4] + 2) >> 2;
    131         dst[0 * dst_stride + 3] =
    132             dst[1 * dst_stride + 2] =
    133                 dst[2 * dst_stride + 1] =
    134                     dst[3 * dst_stride + 0] = (ptr[3] + ptr[4] * 2 + ptr[5] + 2) >> 2;
    135         dst[1 * dst_stride + 3] =
    136             dst[2 * dst_stride + 2] =
    137                 dst[3 * dst_stride + 1] = (ptr[4] + ptr[5] * 2 + ptr[6] + 2) >> 2;
    138         dst[2 * dst_stride + 3] =
    139             dst[3 * dst_stride + 2] = (ptr[5] + ptr[6] * 2 + ptr[7] + 2) >> 2;
    140         dst[3 * dst_stride + 3] = (ptr[6] + ptr[7] * 2 + ptr[7] + 2) >> 2;
    141 
    142     }
    143     break;
    144     case B_RD_PRED:
    145     {
    146 
    147         unsigned char pp[9];
    148 
    149         pp[0] = Left[3];
    150         pp[1] = Left[2];
    151         pp[2] = Left[1];
    152         pp[3] = Left[0];
    153         pp[4] = top_left;
    154         pp[5] = Above[0];
    155         pp[6] = Above[1];
    156         pp[7] = Above[2];
    157         pp[8] = Above[3];
    158 
    159         dst[3 * dst_stride + 0] = (pp[0] + pp[1] * 2 + pp[2] + 2) >> 2;
    160         dst[3 * dst_stride + 1] =
    161             dst[2 * dst_stride + 0] = (pp[1] + pp[2] * 2 + pp[3] + 2) >> 2;
    162         dst[3 * dst_stride + 2] =
    163             dst[2 * dst_stride + 1] =
    164                 dst[1 * dst_stride + 0] = (pp[2] + pp[3] * 2 + pp[4] + 2) >> 2;
    165         dst[3 * dst_stride + 3] =
    166             dst[2 * dst_stride + 2] =
    167                 dst[1 * dst_stride + 1] =
    168                     dst[0 * dst_stride + 0] = (pp[3] + pp[4] * 2 + pp[5] + 2) >> 2;
    169         dst[2 * dst_stride + 3] =
    170             dst[1 * dst_stride + 2] =
    171                 dst[0 * dst_stride + 1] = (pp[4] + pp[5] * 2 + pp[6] + 2) >> 2;
    172         dst[1 * dst_stride + 3] =
    173             dst[0 * dst_stride + 2] = (pp[5] + pp[6] * 2 + pp[7] + 2) >> 2;
    174         dst[0 * dst_stride + 3] = (pp[6] + pp[7] * 2 + pp[8] + 2) >> 2;
    175 
    176     }
    177     break;
    178     case B_VR_PRED:
    179     {
    180 
    181         unsigned char pp[9];
    182 
    183         pp[0] = Left[3];
    184         pp[1] = Left[2];
    185         pp[2] = Left[1];
    186         pp[3] = Left[0];
    187         pp[4] = top_left;
    188         pp[5] = Above[0];
    189         pp[6] = Above[1];
    190         pp[7] = Above[2];
    191         pp[8] = Above[3];
    192 
    193 
    194         dst[3 * dst_stride + 0] = (pp[1] + pp[2] * 2 + pp[3] + 2) >> 2;
    195         dst[2 * dst_stride + 0] = (pp[2] + pp[3] * 2 + pp[4] + 2) >> 2;
    196         dst[3 * dst_stride + 1] =
    197             dst[1 * dst_stride + 0] = (pp[3] + pp[4] * 2 + pp[5] + 2) >> 2;
    198         dst[2 * dst_stride + 1] =
    199             dst[0 * dst_stride + 0] = (pp[4] + pp[5] + 1) >> 1;
    200         dst[3 * dst_stride + 2] =
    201             dst[1 * dst_stride + 1] = (pp[4] + pp[5] * 2 + pp[6] + 2) >> 2;
    202         dst[2 * dst_stride + 2] =
    203             dst[0 * dst_stride + 1] = (pp[5] + pp[6] + 1) >> 1;
    204         dst[3 * dst_stride + 3] =
    205             dst[1 * dst_stride + 2] = (pp[5] + pp[6] * 2 + pp[7] + 2) >> 2;
    206         dst[2 * dst_stride + 3] =
    207             dst[0 * dst_stride + 2] = (pp[6] + pp[7] + 1) >> 1;
    208         dst[1 * dst_stride + 3] = (pp[6] + pp[7] * 2 + pp[8] + 2) >> 2;
    209         dst[0 * dst_stride + 3] = (pp[7] + pp[8] + 1) >> 1;
    210 
    211     }
    212     break;
    213     case B_VL_PRED:
    214     {
    215 
    216         unsigned char *pp = Above;
    217 
    218         dst[0 * dst_stride + 0] = (pp[0] + pp[1] + 1) >> 1;
    219         dst[1 * dst_stride + 0] = (pp[0] + pp[1] * 2 + pp[2] + 2) >> 2;
    220         dst[2 * dst_stride + 0] =
    221             dst[0 * dst_stride + 1] = (pp[1] + pp[2] + 1) >> 1;
    222         dst[1 * dst_stride + 1] =
    223             dst[3 * dst_stride + 0] = (pp[1] + pp[2] * 2 + pp[3] + 2) >> 2;
    224         dst[2 * dst_stride + 1] =
    225             dst[0 * dst_stride + 2] = (pp[2] + pp[3] + 1) >> 1;
    226         dst[3 * dst_stride + 1] =
    227             dst[1 * dst_stride + 2] = (pp[2] + pp[3] * 2 + pp[4] + 2) >> 2;
    228         dst[0 * dst_stride + 3] =
    229             dst[2 * dst_stride + 2] = (pp[3] + pp[4] + 1) >> 1;
    230         dst[1 * dst_stride + 3] =
    231             dst[3 * dst_stride + 2] = (pp[3] + pp[4] * 2 + pp[5] + 2) >> 2;
    232         dst[2 * dst_stride + 3] = (pp[4] + pp[5] * 2 + pp[6] + 2) >> 2;
    233         dst[3 * dst_stride + 3] = (pp[5] + pp[6] * 2 + pp[7] + 2) >> 2;
    234     }
    235     break;
    236 
    237     case B_HD_PRED:
    238     {
    239         unsigned char pp[9];
    240         pp[0] = Left[3];
    241         pp[1] = Left[2];
    242         pp[2] = Left[1];
    243         pp[3] = Left[0];
    244         pp[4] = top_left;
    245         pp[5] = Above[0];
    246         pp[6] = Above[1];
    247         pp[7] = Above[2];
    248         pp[8] = Above[3];
    249 
    250 
    251         dst[3 * dst_stride + 0] = (pp[0] + pp[1] + 1) >> 1;
    252         dst[3 * dst_stride + 1] = (pp[0] + pp[1] * 2 + pp[2] + 2) >> 2;
    253         dst[2 * dst_stride + 0] =
    254             dst[3 * dst_stride + 2] = (pp[1] + pp[2] + 1) >> 1;
    255         dst[2 * dst_stride + 1] =
    256             dst[3 * dst_stride + 3] = (pp[1] + pp[2] * 2 + pp[3] + 2) >> 2;
    257         dst[2 * dst_stride + 2] =
    258             dst[1 * dst_stride + 0] = (pp[2] + pp[3] + 1) >> 1;
    259         dst[2 * dst_stride + 3] =
    260             dst[1 * dst_stride + 1] = (pp[2] + pp[3] * 2 + pp[4] + 2) >> 2;
    261         dst[1 * dst_stride + 2] =
    262             dst[0 * dst_stride + 0] = (pp[3] + pp[4] + 1) >> 1;
    263         dst[1 * dst_stride + 3] =
    264             dst[0 * dst_stride + 1] = (pp[3] + pp[4] * 2 + pp[5] + 2) >> 2;
    265         dst[0 * dst_stride + 2] = (pp[4] + pp[5] * 2 + pp[6] + 2) >> 2;
    266         dst[0 * dst_stride + 3] = (pp[5] + pp[6] * 2 + pp[7] + 2) >> 2;
    267     }
    268     break;
    269 
    270 
    271     case B_HU_PRED:
    272     {
    273         unsigned char *pp = Left;
    274         dst[0 * dst_stride + 0] = (pp[0] + pp[1] + 1) >> 1;
    275         dst[0 * dst_stride + 1] = (pp[0] + pp[1] * 2 + pp[2] + 2) >> 2;
    276         dst[0 * dst_stride + 2] =
    277             dst[1 * dst_stride + 0] = (pp[1] + pp[2] + 1) >> 1;
    278         dst[0 * dst_stride + 3] =
    279             dst[1 * dst_stride + 1] = (pp[1] + pp[2] * 2 + pp[3] + 2) >> 2;
    280         dst[1 * dst_stride + 2] =
    281             dst[2 * dst_stride + 0] = (pp[2] + pp[3] + 1) >> 1;
    282         dst[1 * dst_stride + 3] =
    283             dst[2 * dst_stride + 1] = (pp[2] + pp[3] * 2 + pp[3] + 2) >> 2;
    284         dst[2 * dst_stride + 2] =
    285             dst[2 * dst_stride + 3] =
    286                 dst[3 * dst_stride + 0] =
    287                     dst[3 * dst_stride + 1] =
    288                         dst[3 * dst_stride + 2] =
    289                             dst[3 * dst_stride + 3] = pp[3];
    290     }
    291     break;
    292 
    293     default:
    294     break;
    295 
    296     }
    297 }
    298