/src/libvpx/vp8/encoder/rdopt.h
Line | Count | Source |
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 | | #ifndef VPX_VP8_ENCODER_RDOPT_H_ |
12 | | #define VPX_VP8_ENCODER_RDOPT_H_ |
13 | | |
14 | | #include "./vpx_config.h" |
15 | | |
16 | | #ifdef __cplusplus |
17 | | extern "C" { |
18 | | #endif |
19 | | |
20 | 169M | #define RDCOST(RM, DM, R, D) (((128 + (R) * (RM)) >> 8) + (DM) * (D)) |
21 | | |
22 | | void vp8cx_initialize_me_consts(VP8_COMP *cpi, int QIndex); |
23 | | void vp8_auto_select_speed(VP8_COMP *cpi); |
24 | | |
25 | 1.25M | static INLINE void insertsortmv(int arr[], int len) { |
26 | 1.25M | int i, j, k; |
27 | | |
28 | 7.72M | for (i = 1; i <= len - 1; ++i) { |
29 | 30.0M | for (j = 0; j < i; ++j) { |
30 | 23.6M | if (arr[j] > arr[i]) { |
31 | 1.42M | int temp; |
32 | | |
33 | 1.42M | temp = arr[i]; |
34 | | |
35 | 4.46M | for (k = i; k > j; k--) arr[k] = arr[k - 1]; |
36 | | |
37 | 1.42M | arr[j] = temp; |
38 | 1.42M | } |
39 | 23.6M | } |
40 | 6.47M | } |
41 | 1.25M | } Unexecuted instantiation: pickinter.c:insertsortmv Line | Count | Source | 25 | 1.25M | static INLINE void insertsortmv(int arr[], int len) { | 26 | 1.25M | int i, j, k; | 27 | | | 28 | 7.72M | for (i = 1; i <= len - 1; ++i) { | 29 | 30.0M | for (j = 0; j < i; ++j) { | 30 | 23.6M | if (arr[j] > arr[i]) { | 31 | 1.42M | int temp; | 32 | | | 33 | 1.42M | temp = arr[i]; | 34 | | | 35 | 4.46M | for (k = i; k > j; k--) arr[k] = arr[k - 1]; | 36 | | | 37 | 1.42M | arr[j] = temp; | 38 | 1.42M | } | 39 | 23.6M | } | 40 | 6.47M | } | 41 | 1.25M | } |
Unexecuted instantiation: encodeframe.c:insertsortmv Unexecuted instantiation: encodemb.c:insertsortmv Unexecuted instantiation: firstpass.c:insertsortmv |
42 | | |
43 | 951k | static INLINE void insertsortsad(int arr[], int idx[], int len) { |
44 | 951k | int i, j, k; |
45 | | |
46 | 5.27M | for (i = 1; i <= len - 1; ++i) { |
47 | 19.2M | for (j = 0; j < i; ++j) { |
48 | 14.9M | if (arr[j] > arr[i]) { |
49 | 2.50M | int temp, tempi; |
50 | | |
51 | 2.50M | temp = arr[i]; |
52 | 2.50M | tempi = idx[i]; |
53 | | |
54 | 8.41M | for (k = i; k > j; k--) { |
55 | 5.91M | arr[k] = arr[k - 1]; |
56 | 5.91M | idx[k] = idx[k - 1]; |
57 | 5.91M | } |
58 | | |
59 | 2.50M | arr[j] = temp; |
60 | 2.50M | idx[j] = tempi; |
61 | 2.50M | } |
62 | 14.9M | } |
63 | 4.32M | } |
64 | 951k | } Unexecuted instantiation: pickinter.c:insertsortsad Line | Count | Source | 43 | 951k | static INLINE void insertsortsad(int arr[], int idx[], int len) { | 44 | 951k | int i, j, k; | 45 | | | 46 | 5.27M | for (i = 1; i <= len - 1; ++i) { | 47 | 19.2M | for (j = 0; j < i; ++j) { | 48 | 14.9M | if (arr[j] > arr[i]) { | 49 | 2.50M | int temp, tempi; | 50 | | | 51 | 2.50M | temp = arr[i]; | 52 | 2.50M | tempi = idx[i]; | 53 | | | 54 | 8.41M | for (k = i; k > j; k--) { | 55 | 5.91M | arr[k] = arr[k - 1]; | 56 | 5.91M | idx[k] = idx[k - 1]; | 57 | 5.91M | } | 58 | | | 59 | 2.50M | arr[j] = temp; | 60 | 2.50M | idx[j] = tempi; | 61 | 2.50M | } | 62 | 14.9M | } | 63 | 4.32M | } | 64 | 951k | } |
Unexecuted instantiation: encodeframe.c:insertsortsad Unexecuted instantiation: encodemb.c:insertsortsad Unexecuted instantiation: firstpass.c:insertsortsad |
65 | | |
66 | | void vp8_initialize_rd_consts(VP8_COMP *cpi, MACROBLOCK *x, int Qvalue); |
67 | | void vp8_rd_pick_inter_mode(VP8_COMP *cpi, MACROBLOCK *x, int recon_yoffset, |
68 | | int recon_uvoffset, int *returnrate, |
69 | | int *returndistortion, int *returnintra, int mb_row, |
70 | | int mb_col); |
71 | | void vp8_rd_pick_intra_mode(MACROBLOCK *x, int *rate); |
72 | | |
73 | | static INLINE void get_plane_pointers(const YV12_BUFFER_CONFIG *fb, |
74 | | unsigned char *plane[3], |
75 | | unsigned int recon_yoffset, |
76 | 2.13M | unsigned int recon_uvoffset) { |
77 | 2.13M | plane[0] = fb->y_buffer + recon_yoffset; |
78 | 2.13M | plane[1] = fb->u_buffer + recon_uvoffset; |
79 | 2.13M | plane[2] = fb->v_buffer + recon_uvoffset; |
80 | 2.13M | } pickinter.c:get_plane_pointers Line | Count | Source | 76 | 1.21M | unsigned int recon_uvoffset) { | 77 | 1.21M | plane[0] = fb->y_buffer + recon_yoffset; | 78 | 1.21M | plane[1] = fb->u_buffer + recon_uvoffset; | 79 | 1.21M | plane[2] = fb->v_buffer + recon_uvoffset; | 80 | 1.21M | } |
rdopt.c:get_plane_pointers Line | Count | Source | 76 | 920k | unsigned int recon_uvoffset) { | 77 | 920k | plane[0] = fb->y_buffer + recon_yoffset; | 78 | 920k | plane[1] = fb->u_buffer + recon_uvoffset; | 79 | 920k | plane[2] = fb->v_buffer + recon_uvoffset; | 80 | 920k | } |
Unexecuted instantiation: encodeframe.c:get_plane_pointers Unexecuted instantiation: encodemb.c:get_plane_pointers Unexecuted instantiation: firstpass.c:get_plane_pointers |
81 | | |
82 | | static INLINE void get_predictor_pointers(const VP8_COMP *cpi, |
83 | | unsigned char *plane[4][3], |
84 | | unsigned int recon_yoffset, |
85 | 1.27M | unsigned int recon_uvoffset) { |
86 | 1.27M | if (cpi->ref_frame_flags & VP8_LAST_FRAME) { |
87 | 1.27M | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.lst_fb_idx], |
88 | 1.27M | plane[LAST_FRAME], recon_yoffset, recon_uvoffset); |
89 | 1.27M | } |
90 | | |
91 | 1.27M | if (cpi->ref_frame_flags & VP8_GOLD_FRAME) { |
92 | 646k | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.gld_fb_idx], |
93 | 646k | plane[GOLDEN_FRAME], recon_yoffset, recon_uvoffset); |
94 | 646k | } |
95 | | |
96 | 1.27M | if (cpi->ref_frame_flags & VP8_ALTR_FRAME) { |
97 | 206k | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.alt_fb_idx], |
98 | 206k | plane[ALTREF_FRAME], recon_yoffset, recon_uvoffset); |
99 | 206k | } |
100 | 1.27M | } pickinter.c:get_predictor_pointers Line | Count | Source | 85 | 725k | unsigned int recon_uvoffset) { | 86 | 725k | if (cpi->ref_frame_flags & VP8_LAST_FRAME) { | 87 | 725k | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.lst_fb_idx], | 88 | 725k | plane[LAST_FRAME], recon_yoffset, recon_uvoffset); | 89 | 725k | } | 90 | | | 91 | 725k | if (cpi->ref_frame_flags & VP8_GOLD_FRAME) { | 92 | 369k | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.gld_fb_idx], | 93 | 369k | plane[GOLDEN_FRAME], recon_yoffset, recon_uvoffset); | 94 | 369k | } | 95 | | | 96 | 725k | if (cpi->ref_frame_flags & VP8_ALTR_FRAME) { | 97 | 114k | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.alt_fb_idx], | 98 | 114k | plane[ALTREF_FRAME], recon_yoffset, recon_uvoffset); | 99 | 114k | } | 100 | 725k | } |
rdopt.c:get_predictor_pointers Line | Count | Source | 85 | 552k | unsigned int recon_uvoffset) { | 86 | 552k | if (cpi->ref_frame_flags & VP8_LAST_FRAME) { | 87 | 552k | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.lst_fb_idx], | 88 | 552k | plane[LAST_FRAME], recon_yoffset, recon_uvoffset); | 89 | 552k | } | 90 | | | 91 | 552k | if (cpi->ref_frame_flags & VP8_GOLD_FRAME) { | 92 | 276k | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.gld_fb_idx], | 93 | 276k | plane[GOLDEN_FRAME], recon_yoffset, recon_uvoffset); | 94 | 276k | } | 95 | | | 96 | 552k | if (cpi->ref_frame_flags & VP8_ALTR_FRAME) { | 97 | 91.8k | get_plane_pointers(&cpi->common.yv12_fb[cpi->common.alt_fb_idx], | 98 | 91.8k | plane[ALTREF_FRAME], recon_yoffset, recon_uvoffset); | 99 | 91.8k | } | 100 | 552k | } |
Unexecuted instantiation: encodeframe.c:get_predictor_pointers Unexecuted instantiation: encodemb.c:get_predictor_pointers Unexecuted instantiation: firstpass.c:get_predictor_pointers |
101 | | |
102 | | static INLINE void get_reference_search_order(const VP8_COMP *cpi, |
103 | 1.27M | int ref_frame_map[4]) { |
104 | 1.27M | int i = 0; |
105 | | |
106 | 1.27M | ref_frame_map[i++] = INTRA_FRAME; |
107 | 1.27M | if (cpi->ref_frame_flags & VP8_LAST_FRAME) ref_frame_map[i++] = LAST_FRAME; |
108 | 1.27M | if (cpi->ref_frame_flags & VP8_GOLD_FRAME) ref_frame_map[i++] = GOLDEN_FRAME; |
109 | 1.27M | if (cpi->ref_frame_flags & VP8_ALTR_FRAME) ref_frame_map[i++] = ALTREF_FRAME; |
110 | 2.98M | for (; i < 4; ++i) ref_frame_map[i] = -1; |
111 | 1.27M | } pickinter.c:get_reference_search_order Line | Count | Source | 103 | 725k | int ref_frame_map[4]) { | 104 | 725k | int i = 0; | 105 | | | 106 | 725k | ref_frame_map[i++] = INTRA_FRAME; | 107 | 725k | if (cpi->ref_frame_flags & VP8_LAST_FRAME) ref_frame_map[i++] = LAST_FRAME; | 108 | 725k | if (cpi->ref_frame_flags & VP8_GOLD_FRAME) ref_frame_map[i++] = GOLDEN_FRAME; | 109 | 725k | if (cpi->ref_frame_flags & VP8_ALTR_FRAME) ref_frame_map[i++] = ALTREF_FRAME; | 110 | 1.69M | for (; i < 4; ++i) ref_frame_map[i] = -1; | 111 | 725k | } |
rdopt.c:get_reference_search_order Line | Count | Source | 103 | 552k | int ref_frame_map[4]) { | 104 | 552k | int i = 0; | 105 | | | 106 | 552k | ref_frame_map[i++] = INTRA_FRAME; | 107 | 552k | if (cpi->ref_frame_flags & VP8_LAST_FRAME) ref_frame_map[i++] = LAST_FRAME; | 108 | 552k | if (cpi->ref_frame_flags & VP8_GOLD_FRAME) ref_frame_map[i++] = GOLDEN_FRAME; | 109 | 552k | if (cpi->ref_frame_flags & VP8_ALTR_FRAME) ref_frame_map[i++] = ALTREF_FRAME; | 110 | 1.29M | for (; i < 4; ++i) ref_frame_map[i] = -1; | 111 | 552k | } |
Unexecuted instantiation: encodeframe.c:get_reference_search_order Unexecuted instantiation: encodemb.c:get_reference_search_order Unexecuted instantiation: firstpass.c:get_reference_search_order |
112 | | |
113 | | void vp8_mv_pred(VP8_COMP *cpi, MACROBLOCKD *xd, const MODE_INFO *here, |
114 | | int_mv *mvp, int refframe, int *ref_frame_sign_bias, int *sr, |
115 | | int near_sadidx[]); |
116 | | void vp8_cal_sad(VP8_COMP *cpi, MACROBLOCKD *xd, MACROBLOCK *x, |
117 | | int recon_yoffset, int near_sadidx[]); |
118 | | int VP8_UVSSE(MACROBLOCK *x); |
119 | | int vp8_cost_mv_ref(MB_PREDICTION_MODE m, const int near_mv_ref_ct[4]); |
120 | | void vp8_set_mbmode_and_mvs(MACROBLOCK *x, MB_PREDICTION_MODE mb, int_mv *mv); |
121 | | |
122 | | #ifdef __cplusplus |
123 | | } // extern "C" |
124 | | #endif |
125 | | |
126 | | #endif // VPX_VP8_ENCODER_RDOPT_H_ |