2010-05-18 11:58:33 -04:00
|
|
|
/*
|
2010-09-09 08:16:39 -04:00
|
|
|
* Copyright (c) 2010 The WebM project authors. All Rights Reserved.
|
2010-05-18 11:58:33 -04:00
|
|
|
*
|
2010-06-18 12:39:21 -04:00
|
|
|
* Use of this source code is governed by a BSD-style license
|
2010-06-04 16:19:40 -04:00
|
|
|
* that can be found in the LICENSE file in the root of the source
|
|
|
|
* tree. An additional intellectual property rights grant can be found
|
2010-06-18 12:39:21 -04:00
|
|
|
* in the file PATENTS. All contributing project authors may
|
2010-06-04 16:19:40 -04:00
|
|
|
* be found in the AUTHORS file in the root of the source tree.
|
2010-05-18 11:58:33 -04:00
|
|
|
*/
|
|
|
|
|
|
|
|
|
2012-12-03 14:19:49 -08:00
|
|
|
#include "vpx_scale/vpx_scale.h"
|
2010-05-18 11:58:33 -04:00
|
|
|
#include "vpx_mem/vpx_mem.h"
|
|
|
|
/****************************************************************************
|
|
|
|
* Imports
|
|
|
|
****************************************************************************/
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
*
|
|
|
|
*
|
|
|
|
* INPUTS : const unsigned char *source : Pointer to source data.
|
|
|
|
* unsigned int source_width : Stride of source.
|
|
|
|
* unsigned char *dest : Pointer to destination data.
|
|
|
|
* unsigned int dest_width : Stride of destination (NOT USED).
|
|
|
|
*
|
|
|
|
* OUTPUTS : None.
|
|
|
|
*
|
|
|
|
* RETURNS : void
|
|
|
|
*
|
|
|
|
* FUNCTION : Copies horizontal line of pixels from source to
|
|
|
|
* destination scaling up by 4 to 5.
|
|
|
|
*
|
|
|
|
* SPECIAL NOTES : None.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
2012-11-01 17:53:44 -07:00
|
|
|
void vp8_horizontal_line_5_4_scale_c(const unsigned char *source,
|
|
|
|
unsigned int source_width,
|
|
|
|
unsigned char *dest,
|
|
|
|
unsigned int dest_width) {
|
2012-07-13 15:21:29 -07:00
|
|
|
unsigned i;
|
|
|
|
unsigned int a, b, c, d, e;
|
|
|
|
unsigned char *des = dest;
|
|
|
|
const unsigned char *src = source;
|
|
|
|
|
|
|
|
(void) dest_width;
|
|
|
|
|
|
|
|
for (i = 0; i < source_width; i += 5) {
|
|
|
|
a = src[0];
|
|
|
|
b = src[1];
|
|
|
|
c = src[2];
|
|
|
|
d = src[3];
|
|
|
|
e = src[4];
|
|
|
|
|
|
|
|
des[0] = (unsigned char) a;
|
|
|
|
des[1] = (unsigned char)((b * 192 + c * 64 + 128) >> 8);
|
|
|
|
des[2] = (unsigned char)((c * 128 + d * 128 + 128) >> 8);
|
|
|
|
des[3] = (unsigned char)((d * 64 + e * 192 + 128) >> 8);
|
|
|
|
|
|
|
|
src += 5;
|
|
|
|
des += 4;
|
|
|
|
}
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
|
2012-11-01 17:53:44 -07:00
|
|
|
void vp8_vertical_band_5_4_scale_c(unsigned char *source,
|
|
|
|
unsigned int src_pitch,
|
|
|
|
unsigned char *dest,
|
|
|
|
unsigned int dest_pitch,
|
|
|
|
unsigned int dest_width) {
|
2012-07-13 15:21:29 -07:00
|
|
|
unsigned int i;
|
|
|
|
unsigned int a, b, c, d, e;
|
|
|
|
unsigned char *des = dest;
|
|
|
|
unsigned char *src = source;
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
for (i = 0; i < dest_width; i++) {
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
a = src[0 * src_pitch];
|
|
|
|
b = src[1 * src_pitch];
|
|
|
|
c = src[2 * src_pitch];
|
|
|
|
d = src[3 * src_pitch];
|
|
|
|
e = src[4 * src_pitch];
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
des[0 * dest_pitch] = (unsigned char) a;
|
|
|
|
des[1 * dest_pitch] = (unsigned char)((b * 192 + c * 64 + 128) >> 8);
|
|
|
|
des[2 * dest_pitch] = (unsigned char)((c * 128 + d * 128 + 128) >> 8);
|
|
|
|
des[3 * dest_pitch] = (unsigned char)((d * 64 + e * 192 + 128) >> 8);
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
src++;
|
|
|
|
des++;
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
}
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
|
|
|
|
/*7***************************************************************************
|
|
|
|
*
|
2012-11-01 17:53:44 -07:00
|
|
|
* ROUTINE : vp8_horizontal_line_3_5_scale_c
|
2010-05-18 11:58:33 -04:00
|
|
|
*
|
|
|
|
* INPUTS : const unsigned char *source : Pointer to source data.
|
|
|
|
* unsigned int source_width : Stride of source.
|
|
|
|
* unsigned char *dest : Pointer to destination data.
|
|
|
|
* unsigned int dest_width : Stride of destination (NOT USED).
|
|
|
|
*
|
|
|
|
* OUTPUTS : None.
|
|
|
|
*
|
|
|
|
* RETURNS : void
|
|
|
|
*
|
|
|
|
* FUNCTION : Copies horizontal line of pixels from source to
|
|
|
|
* destination scaling up by 3 to 5.
|
|
|
|
*
|
|
|
|
* SPECIAL NOTES : None.
|
|
|
|
*
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
2012-11-01 17:53:44 -07:00
|
|
|
void vp8_horizontal_line_5_3_scale_c(const unsigned char *source,
|
|
|
|
unsigned int source_width,
|
|
|
|
unsigned char *dest,
|
|
|
|
unsigned int dest_width) {
|
2012-07-13 15:21:29 -07:00
|
|
|
unsigned int i;
|
|
|
|
unsigned int a, b, c, d, e;
|
|
|
|
unsigned char *des = dest;
|
|
|
|
const unsigned char *src = source;
|
|
|
|
|
|
|
|
(void) dest_width;
|
|
|
|
|
|
|
|
for (i = 0; i < source_width; i += 5) {
|
|
|
|
a = src[0];
|
|
|
|
b = src[1];
|
|
|
|
c = src[2];
|
|
|
|
d = src[3];
|
|
|
|
e = src[4];
|
|
|
|
|
|
|
|
des[0] = (unsigned char) a;
|
|
|
|
des[1] = (unsigned char)((b * 85 + c * 171 + 128) >> 8);
|
|
|
|
des[2] = (unsigned char)((d * 171 + e * 85 + 128) >> 8);
|
|
|
|
|
|
|
|
src += 5;
|
|
|
|
des += 3;
|
|
|
|
}
|
2010-05-18 11:58:33 -04:00
|
|
|
|
|
|
|
}
|
|
|
|
|
2012-11-01 17:53:44 -07:00
|
|
|
void vp8_vertical_band_5_3_scale_c(unsigned char *source,
|
|
|
|
unsigned int src_pitch,
|
|
|
|
unsigned char *dest,
|
|
|
|
unsigned int dest_pitch,
|
|
|
|
unsigned int dest_width) {
|
2012-07-13 15:21:29 -07:00
|
|
|
unsigned int i;
|
|
|
|
unsigned int a, b, c, d, e;
|
|
|
|
unsigned char *des = dest;
|
|
|
|
unsigned char *src = source;
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
for (i = 0; i < dest_width; i++) {
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
a = src[0 * src_pitch];
|
|
|
|
b = src[1 * src_pitch];
|
|
|
|
c = src[2 * src_pitch];
|
|
|
|
d = src[3 * src_pitch];
|
|
|
|
e = src[4 * src_pitch];
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
des[0 * dest_pitch] = (unsigned char) a;
|
|
|
|
des[1 * dest_pitch] = (unsigned char)((b * 85 + c * 171 + 128) >> 8);
|
|
|
|
des[2 * dest_pitch] = (unsigned char)((d * 171 + e * 85 + 128) >> 8);
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
src++;
|
|
|
|
des++;
|
2010-05-18 11:58:33 -04:00
|
|
|
|
2012-07-13 15:21:29 -07:00
|
|
|
}
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|
|
|
|
|
|
|
|
/****************************************************************************
|
|
|
|
*
|
2012-11-01 17:53:44 -07:00
|
|
|
* ROUTINE : vp8_horizontal_line_1_2_scale_c
|
2010-05-18 11:58:33 -04:00
|
|
|
*
|
|
|
|
* INPUTS : const unsigned char *source : Pointer to source data.
|
|
|
|
* unsigned int source_width : Stride of source.
|
|
|
|
* unsigned char *dest : Pointer to destination data.
|
|
|
|
* unsigned int dest_width : Stride of destination (NOT USED).
|
|
|
|
*
|
|
|
|
* OUTPUTS : None.
|
|
|
|
*
|
|
|
|
* RETURNS : void
|
|
|
|
*
|
|
|
|
* FUNCTION : Copies horizontal line of pixels from source to
|
|
|
|
* destination scaling up by 1 to 2.
|
|
|
|
*
|
|
|
|
* SPECIAL NOTES : None.
|
|
|
|
*
|
|
|
|
****************************************************************************/
|
2012-11-01 17:53:44 -07:00
|
|
|
void vp8_horizontal_line_2_1_scale_c(const unsigned char *source,
|
|
|
|
unsigned int source_width,
|
|
|
|
unsigned char *dest,
|
|
|
|
unsigned int dest_width) {
|
2012-07-13 15:21:29 -07:00
|
|
|
unsigned int i;
|
|
|
|
unsigned int a;
|
|
|
|
unsigned char *des = dest;
|
|
|
|
const unsigned char *src = source;
|
|
|
|
|
|
|
|
(void) dest_width;
|
|
|
|
|
|
|
|
for (i = 0; i < source_width; i += 2) {
|
|
|
|
a = src[0];
|
|
|
|
des [0] = (unsigned char)(a);
|
|
|
|
src += 2;
|
|
|
|
des += 1;
|
|
|
|
}
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|
2012-11-01 17:53:44 -07:00
|
|
|
|
|
|
|
void vp8_vertical_band_2_1_scale_c(unsigned char *source,
|
|
|
|
unsigned int src_pitch,
|
|
|
|
unsigned char *dest,
|
|
|
|
unsigned int dest_pitch,
|
|
|
|
unsigned int dest_width) {
|
2012-07-13 15:21:29 -07:00
|
|
|
(void) dest_pitch;
|
|
|
|
(void) src_pitch;
|
|
|
|
vpx_memcpy(dest, source, dest_width);
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|
|
|
|
|
2012-11-01 17:53:44 -07:00
|
|
|
void vp8_vertical_band_2_1_scale_i_c(unsigned char *source,
|
|
|
|
unsigned int src_pitch,
|
|
|
|
unsigned char *dest,
|
|
|
|
unsigned int dest_pitch,
|
|
|
|
unsigned int dest_width) {
|
2012-07-13 15:21:29 -07:00
|
|
|
int i;
|
|
|
|
int temp;
|
|
|
|
int width = dest_width;
|
|
|
|
|
|
|
|
(void) dest_pitch;
|
|
|
|
|
|
|
|
for (i = 0; i < width; i++) {
|
|
|
|
temp = 8;
|
|
|
|
temp += source[i - (int)src_pitch] * 3;
|
|
|
|
temp += source[i] * 10;
|
|
|
|
temp += source[i + src_pitch] * 3;
|
|
|
|
temp >>= 4;
|
|
|
|
dest[i] = (unsigned char)(temp);
|
|
|
|
}
|
2010-05-18 11:58:33 -04:00
|
|
|
}
|