rv34dsp.h
Go to the documentation of this file.
1 /*
2  * RV30/40 decoder motion compensation functions
3  * Copyright (c) 2008 Konstantin Shishkov
4  *
5  * This file is part of Libav.
6  *
7  * Libav is free software; you can redistribute it and/or
8  * modify it under the terms of the GNU Lesser General Public
9  * License as published by the Free Software Foundation; either
10  * version 2.1 of the License, or (at your option) any later version.
11  *
12  * Libav is distributed in the hope that it will be useful,
13  * but WITHOUT ANY WARRANTY; without even the implied warranty of
14  * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
15  * Lesser General Public License for more details.
16  *
17  * You should have received a copy of the GNU Lesser General Public
18  * License along with Libav; if not, write to the Free Software
19  * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20  */
21 
22 /**
23  * @file
24  * RV30/40 decoder motion compensation functions
25  */
26 
27 #ifndef AVCODEC_RV34DSP_H
28 #define AVCODEC_RV34DSP_H
29 
30 #include "dsputil.h"
31 #include "h264chroma.h"
32 
33 typedef void (*rv40_weight_func)(uint8_t *dst/*align width (8 or 16)*/,
34  uint8_t *src1/*align width (8 or 16)*/,
35  uint8_t *src2/*align width (8 or 16)*/,
36  int w1, int w2, ptrdiff_t stride);
37 
38 typedef void (*rv34_inv_transform_func)(int16_t *block);
39 
40 typedef void (*rv34_idct_add_func)(uint8_t *dst, ptrdiff_t stride, int16_t *block);
41 typedef void (*rv34_idct_dc_add_func)(uint8_t *dst, ptrdiff_t stride,
42  int dc);
43 
45  int filter_p1, int filter_q1,
46  int alpha, int beta,
47  int lims, int lim_q1, int lim_p1);
48 
50  int alpha, int lims,
51  int dmode, int chroma);
52 
53 typedef int (*rv40_loop_filter_strength_func)(uint8_t *src, ptrdiff_t stride,
54  int beta, int beta2, int edge,
55  int *p1, int *q1);
56 
57 typedef struct RV34DSPContext {
62  /**
63  * Biweight functions, first dimension is transform size (16/8),
64  * second is whether the weight is prescaled by 1/512 to skip
65  * the intermediate shifting.
66  */
76 
80 
83 
86 
87 #endif /* AVCODEC_RV34DSP_H */
qpel_mc_func put_pixels_tab[4][16]
Definition: rv34dsp.h:58
void ff_rv40dsp_init(RV34DSPContext *c)
Definition: rv40dsp.c:533
void(* rv34_inv_transform_func)(int16_t *block)
Definition: rv34dsp.h:38
rv40_loop_filter_strength_func rv40_loop_filter_strength[2]
Definition: rv34dsp.h:74
void(* rv40_weight_func)(uint8_t *dst, uint8_t *src1, uint8_t *src2, int w1, int w2, ptrdiff_t stride)
Definition: rv34dsp.h:33
int stride
Definition: mace.c:144
void ff_rv40dsp_init_arm(RV34DSPContext *c)
uint8_t
rv40_weak_loop_filter_func rv40_weak_loop_filter[2]
Definition: rv34dsp.h:72
void(* rv34_idct_dc_add_func)(uint8_t *dst, ptrdiff_t stride, int dc)
Definition: rv34dsp.h:41
rv40_weight_func rv40_weight_pixels_tab[2][2]
Biweight functions, first dimension is transform size (16/8), second is whether the weight is prescal...
Definition: rv34dsp.h:67
int(* rv40_loop_filter_strength_func)(uint8_t *src, ptrdiff_t stride, int beta, int beta2, int edge, int *p1, int *q1)
Definition: rv34dsp.h:53
rv34_idct_add_func rv34_idct_add
Definition: rv34dsp.h:70
void(* qpel_mc_func)(uint8_t *dst, uint8_t *src, ptrdiff_t stride)
Definition: dsputil.h:84
static double alpha(void *priv, double x, double y)
Definition: vf_geq.c:86
qpel_mc_func avg_pixels_tab[4][16]
Definition: rv34dsp.h:59
void ff_rv34dsp_init_arm(RV34DSPContext *c)
rv34_idct_dc_add_func rv34_idct_dc_add
Definition: rv34dsp.h:71
struct RV34DSPContext RV34DSPContext
rv34_inv_transform_func rv34_inv_transform_dc
Definition: rv34dsp.h:69
void(* h264_chroma_mc_func)(uint8_t *dst, uint8_t *src, int srcStride, int h, int x, int y)
Definition: h264chroma.h:24
void(* rv34_idct_add_func)(uint8_t *dst, ptrdiff_t stride, int16_t *block)
Definition: rv34dsp.h:40
AVS_Value src
Definition: avisynth_c.h:523
typedef void(RENAME(mix_any_func_type))
FIXME Range Coding of cr are mx and my are Motion Vector top and top right vectors is used as motion vector prediction the used motion vector is the sum of the predictor and(mvx_diff, mvy_diff)*mv_scale Intra DC Predicton block[y][x] dc[1]
Definition: snow.txt:392
void ff_rv34dsp_init_x86(RV34DSPContext *c)
Definition: rv34dsp_init.c:33
void ff_rv34dsp_init(RV34DSPContext *c)
Definition: rv34dsp.c:131
void(* rv40_strong_loop_filter_func)(uint8_t *src, ptrdiff_t stride, int alpha, int lims, int dmode, int chroma)
Definition: rv34dsp.h:49
void ff_rv40dsp_init_x86(RV34DSPContext *c)
Definition: rv40dsp_init.c:191
static double c[64]
rv40_strong_loop_filter_func rv40_strong_loop_filter[2]
Definition: rv34dsp.h:73
void(* rv40_weak_loop_filter_func)(uint8_t *src, ptrdiff_t stride, int filter_p1, int filter_q1, int alpha, int beta, int lims, int lim_q1, int lim_p1)
Definition: rv34dsp.h:44
DSP utils.
else dst[i][x+y *dst_stride[i]]
Definition: vf_mcdeint.c:160
rv34_inv_transform_func rv34_inv_transform
Definition: rv34dsp.h:68
h264_chroma_mc_func avg_chroma_pixels_tab[3]
Definition: rv34dsp.h:61
h264_chroma_mc_func put_chroma_pixels_tab[3]
Definition: rv34dsp.h:60
void ff_rv30dsp_init(RV34DSPContext *c)
Definition: rv30dsp.c:264