| OLD | NEW |
| 1 /* | 1 /* |
| 2 * Copyright (c) 2010 The WebM project authors. All Rights Reserved. | 2 * Copyright (c) 2010 The WebM project authors. All Rights Reserved. |
| 3 * | 3 * |
| 4 * Use of this source code is governed by a BSD-style license | 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 | 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 | 6 * tree. An additional intellectual property rights grant can be found |
| 7 * in the file PATENTS. All contributing project authors may | 7 * in the file PATENTS. All contributing project authors may |
| 8 * be found in the AUTHORS file in the root of the source tree. | 8 * be found in the AUTHORS file in the root of the source tree. |
| 9 */ | 9 */ |
| 10 | 10 |
| 11 | 11 |
| 12 #include "vp9/common/vp9_blockd.h" | 12 #include "vp9/common/vp9_blockd.h" |
| 13 #include "vp9/encoder/vp9_onyx_int.h" | 13 #include "vp9/encoder/vp9_onyx_int.h" |
| 14 #include "vp9/encoder/vp9_treewriter.h" | 14 #include "vp9/encoder/vp9_treewriter.h" |
| 15 #include "vp9/common/vp9_entropymode.h" | 15 #include "vp9/common/vp9_entropymode.h" |
| 16 | 16 |
| 17 | 17 |
| 18 void vp9_init_mode_costs(VP9_COMP *c) { | 18 void vp9_init_mode_costs(VP9_COMP *c) { |
| 19 VP9_COMMON *const cm = &c->common; | 19 VP9_COMMON *const cm = &c->common; |
| 20 const vp9_tree_p KT = vp9_intra_mode_tree; | 20 const vp9_tree_index *KT = vp9_intra_mode_tree; |
| 21 int i, j; | 21 int i, j; |
| 22 | 22 |
| 23 for (i = 0; i < INTRA_MODES; i++) { | 23 for (i = 0; i < INTRA_MODES; i++) { |
| 24 for (j = 0; j < INTRA_MODES; j++) { | 24 for (j = 0; j < INTRA_MODES; j++) { |
| 25 vp9_cost_tokens((int *)c->mb.y_mode_costs[i][j], vp9_kf_y_mode_prob[i][j], | 25 vp9_cost_tokens((int *)c->mb.y_mode_costs[i][j], vp9_kf_y_mode_prob[i][j], |
| 26 KT); | 26 KT); |
| 27 } | 27 } |
| 28 } | 28 } |
| 29 | 29 |
| 30 // TODO(rbultje) separate tables for superblock costing? | 30 // TODO(rbultje) separate tables for superblock costing? |
| 31 vp9_cost_tokens(c->mb.mbmode_cost, cm->fc.y_mode_prob[1], | 31 vp9_cost_tokens(c->mb.mbmode_cost, cm->fc.y_mode_prob[1], |
| 32 vp9_intra_mode_tree); | 32 vp9_intra_mode_tree); |
| 33 vp9_cost_tokens(c->mb.intra_uv_mode_cost[1], | 33 vp9_cost_tokens(c->mb.intra_uv_mode_cost[1], |
| 34 cm->fc.uv_mode_prob[INTRA_MODES - 1], vp9_intra_mode_tree); | 34 cm->fc.uv_mode_prob[INTRA_MODES - 1], vp9_intra_mode_tree); |
| 35 vp9_cost_tokens(c->mb.intra_uv_mode_cost[0], | 35 vp9_cost_tokens(c->mb.intra_uv_mode_cost[0], |
| 36 vp9_kf_uv_mode_prob[INTRA_MODES - 1], | 36 vp9_kf_uv_mode_prob[INTRA_MODES - 1], |
| 37 vp9_intra_mode_tree); | 37 vp9_intra_mode_tree); |
| 38 | 38 |
| 39 for (i = 0; i <= SWITCHABLE_FILTERS; ++i) | 39 for (i = 0; i < SWITCHABLE_FILTER_CONTEXTS; ++i) |
| 40 vp9_cost_tokens((int *)c->mb.switchable_interp_costs[i], | 40 vp9_cost_tokens((int *)c->mb.switchable_interp_costs[i], |
| 41 cm->fc.switchable_interp_prob[i], | 41 cm->fc.switchable_interp_prob[i], |
| 42 vp9_switchable_interp_tree); | 42 vp9_switchable_interp_tree); |
| 43 } | 43 } |
| OLD | NEW |