blob: 4bc470acda9295588326447dba00bb449c632352 [file] [log] [blame]
/*
* Copyright (c) 2016, Alliance for Open Media. All rights reserved
*
* This source code is subject to the terms of the BSD 2 Clause License and
* the Alliance for Open Media Patent License 1.0. If the BSD 2 Clause License
* was not distributed with this source code in the LICENSE file, you can
* obtain it at www.aomedia.org/license/software. If the Alliance for Open
* Media Patent License 1.0 was not distributed with this source code in the
* PATENTS file, you can obtain it at www.aomedia.org/license/patent.
*/
#include "aom_mem/aom_mem.h"
#include "av1/common/reconinter.h"
#include "av1/common/scan.h"
#include "av1/common/onyxc_int.h"
#include "av1/common/seg_common.h"
#if CONFIG_ALT_INTRA
const aom_prob av1_kf_y_mode_prob[INTRA_MODES][INTRA_MODES][INTRA_MODES - 1] = {
{
// above = dc
{ 121, 30, 54, 128, 164, 158, 45, 41, 57, 91 }, // left = dc
{ 91, 38, 101, 102, 124, 141, 49, 48, 45, 73 }, // left = v
{ 66, 28, 27, 177, 225, 178, 32, 27, 52, 114 }, // left = h
{ 106, 23, 50, 101, 134, 148, 64, 50, 49, 107 }, // left = d45
{ 75, 24, 32, 118, 66, 143, 42, 28, 57, 74 }, // left = d135
{ 95, 24, 40, 142, 56, 141, 72, 121, 129, 255 }, // left = d117
{ 71, 14, 25, 126, 117, 201, 28, 21, 117, 89 }, // left = d153
{ 85, 16, 37, 110, 163, 178, 41, 28, 48, 134 }, // left = d207
{ 86, 25, 32, 83, 105, 133, 58, 81, 46, 95 }, // left = d63
{ 79, 25, 38, 75, 150, 255, 30, 49, 34, 51 }, // left = smooth
{ 68, 59, 48, 122, 193, 158, 43, 46, 46, 112 }, // left = paeth
},
{
// above = v
{ 66, 21, 118, 111, 145, 107, 27, 50, 27, 54 }, // left = dc
{ 52, 25, 167, 81, 120, 101, 34, 55, 19, 32 }, // left = v
{ 56, 18, 72, 134, 208, 139, 31, 34, 27, 89 }, // left = h
{ 75, 21, 94, 88, 134, 123, 49, 57, 30, 68 }, // left = d45
{ 54, 18, 95, 96, 78, 107, 33, 49, 28, 65 }, // left = d135
{ 61, 19, 121, 131, 58, 101, 56, 143, 120, 255 }, // left = d117
{ 53, 13, 78, 103, 110, 147, 31, 41, 64, 77 }, // left = d153
{ 69, 14, 78, 93, 167, 121, 31, 39, 25, 113 }, // left = d207
{ 64, 18, 103, 79, 90, 108, 34, 73, 27, 69 }, // left = d63
{ 52, 20, 103, 61, 161, 255, 22, 42, 16, 35 }, // left = smooth
{ 50, 31, 124, 92, 161, 120, 50, 53, 23, 60 }, // left = paeth
},
{
// above = h
{ 94, 29, 31, 158, 214, 178, 35, 31, 72, 111 }, // left = dc
{ 72, 37, 72, 149, 184, 177, 43, 40, 53, 105 }, // left = v
{ 53, 21, 14, 196, 242, 209, 29, 19, 55, 145 }, // left = h
{ 93, 36, 36, 104, 176, 166, 56, 37, 49, 141 }, // left = d45
{ 84, 32, 27, 124, 108, 143, 38, 36, 76, 134 }, // left = d135
{ 82, 31, 47, 142, 122, 161, 83, 73, 126, 255 }, // left = d117
{ 66, 16, 20, 133, 148, 210, 30, 17, 113, 104 }, // left = d153
{ 76, 16, 17, 129, 207, 181, 41, 20, 46, 163 }, // left = d207
{ 72, 38, 21, 100, 142, 171, 37, 70, 49, 111 }, // left = d63
{ 61, 30, 27, 115, 208, 255, 27, 31, 44, 63 }, // left = smooth
{ 53, 45, 29, 157, 222, 185, 49, 37, 55, 102 }, // left = paeth
},
{
// above = d45
{ 96, 18, 37, 98, 138, 154, 68, 56, 59, 96 }, // left = dc
{ 73, 18, 92, 81, 125, 132, 75, 64, 27, 67 }, // left = v
{ 73, 17, 27, 128, 213, 154, 56, 44, 32, 105 }, // left = h
{ 101, 20, 21, 75, 138, 138, 82, 56, 23, 154 }, // left = d45
{ 71, 15, 33, 91, 70, 150, 62, 55, 38, 118 }, // left = d135
{ 80, 19, 38, 116, 69, 122, 88, 132, 92, 255 }, // left = d117
{ 68, 11, 22, 101, 116, 179, 52, 44, 85, 96 }, // left = d153
{ 101, 8, 59, 77, 151, 170, 53, 41, 35, 172 }, // left = d207
{ 82, 19, 24, 81, 172, 129, 82, 128, 43, 108 }, // left = d63
{ 66, 18, 42, 64, 143, 255, 52, 52, 25, 83 }, // left = smooth
{ 57, 24, 42, 85, 169, 145, 104, 71, 34, 86 }, // left = paeth
},
{
// above = d135
{ 85, 15, 29, 113, 83, 176, 26, 29, 70, 110 }, // left = dc
{ 78, 28, 49, 111, 91, 141, 30, 42, 48, 75 }, // left = v
{ 56, 21, 16, 146, 190, 178, 23, 31, 49, 92 }, // left = h
{ 70, 19, 20, 65, 90, 173, 97, 36, 57, 98 }, // left = d45
{ 77, 14, 26, 110, 51, 156, 34, 35, 54, 74 }, // left = d135
{ 78, 18, 36, 153, 47, 131, 62, 102, 155, 255 }, // left = d117
{ 56, 11, 15, 115, 85, 196, 32, 45, 81, 96 }, // left = d153
{ 90, 18, 24, 95, 126, 159, 34, 31, 46, 136 }, // left = d207
{ 80, 23, 28, 90, 75, 141, 39, 50, 46, 87 }, // left = d63
{ 63, 22, 31, 91, 110, 255, 26, 43, 51, 51 }, // left = smooth
{ 66, 32, 31, 122, 145, 165, 40, 43, 56, 79 }, // left = paeth
},
{
// above = d117
{ 81, 16, 61, 170, 74, 105, 54, 105, 113, 255 }, // left = dc
{ 74, 20, 86, 163, 64, 97, 65, 129, 101, 255 }, // left = v
{ 63, 15, 47, 168, 141, 176, 69, 77, 77, 255 }, // left = h
{ 70, 17, 59, 97, 78, 114, 74, 122, 80, 255 }, // left = d45
{ 78, 13, 50, 153, 34, 126, 75, 114, 120, 255 }, // left = d135
{ 72, 16, 69, 159, 28, 108, 63, 134, 107, 255 }, // left = d117
{ 66, 9, 47, 131, 79, 148, 41, 88, 105, 255 }, // left = d153
{ 78, 12, 60, 119, 105, 133, 47, 95, 63, 255 }, // left = d207
{ 82, 21, 58, 128, 61, 98, 64, 136, 91, 255 }, // left = d63
{ 23, 26, 28, 96, 85, 128, 51, 64, 85, 128 }, // left = smooth
{ 58, 27, 62, 162, 109, 151, 75, 106, 78, 255 }, // left = paeth
},
{
// above = d153
{ 91, 18, 25, 121, 166, 173, 25, 25, 128, 102 }, // left = dc
{ 80, 27, 51, 111, 141, 147, 45, 38, 70, 85 }, // left = v
{ 53, 12, 11, 154, 197, 225, 17, 17, 74, 145 }, // left = h
{ 93, 27, 23, 111, 143, 188, 43, 39, 69, 112 }, // left = d45
{ 83, 15, 21, 118, 67, 178, 40, 33, 73, 92 }, // left = d135
{ 94, 13, 31, 132, 66, 110, 61, 82, 148, 255 }, // left = d117
{ 76, 9, 11, 96, 105, 201, 16, 13, 157, 97 }, // left = d153
{ 70, 10, 12, 100, 172, 201, 23, 17, 53, 158 }, // left = d207
{ 114, 25, 21, 104, 108, 163, 30, 47, 53, 111 }, // left = d63
{ 70, 16, 21, 80, 157, 255, 25, 30, 81, 69 }, // left = smooth
{ 87, 32, 26, 120, 191, 168, 32, 33, 70, 118 }, // left = paeth
},
{
// above = d207
{ 98, 20, 39, 122, 168, 188, 38, 36, 54, 132 }, // left = dc
{ 81, 37, 62, 97, 122, 153, 38, 43, 36, 118 }, // left = v
{ 71, 21, 22, 154, 227, 183, 37, 31, 46, 140 }, // left = h
{ 90, 34, 19, 93, 144, 194, 65, 47, 41, 163 }, // left = d45
{ 78, 20, 27, 91, 93, 173, 57, 52, 49, 113 }, // left = d135
{ 79, 25, 45, 121, 101, 147, 69, 56, 122, 255 }, // left = d117
{ 73, 13, 19, 105, 122, 206, 40, 28, 91, 126 }, // left = d153
{ 101, 14, 22, 87, 153, 169, 33, 25, 26, 175 }, // left = d207
{ 81, 28, 23, 86, 115, 169, 48, 56, 41, 111 }, // left = d63
{ 70, 24, 30, 90, 180, 255, 38, 26, 36, 82 }, // left = smooth
{ 61, 37, 30, 94, 189, 163, 76, 50, 36, 127 }, // left = paeth
},
{
// above = d63
{ 77, 13, 46, 86, 138, 117, 55, 88, 34, 68 }, // left = dc
{ 68, 17, 80, 64, 105, 108, 66, 115, 32, 45 }, // left = v
{ 62, 13, 37, 124, 210, 131, 46, 57, 28, 103 }, // left = h
{ 88, 15, 45, 73, 134, 145, 73, 101, 37, 87 }, // left = d45
{ 68, 16, 35, 78, 81, 133, 54, 71, 33, 67 }, // left = d135
{ 71, 16, 57, 108, 61, 135, 71, 184, 113, 255 }, // left = d117
{ 55, 10, 27, 69, 107, 158, 39, 76, 82, 95 }, // left = d153
{ 80, 9, 38, 78, 153, 145, 50, 63, 28, 123 }, // left = d207
{ 86, 12, 33, 49, 107, 135, 64, 134, 57, 89 }, // left = d63
{ 56, 19, 55, 60, 163, 255, 38, 84, 22, 36 }, // left = smooth
{ 53, 17, 60, 69, 151, 126, 73, 113, 26, 80 }, // left = paeth
},
{
// above = smooth
{ 79, 16, 46, 89, 167, 255, 22, 36, 29, 42 }, // left = dc
{ 63, 22, 88, 71, 131, 255, 26, 41, 21, 35 }, // left = v
{ 51, 18, 28, 142, 232, 255, 26, 25, 25, 75 }, // left = h
{ 75, 18, 43, 70, 140, 255, 37, 49, 34, 89 }, // left = d45
{ 70, 14, 35, 87, 83, 255, 30, 36, 34, 50 }, // left = d135
{ 23, 26, 28, 96, 85, 128, 51, 64, 85, 128 }, // left = d117
{ 74, 12, 33, 83, 128, 255, 27, 33, 58, 68 }, // left = d153
{ 66, 11, 30, 77, 179, 255, 21, 27, 23, 113 }, // left = d207
{ 68, 22, 40, 65, 118, 255, 28, 61, 30, 50 }, // left = d63
{ 60, 18, 44, 69, 141, 255, 18, 32, 22, 40 }, // left = smooth
{ 52, 32, 54, 96, 194, 255, 33, 37, 25, 53 }, // left = paeth
},
{
// above = paeth
{ 76, 47, 67, 123, 182, 150, 41, 52, 55, 97 }, // left = dc
{ 69, 40, 125, 102, 138, 138, 42, 55, 32, 70 }, // left = v
{ 46, 28, 27, 160, 232, 169, 34, 21, 32, 122 }, // left = h
{ 78, 35, 41, 99, 128, 124, 49, 43, 35, 111 }, // left = d45
{ 66, 28, 47, 100, 113, 145, 37, 40, 72, 93 }, // left = d135
{ 77, 37, 76, 134, 124, 124, 65, 122, 88, 255 }, // left = d117
{ 53, 23, 38, 108, 128, 204, 26, 32, 115, 114 }, // left = d153
{ 65, 20, 29, 101, 202, 186, 29, 24, 29, 188 }, // left = d207
{ 71, 24, 49, 81, 126, 151, 36, 65, 28, 93 }, // left = d63
{ 54, 36, 53, 94, 193, 255, 25, 38, 20, 64 }, // left = smooth
{ 52, 54, 60, 108, 176, 168, 47, 44, 50, 105 }, // left = paeth
},
};
static const aom_prob default_if_y_probs[BLOCK_SIZE_GROUPS][INTRA_MODES - 1] = {
{ 88, 16, 47, 133, 143, 150, 70, 48, 84, 122 }, // block_size < 8x8
{ 75, 26, 51, 120, 158, 157, 44, 45, 56, 102 }, // block_size < 16x16
{ 73, 24, 60, 115, 184, 164, 26, 36, 32, 63 }, // block_size < 32x32
{ 96, 27, 50, 107, 221, 148, 16, 22, 14, 39 }, // block_size >= 32x32
};
static const aom_prob default_uv_probs[INTRA_MODES][INTRA_MODES - 1] = {
{ 199, 3, 79, 179, 220, 109, 38, 50, 68, 138 }, // y = dc
{ 17, 2, 219, 136, 131, 58, 21, 106, 23, 41 }, // y = v
{ 26, 1, 5, 244, 253, 138, 16, 21, 68, 205 }, // y = h
{ 183, 3, 66, 94, 195, 97, 101, 104, 41, 178 }, // y = d45
{ 178, 2, 36, 158, 99, 175, 21, 29, 105, 77 }, // y = d135
{ 154, 3, 65, 219, 40, 48, 45, 95, 146, 255 }, // y = d117
{ 167, 1, 16, 160, 214, 187, 10, 10, 200, 155 }, // y = d153
{ 154, 2, 18, 178, 238, 132, 25, 21, 34, 221 }, // y = d207
{ 153, 4, 76, 85, 157, 90, 38, 165, 46, 104 }, // y = d63
{ 163, 3, 68, 87, 190, 255, 19, 27, 25, 46 }, // y = smooth
{ 185, 7, 113, 171, 203, 57, 18, 69, 49, 104 }, // y = paeth
};
#else
const aom_prob av1_kf_y_mode_prob[INTRA_MODES][INTRA_MODES][INTRA_MODES - 1] = {
{
// above = dc
{ 137, 30, 42, 148, 151, 207, 70, 52, 91 }, // left = dc
{ 92, 45, 102, 136, 116, 180, 74, 90, 100 }, // left = v
{ 73, 32, 19, 187, 222, 215, 46, 34, 100 }, // left = h
{ 91, 30, 32, 116, 121, 186, 93, 86, 94 }, // left = d45
{ 72, 35, 36, 149, 68, 206, 68, 63, 105 }, // left = d135
{ 73, 31, 28, 138, 57, 124, 55, 122, 151 }, // left = d117
{ 67, 23, 21, 140, 126, 197, 40, 37, 171 }, // left = d153
{ 86, 27, 28, 128, 154, 212, 45, 43, 53 }, // left = d207
{ 74, 32, 27, 107, 86, 160, 63, 134, 102 }, // left = d63
{ 59, 67, 44, 140, 161, 202, 78, 67, 119 } // left = tm
},
{
// above = v
{ 63, 36, 126, 146, 123, 158, 60, 90, 96 }, // left = dc
{ 43, 46, 168, 134, 107, 128, 69, 142, 92 }, // left = v
{ 44, 29, 68, 159, 201, 177, 50, 57, 77 }, // left = h
{ 58, 38, 76, 114, 97, 172, 78, 133, 92 }, // left = d45
{ 46, 41, 76, 140, 63, 184, 69, 112, 57 }, // left = d135
{ 38, 32, 85, 140, 46, 112, 54, 151, 133 }, // left = d117
{ 39, 27, 61, 131, 110, 175, 44, 75, 136 }, // left = d153
{ 52, 30, 74, 113, 130, 175, 51, 64, 58 }, // left = d207
{ 47, 35, 80, 100, 74, 143, 64, 163, 74 }, // left = d63
{ 36, 61, 116, 114, 128, 162, 80, 125, 82 } // left = tm
},
{
// above = h
{ 82, 26, 26, 171, 208, 204, 44, 32, 105 }, // left = dc
{ 55, 44, 68, 166, 179, 192, 57, 57, 108 }, // left = v
{ 42, 26, 11, 199, 241, 228, 23, 15, 85 }, // left = h
{ 68, 42, 19, 131, 160, 199, 55, 52, 83 }, // left = d45
{ 58, 50, 25, 139, 115, 232, 39, 52, 118 }, // left = d135
{ 50, 35, 33, 153, 104, 162, 64, 59, 131 }, // left = d117
{ 44, 24, 16, 150, 177, 202, 33, 19, 156 }, // left = d153
{ 55, 27, 12, 153, 203, 218, 26, 27, 49 }, // left = d207
{ 53, 49, 21, 110, 116, 168, 59, 80, 76 }, // left = d63
{ 38, 72, 19, 168, 203, 212, 50, 50, 107 } // left = tm
},
{
// above = d45
{ 103, 26, 36, 129, 132, 201, 83, 80, 93 }, // left = dc
{ 59, 38, 83, 112, 103, 162, 98, 136, 90 }, // left = v
{ 62, 30, 23, 158, 200, 207, 59, 57, 50 }, // left = h
{ 67, 30, 29, 84, 86, 191, 102, 91, 59 }, // left = d45
{ 60, 32, 33, 112, 71, 220, 64, 89, 104 }, // left = d135
{ 53, 26, 34, 130, 56, 149, 84, 120, 103 }, // left = d117
{ 53, 21, 23, 133, 109, 210, 56, 77, 172 }, // left = d153
{ 77, 19, 29, 112, 142, 228, 55, 66, 36 }, // left = d207
{ 61, 29, 29, 93, 97, 165, 83, 175, 162 }, // left = d63
{ 47, 47, 43, 114, 137, 181, 100, 99, 95 } // left = tm
},
{
// above = d135
{ 69, 23, 29, 128, 83, 199, 46, 44, 101 }, // left = dc
{ 53, 40, 55, 139, 69, 183, 61, 80, 110 }, // left = v
{ 40, 29, 19, 161, 180, 207, 43, 24, 91 }, // left = h
{ 60, 34, 19, 105, 61, 198, 53, 64, 89 }, // left = d45
{ 52, 31, 22, 158, 40, 209, 58, 62, 89 }, // left = d135
{ 44, 31, 29, 147, 46, 158, 56, 102, 198 }, // left = d117
{ 35, 19, 12, 135, 87, 209, 41, 45, 167 }, // left = d153
{ 55, 25, 21, 118, 95, 215, 38, 39, 66 }, // left = d207
{ 51, 38, 25, 113, 58, 164, 70, 93, 97 }, // left = d63
{ 47, 54, 34, 146, 108, 203, 72, 103, 151 } // left = tm
},
{
// above = d117
{ 64, 19, 37, 156, 66, 138, 49, 95, 133 }, // left = dc
{ 46, 27, 80, 150, 55, 124, 55, 121, 135 }, // left = v
{ 36, 23, 27, 165, 149, 166, 54, 64, 118 }, // left = h
{ 53, 21, 36, 131, 63, 163, 60, 109, 81 }, // left = d45
{ 40, 26, 35, 154, 40, 185, 51, 97, 123 }, // left = d135
{ 35, 19, 34, 179, 19, 97, 48, 129, 124 }, // left = d117
{ 36, 20, 26, 136, 62, 164, 33, 77, 154 }, // left = d153
{ 45, 18, 32, 130, 90, 157, 40, 79, 91 }, // left = d207
{ 45, 26, 28, 129, 45, 129, 49, 147, 123 }, // left = d63
{ 38, 44, 51, 136, 74, 162, 57, 97, 121 } // left = tm
},
{
// above = d153
{ 75, 17, 22, 136, 138, 185, 32, 34, 166 }, // left = dc
{ 56, 39, 58, 133, 117, 173, 48, 53, 187 }, // left = v
{ 35, 21, 12, 161, 212, 207, 20, 23, 145 }, // left = h
{ 56, 29, 19, 117, 109, 181, 55, 68, 112 }, // left = d45
{ 47, 29, 17, 153, 64, 220, 59, 51, 114 }, // left = d135
{ 46, 16, 24, 136, 76, 147, 41, 64, 172 }, // left = d117
{ 34, 17, 11, 108, 152, 187, 13, 15, 209 }, // left = d153
{ 51, 24, 14, 115, 133, 209, 32, 26, 104 }, // left = d207
{ 55, 30, 18, 122, 79, 179, 44, 88, 116 }, // left = d63
{ 37, 49, 25, 129, 168, 164, 41, 54, 148 } // left = tm
},
{
// above = d207
{ 82, 22, 32, 127, 143, 213, 39, 41, 70 }, // left = dc
{ 62, 44, 61, 123, 105, 189, 48, 57, 64 }, // left = v
{ 47, 25, 17, 175, 222, 220, 24, 30, 86 }, // left = h
{ 68, 36, 17, 106, 102, 206, 59, 74, 74 }, // left = d45
{ 57, 39, 23, 151, 68, 216, 55, 63, 58 }, // left = d135
{ 49, 30, 35, 141, 70, 168, 82, 40, 115 }, // left = d117
{ 51, 25, 15, 136, 129, 202, 38, 35, 139 }, // left = d153
{ 68, 26, 16, 111, 141, 215, 29, 28, 28 }, // left = d207
{ 59, 39, 19, 114, 75, 180, 77, 104, 42 }, // left = d63
{ 40, 61, 26, 126, 152, 206, 61, 59, 93 } // left = tm
},
{
// above = d63
{ 78, 23, 39, 111, 117, 170, 74, 124, 94 }, // left = dc
{ 48, 34, 86, 101, 92, 146, 78, 179, 134 }, // left = v
{ 47, 22, 24, 138, 187, 178, 68, 69, 59 }, // left = h
{ 56, 25, 33, 105, 112, 187, 95, 177, 129 }, // left = d45
{ 48, 31, 27, 114, 63, 183, 82, 116, 56 }, // left = d135
{ 43, 28, 37, 121, 63, 123, 61, 192, 169 }, // left = d117
{ 42, 17, 24, 109, 97, 177, 56, 76, 122 }, // left = d153
{ 58, 18, 28, 105, 139, 182, 70, 92, 63 }, // left = d207
{ 46, 23, 32, 74, 86, 150, 67, 183, 88 }, // left = d63
{ 36, 38, 48, 92, 122, 165, 88, 137, 91 } // left = tm
},
{
// above = tm
{ 65, 70, 60, 155, 159, 199, 61, 60, 81 }, // left = dc
{ 44, 78, 115, 132, 119, 173, 71, 112, 93 }, // left = v
{ 39, 38, 21, 184, 227, 206, 42, 32, 64 }, // left = h
{ 58, 47, 36, 124, 137, 193, 80, 82, 78 }, // left = d45
{ 49, 50, 35, 144, 95, 205, 63, 78, 59 }, // left = d135
{ 41, 53, 52, 148, 71, 142, 65, 128, 51 }, // left = d117
{ 40, 36, 28, 143, 143, 202, 40, 55, 137 }, // left = d153
{ 52, 34, 29, 129, 183, 227, 42, 35, 43 }, // left = d207
{ 42, 44, 44, 104, 105, 164, 64, 130, 80 }, // left = d63
{ 43, 81, 53, 140, 169, 204, 68, 84, 72 } // left = tm
}
};
// Default probabilities for signaling Intra mode for Y plane -- used only for
// inter frames. ('av1_kf_y_mode_prob' is used for intra-only frames).
// Context used: block size group.
static const aom_prob default_if_y_probs[BLOCK_SIZE_GROUPS][INTRA_MODES - 1] = {
{ 65, 32, 18, 144, 162, 194, 41, 51, 98 }, // block_size < 8x8
{ 132, 68, 18, 165, 217, 196, 45, 40, 78 }, // block_size < 16x16
{ 173, 80, 19, 176, 240, 193, 64, 35, 46 }, // block_size < 32x32
{ 221, 135, 38, 194, 248, 121, 96, 85, 29 } // block_size >= 32x32
};
// Default probabilities for signaling Intra mode for UV plane -- common for
// both intra and inter frames.
// Context used: Intra mode used by Y plane of the same block.
static const aom_prob default_uv_probs[INTRA_MODES][INTRA_MODES - 1] = {
{ 120, 7, 76, 176, 208, 126, 28, 54, 103 }, // y = dc
{ 48, 12, 154, 155, 139, 90, 34, 117, 119 }, // y = v
{ 67, 6, 25, 204, 243, 158, 13, 21, 96 }, // y = h
{ 97, 5, 44, 131, 176, 139, 48, 68, 97 }, // y = d45
{ 83, 5, 42, 156, 111, 152, 26, 49, 152 }, // y = d135
{ 80, 5, 58, 178, 74, 83, 33, 62, 145 }, // y = d117
{ 86, 5, 32, 154, 192, 168, 14, 22, 163 }, // y = d153
{ 85, 5, 32, 156, 216, 148, 19, 29, 73 }, // y = d207
{ 77, 7, 64, 116, 132, 122, 37, 126, 120 }, // y = d63
{ 101, 21, 107, 181, 192, 103, 19, 67, 125 } // y = tm
};
#endif // CONFIG_ALT_INTRA
#if CONFIG_EXT_PARTITION_TYPES
static const aom_prob
default_partition_probs[PARTITION_CONTEXTS][EXT_PARTITION_TYPES - 1] = {
// 8x8 -> 4x4
{ 199, 122, 141, 128, 128, 128, 128 }, // a/l both not split
{ 147, 63, 159, 128, 128, 128, 128 }, // a split, l not split
{ 148, 133, 118, 128, 128, 128, 128 }, // l split, a not split
{ 121, 104, 114, 128, 128, 128, 128 }, // a/l both split
// 16x16 -> 8x8
{ 174, 73, 87, 128, 128, 128, 128 }, // a/l both not split
{ 92, 41, 83, 128, 128, 128, 128 }, // a split, l not split
{ 82, 99, 50, 128, 128, 128, 128 }, // l split, a not split
{ 53, 39, 39, 128, 128, 128, 128 }, // a/l both split
// 32x32 -> 16x16
{ 177, 58, 59, 128, 128, 128, 128 }, // a/l both not split
{ 68, 26, 63, 128, 128, 128, 128 }, // a split, l not split
{ 52, 79, 25, 128, 128, 128, 128 }, // l split, a not split
{ 17, 14, 12, 128, 128, 128, 128 }, // a/l both split
// 64x64 -> 32x32
{ 222, 34, 30, 128, 128, 128, 128 }, // a/l both not split
{ 72, 16, 44, 128, 128, 128, 128 }, // a split, l not split
{ 58, 32, 12, 128, 128, 128, 128 }, // l split, a not split
{ 10, 7, 6, 128, 128, 128, 128 }, // a/l both split
#if CONFIG_EXT_PARTITION
// 128x128 -> 64x64
{ 222, 34, 30, 128, 128, 128, 128 }, // a/l both not split
{ 72, 16, 44, 128, 128, 128, 128 }, // a split, l not split
{ 58, 32, 12, 128, 128, 128, 128 }, // l split, a not split
{ 10, 7, 6, 128, 128, 128, 128 }, // a/l both split
#endif // CONFIG_EXT_PARTITION
#if CONFIG_UNPOISON_PARTITION_CTX
{ 0, 0, 141, 0, 0, 0, 0 }, // 8x8 -> 4x4
{ 0, 0, 87, 0, 0, 0, 0 }, // 16x16 -> 8x8
{ 0, 0, 59, 0, 0, 0, 0 }, // 32x32 -> 16x16
{ 0, 0, 30, 0, 0, 0, 0 }, // 64x64 -> 32x32
#if CONFIG_EXT_PARTITION
{ 0, 0, 30, 0, 0, 0, 0 }, // 128x128 -> 64x64
#endif // CONFIG_EXT_PARTITION
{ 0, 122, 0, 0, 0, 0, 0 }, // 8x8 -> 4x4
{ 0, 73, 0, 0, 0, 0, 0 }, // 16x16 -> 8x8
{ 0, 58, 0, 0, 0, 0, 0 }, // 32x32 -> 16x16
{ 0, 34, 0, 0, 0, 0, 0 }, // 64x64 -> 32x32
#if CONFIG_EXT_PARTITION
{ 0, 34, 0, 0, 0, 0, 0 }, // 128x128 -> 64x64
#endif // CONFIG_EXT_PARTITION
#endif // CONFIG_UNPOISON_PARTITION_CTX
};
#else
static const aom_prob
default_partition_probs[PARTITION_CONTEXTS][PARTITION_TYPES - 1] = {
// 8x8 -> 4x4
{ 199, 122, 141 }, // a/l both not split
{ 147, 63, 159 }, // a split, l not split
{ 148, 133, 118 }, // l split, a not split
{ 121, 104, 114 }, // a/l both split
// 16x16 -> 8x8
{ 174, 73, 87 }, // a/l both not split
{ 92, 41, 83 }, // a split, l not split
{ 82, 99, 50 }, // l split, a not split
{ 53, 39, 39 }, // a/l both split
// 32x32 -> 16x16
{ 177, 58, 59 }, // a/l both not split
{ 68, 26, 63 }, // a split, l not split
{ 52, 79, 25 }, // l split, a not split
{ 17, 14, 12 }, // a/l both split
// 64x64 -> 32x32
{ 222, 34, 30 }, // a/l both not split
{ 72, 16, 44 }, // a split, l not split
{ 58, 32, 12 }, // l split, a not split
{ 10, 7, 6 }, // a/l both split
#if CONFIG_EXT_PARTITION
// 128x128 -> 64x64
{ 222, 34, 30 }, // a/l both not split
{ 72, 16, 44 }, // a split, l not split
{ 58, 32, 12 }, // l split, a not split
{ 10, 7, 6 }, // a/l both split
#endif // CONFIG_EXT_PARTITION
#if CONFIG_UNPOISON_PARTITION_CTX
{ 0, 0, 141 }, // 8x8 -> 4x4
{ 0, 0, 87 }, // 16x16 -> 8x8
{ 0, 0, 59 }, // 32x32 -> 16x16
{ 0, 0, 30 }, // 64x64 -> 32x32
#if CONFIG_EXT_PARTITION
{ 0, 0, 30 }, // 128x128 -> 64x64
#endif // CONFIG_EXT_PARTITION
{ 0, 122, 0 }, // 8x8 -> 4x4
{ 0, 73, 0 }, // 16x16 -> 8x8
{ 0, 58, 0 }, // 32x32 -> 16x16
{ 0, 34, 0 }, // 64x64 -> 32x32
#if CONFIG_EXT_PARTITION
{ 0, 34, 0 }, // 128x128 -> 64x64
#endif // CONFIG_EXT_PARTITION
#endif // CONFIG_UNPOISON_PARTITION_CTX
};
#endif // CONFIG_EXT_PARTITION_TYPES
#if CONFIG_REF_MV
static const aom_prob default_newmv_prob[NEWMV_MODE_CONTEXTS] = {
200, 180, 150, 150, 110, 70, 60,
};
static const aom_prob default_zeromv_prob[ZEROMV_MODE_CONTEXTS] = {
192, 64,
};
static const aom_prob default_refmv_prob[REFMV_MODE_CONTEXTS] = {
220, 220, 200, 200, 180, 128, 30, 220, 30,
};
static const aom_prob default_drl_prob[DRL_MODE_CONTEXTS] = { 128, 160, 180,
128, 160 };
#if CONFIG_EXT_INTER
static const aom_prob default_new2mv_prob = 180;
#endif // CONFIG_EXT_INTER
#endif // CONFIG_REF_MV
static const aom_prob
default_inter_mode_probs[INTER_MODE_CONTEXTS][INTER_MODES - 1] = {
#if CONFIG_EXT_INTER
// TODO(zoeliu): To adjust the initial default probs
{ 2, 173, 34, 173 }, // 0 = both zero mv
{ 7, 145, 85, 145 }, // 1 = one zero mv + one a predicted mv
{ 7, 166, 63, 166 }, // 2 = two predicted mvs
{ 7, 94, 66, 128 }, // 3 = one predicted/zero and one new mv
{ 8, 64, 46, 128 }, // 4 = two new mvs
{ 17, 81, 31, 128 }, // 5 = one intra neighbour + x
{ 25, 29, 30, 96 }, // 6 = two intra neighbours
#else
{ 2, 173, 34 }, // 0 = both zero mv
{ 7, 145, 85 }, // 1 = one zero mv + one a predicted mv
{ 7, 166, 63 }, // 2 = two predicted mvs
{ 7, 94, 66 }, // 3 = one predicted/zero and one new mv
{ 8, 64, 46 }, // 4 = two new mvs
{ 17, 81, 31 }, // 5 = one intra neighbour + x
{ 25, 29, 30 }, // 6 = two intra neighbours
#endif // CONFIG_EXT_INTER
};
#if CONFIG_EXT_INTER
static const aom_prob default_inter_compound_mode_probs
[INTER_MODE_CONTEXTS][INTER_COMPOUND_MODES - 1] = {
{ 2, 173, 68, 192, 64, 192, 128, 180, 180 }, // 0 = both zero mv
{ 7, 145, 160, 192, 64, 192, 128, 180, 180 }, // 1 = 1 zero + 1 predicted
{ 7, 166, 126, 192, 64, 192, 128, 180, 180 }, // 2 = two predicted mvs
{ 7, 94, 132, 192, 64, 192, 128, 180, 180 }, // 3 = 1 pred/zero, 1 new
{ 8, 64, 64, 192, 64, 192, 128, 180, 180 }, // 4 = two new mvs
{ 17, 81, 52, 192, 64, 192, 128, 180, 180 }, // 5 = one intra neighbour
{ 25, 29, 50, 192, 64, 192, 128, 180, 180 }, // 6 = two intra neighbours
};
#if CONFIG_COMPOUND_SEGMENT
static const aom_prob
default_compound_type_probs[BLOCK_SIZES][COMPOUND_TYPES - 1] = {
#if CONFIG_CB4X4
{ 255, 255 }, { 255, 255 }, { 255, 255 },
#endif
{ 208, 200 }, { 208, 200 }, { 208, 200 }, { 208, 200 }, { 208, 200 },
{ 208, 200 }, { 216, 200 }, { 216, 200 }, { 216, 200 }, { 224, 200 },
{ 224, 200 }, { 240, 200 }, { 240, 200 },
#if CONFIG_EXT_PARTITION
{ 255, 200 }, { 255, 200 }, { 255, 200 },
#endif // CONFIG_EXT_PARTITION
};
#else // !CONFIG_COMPOUND_SEGMENT
static const aom_prob
default_compound_type_probs[BLOCK_SIZES][COMPOUND_TYPES - 1] = {
#if CONFIG_CB4X4
{ 208 }, { 208 }, { 208 },
#endif
{ 208 }, { 208 }, { 208 }, { 208 }, { 208 }, { 208 }, { 216 },
{ 216 }, { 216 }, { 224 }, { 224 }, { 240 }, { 240 },
#if CONFIG_EXT_PARTITION
{ 255 }, { 255 }, { 255 },
#endif // CONFIG_EXT_PARTITION
};
#endif // CONFIG_COMPOUND_SEGMENT
static const aom_prob default_interintra_prob[BLOCK_SIZE_GROUPS] = {
208, 208, 208, 208,
};
static const aom_prob
default_interintra_mode_prob[BLOCK_SIZE_GROUPS][INTERINTRA_MODES - 1] = {
{ 65, 32, 18, 144, 162, 194, 41, 51, 98 }, // block_size < 8x8
{ 132, 68, 18, 165, 217, 196, 45, 40, 78 }, // block_size < 16x16
{ 173, 80, 19, 176, 240, 193, 64, 35, 46 }, // block_size < 32x32
{ 221, 135, 38, 194, 248, 121, 96, 85, 29 } // block_size >= 32x32
};
static const aom_prob default_wedge_interintra_prob[BLOCK_SIZES] = {
#if CONFIG_CB4X4
208, 208, 208,
#endif
208, 208, 208, 208, 208, 208, 216, 216, 216, 224, 224, 224, 240,
#if CONFIG_EXT_PARTITION
208, 208, 208
#endif // CONFIG_EXT_PARTITION
};
#endif // CONFIG_EXT_INTER
// Change this section appropriately once warped motion is supported
#if CONFIG_MOTION_VAR && !CONFIG_WARPED_MOTION
const aom_tree_index av1_motion_mode_tree[TREE_SIZE(MOTION_MODES)] = {
-SIMPLE_TRANSLATION, -OBMC_CAUSAL
};
static const aom_prob default_motion_mode_prob[BLOCK_SIZES][MOTION_MODES - 1] =
{
#if CONFIG_CB4X4
{ 255 }, { 255 }, { 255 },
#endif
{ 255 }, { 255 }, { 255 }, { 151 }, { 153 }, { 144 }, { 178 },
{ 165 }, { 160 }, { 207 }, { 195 }, { 168 }, { 244 },
#if CONFIG_EXT_PARTITION
{ 252 }, { 252 }, { 252 },
#endif // CONFIG_EXT_PARTITION
};
#elif !CONFIG_MOTION_VAR && CONFIG_WARPED_MOTION
const aom_tree_index av1_motion_mode_tree[TREE_SIZE(MOTION_MODES)] = {
-SIMPLE_TRANSLATION, -WARPED_CAUSAL
};
static const aom_prob default_motion_mode_prob[BLOCK_SIZES][MOTION_MODES - 1] =
{
#if CONFIG_CB4X4
{ 255 }, { 255 }, { 255 },
#endif
{ 255 }, { 255 }, { 255 }, { 151 }, { 153 }, { 144 }, { 178 },
{ 165 }, { 160 }, { 207 }, { 195 }, { 168 }, { 244 },
#if CONFIG_EXT_PARTITION
{ 252 }, { 252 }, { 252 },
#endif // CONFIG_EXT_PARTITION
};
#elif CONFIG_MOTION_VAR && CONFIG_WARPED_MOTION
const aom_tree_index av1_motion_mode_tree[TREE_SIZE(MOTION_MODES)] = {
-SIMPLE_TRANSLATION, 2, -OBMC_CAUSAL, -WARPED_CAUSAL,
};
static const aom_prob default_motion_mode_prob[BLOCK_SIZES][MOTION_MODES - 1] =
{
#if CONFIG_CB4X4
{ 255, 200 }, { 255, 200 }, { 255, 200 },
#endif
{ 255, 200 }, { 255, 200 }, { 255, 200 }, { 151, 200 }, { 153, 200 },
{ 144, 200 }, { 178, 200 }, { 165, 200 }, { 160, 200 }, { 207, 200 },
{ 195, 200 }, { 168, 200 }, { 244, 200 },
#if CONFIG_EXT_PARTITION
{ 252, 200 }, { 252, 200 }, { 252, 200 },
#endif // CONFIG_EXT_PARTITION
};
// Probability for the case that only 1 additional motion mode is allowed
static const aom_prob default_obmc_prob[BLOCK_SIZES] = {
#if CONFIG_CB4X4
255, 255, 255,
#endif
255, 255, 255, 151, 153, 144, 178, 165, 160, 207, 195, 168, 244,
#if CONFIG_EXT_PARTITION
252, 252, 252,
#endif // CONFIG_EXT_PARTITION
};
#endif
#if CONFIG_DELTA_Q
static const aom_prob default_delta_q_probs[DELTA_Q_PROBS] = { 220, 220, 220 };
#if CONFIG_EC_MULTISYMBOL
static const aom_cdf_prob default_delta_q_cdf[CDF_SIZE(DELTA_Q_PROBS + 1)] = {
28160, 32120, 32677, 32768, 0
};
#endif
#endif
#if CONFIG_EC_MULTISYMBOL
int av1_intra_mode_ind[INTRA_MODES];
int av1_intra_mode_inv[INTRA_MODES];
int av1_inter_mode_ind[INTER_MODES];
int av1_inter_mode_inv[INTER_MODES];
#endif
/* Array indices are identical to previously-existing INTRAMODECONTEXTNODES. */
#if CONFIG_ALT_INTRA
const aom_tree_index av1_intra_mode_tree[TREE_SIZE(INTRA_MODES)] = {
-DC_PRED, 2, /* 0 = DC_NODE */
-TM_PRED, 4, /* 1 = TM_NODE */
-V_PRED, 6, /* 2 = V_NODE */
8, 12, /* 3 = COM_NODE */
-H_PRED, 10, /* 4 = H_NODE */
-D135_PRED, -D117_PRED, /* 5 = D135_NODE */
-D45_PRED, 14, /* 6 = D45_NODE */
-D63_PRED, 16, /* 7 = D63_NODE */
-D153_PRED, 18, /* 8 = D153_NODE */
-D207_PRED, -SMOOTH_PRED, /* 9 = D207_NODE */
};
#else
const aom_tree_index av1_intra_mode_tree[TREE_SIZE(INTRA_MODES)] = {
-DC_PRED, 2, /* 0 = DC_NODE */
-TM_PRED, 4, /* 1 = TM_NODE */
-V_PRED, 6, /* 2 = V_NODE */
8, 12, /* 3 = COM_NODE */
-H_PRED, 10, /* 4 = H_NODE */
-D135_PRED, -D117_PRED, /* 5 = D135_NODE */
-D45_PRED, 14, /* 6 = D45_NODE */
-D63_PRED, 16, /* 7 = D63_NODE */
-D153_PRED, -D207_PRED /* 8 = D153_NODE */
};
#endif // CONFIG_ALT_INTRA
const aom_tree_index av1_inter_mode_tree[TREE_SIZE(INTER_MODES)] = {
-INTER_OFFSET(ZEROMV), 2,
-INTER_OFFSET(NEARESTMV), 4,
#if CONFIG_EXT_INTER
-INTER_OFFSET(NEARMV), 6,
-INTER_OFFSET(NEWMV), -INTER_OFFSET(NEWFROMNEARMV)
#else
-INTER_OFFSET(NEARMV), -INTER_OFFSET(NEWMV)
#endif // CONFIG_EXT_INTER
};
#if CONFIG_EXT_INTER
/* clang-format off */
const aom_tree_index av1_interintra_mode_tree[TREE_SIZE(INTERINTRA_MODES)] = {
-II_DC_PRED, 2, /* 0 = II_DC_NODE */
-II_TM_PRED, 4, /* 1 = II_TM_NODE */
-II_V_PRED, 6, /* 2 = II_V_NODE */
8, 12, /* 3 = II_COM_NODE */
-II_H_PRED, 10, /* 4 = II_H_NODE */
-II_D135_PRED, -II_D117_PRED, /* 5 = II_D135_NODE */
-II_D45_PRED, 14, /* 6 = II_D45_NODE */
-II_D63_PRED, 16, /* 7 = II_D63_NODE */
-II_D153_PRED, -II_D207_PRED /* 8 = II_D153_NODE */
};
const aom_tree_index av1_inter_compound_mode_tree
[TREE_SIZE(INTER_COMPOUND_MODES)] = {
-INTER_COMPOUND_OFFSET(ZERO_ZEROMV), 2,
-INTER_COMPOUND_OFFSET(NEAREST_NEARESTMV), 4,
6, -INTER_COMPOUND_OFFSET(NEW_NEWMV),
8, 12,
-INTER_COMPOUND_OFFSET(NEAR_NEARMV), 10,
-INTER_COMPOUND_OFFSET(NEAREST_NEARMV),
-INTER_COMPOUND_OFFSET(NEAR_NEARESTMV),
14, 16,
-INTER_COMPOUND_OFFSET(NEAREST_NEWMV), -INTER_COMPOUND_OFFSET(NEW_NEARESTMV),
-INTER_COMPOUND_OFFSET(NEAR_NEWMV), -INTER_COMPOUND_OFFSET(NEW_NEARMV)
};
#if CONFIG_COMPOUND_SEGMENT
const aom_tree_index av1_compound_type_tree[TREE_SIZE(COMPOUND_TYPES)] = {
-COMPOUND_AVERAGE, 2, -COMPOUND_WEDGE, -COMPOUND_SEG
};
#else // !CONFIG_COMPOUND_SEGMENT
const aom_tree_index av1_compound_type_tree[TREE_SIZE(COMPOUND_TYPES)] = {
-COMPOUND_AVERAGE, -COMPOUND_WEDGE
};
#endif // CONFIG_COMPOUND_SEGMENT
/* clang-format on */
#endif // CONFIG_EXT_INTER
const aom_tree_index av1_partition_tree[TREE_SIZE(PARTITION_TYPES)] = {
-PARTITION_NONE, 2, -PARTITION_HORZ, 4, -PARTITION_VERT, -PARTITION_SPLIT
};
#if CONFIG_EXT_PARTITION_TYPES
/* clang-format off */
const aom_tree_index av1_ext_partition_tree[TREE_SIZE(EXT_PARTITION_TYPES)] = {
-PARTITION_NONE, 2,
6, 4,
8, -PARTITION_SPLIT,
-PARTITION_HORZ, 10,
-PARTITION_VERT, 12,
-PARTITION_HORZ_A, -PARTITION_HORZ_B,
-PARTITION_VERT_A, -PARTITION_VERT_B
};
/* clang-format on */
#endif // CONFIG_EXT_PARTITION_TYPES
static const aom_prob default_intra_inter_p[INTRA_INTER_CONTEXTS] = {
9, 102, 187, 225
};
static const aom_prob default_comp_inter_p[COMP_INTER_CONTEXTS] = {
239, 183, 119, 96, 41
};
#if CONFIG_EXT_REFS
static const aom_prob default_comp_ref_p[REF_CONTEXTS][FWD_REFS - 1] = {
// TODO(zoeliu): To adjust the initial prob values.
{ 33, 16, 16 },
{ 77, 74, 74 },
{ 142, 142, 142 },
{ 172, 170, 170 },
{ 238, 247, 247 }
};
static const aom_prob default_comp_bwdref_p[REF_CONTEXTS][BWD_REFS - 1] = {
{ 16 }, { 74 }, { 142 }, { 170 }, { 247 }
};
#else
static const aom_prob default_comp_ref_p[REF_CONTEXTS][COMP_REFS - 1] = {
{ 50 }, { 126 }, { 123 }, { 221 }, { 226 }
};
#endif // CONFIG_EXT_REFS
static const aom_prob default_single_ref_p[REF_CONTEXTS][SINGLE_REFS - 1] = {
#if CONFIG_EXT_REFS
{ 33, 16, 16, 16, 16 },
{ 77, 74, 74, 74, 74 },
{ 142, 142, 142, 142, 142 },
{ 172, 170, 170, 170, 170 },
{ 238, 247, 247, 247, 247 }
#else
{ 33, 16 }, { 77, 74 }, { 142, 142 }, { 172, 170 }, { 238, 247 }
#endif // CONFIG_EXT_REFS
};
#if CONFIG_PALETTE
// Tree to code palette size (number of colors in a palette) and the
// corresponding probabilities for Y and UV planes.
const aom_tree_index av1_palette_size_tree[TREE_SIZE(PALETTE_SIZES)] = {
-TWO_COLORS, 2, -THREE_COLORS, 4, -FOUR_COLORS, 6,
-FIVE_COLORS, 8, -SIX_COLORS, 10, -SEVEN_COLORS, -EIGHT_COLORS,
};
// TODO(huisu): tune these probs
const aom_prob
av1_default_palette_y_size_prob[PALETTE_BLOCK_SIZES][PALETTE_SIZES - 1] = {
{ 96, 89, 100, 64, 77, 130 }, { 22, 15, 44, 16, 34, 82 },
{ 30, 19, 57, 18, 38, 86 }, { 94, 36, 104, 23, 43, 92 },
{ 116, 76, 107, 46, 65, 105 }, { 112, 82, 94, 40, 70, 112 },
{ 147, 124, 123, 58, 69, 103 }, { 180, 113, 136, 49, 45, 114 },
{ 107, 70, 87, 49, 154, 156 }, { 98, 105, 142, 63, 64, 152 },
#if CONFIG_EXT_PARTITION
{ 98, 105, 142, 63, 64, 152 }, { 98, 105, 142, 63, 64, 152 },
{ 98, 105, 142, 63, 64, 152 },
#endif // CONFIG_EXT_PARTITION
};
const aom_prob
av1_default_palette_uv_size_prob[PALETTE_BLOCK_SIZES][PALETTE_SIZES - 1] = {
{ 160, 196, 228, 213, 175, 230 }, { 87, 148, 208, 141, 166, 163 },
{ 72, 151, 204, 139, 155, 161 }, { 78, 135, 171, 104, 120, 173 },
{ 59, 92, 131, 78, 92, 142 }, { 75, 118, 149, 84, 90, 128 },
{ 89, 87, 92, 66, 66, 128 }, { 67, 53, 54, 55, 66, 93 },
{ 120, 130, 83, 171, 75, 214 }, { 72, 55, 66, 68, 79, 107 },
#if CONFIG_EXT_PARTITION
{ 72, 55, 66, 68, 79, 107 }, { 72, 55, 66, 68, 79, 107 },
{ 72, 55, 66, 68, 79, 107 },
#endif // CONFIG_EXT_PARTITION
};
// When palette mode is enabled, following probability tables indicate the
// probabilities to code the "is_palette" bit (i.e. the bit that indicates
// if this block uses palette mode or DC_PRED mode).
const aom_prob av1_default_palette_y_mode_prob
[PALETTE_BLOCK_SIZES][PALETTE_Y_MODE_CONTEXTS] = {
{ 240, 180, 100 }, { 240, 180, 100 }, { 240, 180, 100 },
{ 240, 180, 100 }, { 240, 180, 100 }, { 240, 180, 100 },
{ 240, 180, 100 }, { 240, 180, 100 }, { 240, 180, 100 },
{ 240, 180, 100 },
#if CONFIG_EXT_PARTITION
{ 240, 180, 100 }, { 240, 180, 100 }, { 240, 180, 100 },
#endif // CONFIG_EXT_PARTITION
};
const aom_prob av1_default_palette_uv_mode_prob[PALETTE_UV_MODE_CONTEXTS] = {
253, 229
};
// Trees to code palette color indices (for various palette sizes), and the
// corresponding probability tables for Y and UV planes.
const aom_tree_index
av1_palette_color_index_tree[PALETTE_SIZES][TREE_SIZE(PALETTE_COLORS)] = {
{ // 2 colors
-PALETTE_COLOR_ONE, -PALETTE_COLOR_TWO },
{ // 3 colors
-PALETTE_COLOR_ONE, 2, -PALETTE_COLOR_TWO, -PALETTE_COLOR_THREE },
{ // 4 colors
-PALETTE_COLOR_ONE, 2, -PALETTE_COLOR_TWO, 4, -PALETTE_COLOR_THREE,
-PALETTE_COLOR_FOUR },
{ // 5 colors
-PALETTE_COLOR_ONE, 2, -PALETTE_COLOR_TWO, 4, -PALETTE_COLOR_THREE, 6,
-PALETTE_COLOR_FOUR, -PALETTE_COLOR_FIVE },
{ // 6 colors
-PALETTE_COLOR_ONE, 2, -PALETTE_COLOR_TWO, 4, -PALETTE_COLOR_THREE, 6,
-PALETTE_COLOR_FOUR, 8, -PALETTE_COLOR_FIVE, -PALETTE_COLOR_SIX },
{ // 7 colors
-PALETTE_COLOR_ONE, 2, -PALETTE_COLOR_TWO, 4, -PALETTE_COLOR_THREE, 6,
-PALETTE_COLOR_FOUR, 8, -PALETTE_COLOR_FIVE, 10, -PALETTE_COLOR_SIX,
-PALETTE_COLOR_SEVEN },
{ // 8 colors
-PALETTE_COLOR_ONE, 2, -PALETTE_COLOR_TWO, 4, -PALETTE_COLOR_THREE, 6,
-PALETTE_COLOR_FOUR, 8, -PALETTE_COLOR_FIVE, 10, -PALETTE_COLOR_SIX, 12,
-PALETTE_COLOR_SEVEN, -PALETTE_COLOR_EIGHT },
};
// Note: Has to be non-zero to avoid any asserts triggering.
#define UNUSED_PROB 128
const aom_prob av1_default_palette_y_color_index_prob
[PALETTE_SIZES][PALETTE_COLOR_INDEX_CONTEXTS][PALETTE_COLORS - 1] = {
{
// 2 colors
{ 231, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB, UNUSED_PROB },
{ UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB, UNUSED_PROB },
{ 69, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 224, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB, UNUSED_PROB },
{ 249, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB, UNUSED_PROB },
},
{
// 3 colors
{ 219, 124, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 91, 191, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 34, 237, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 184, 118, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 252, 124, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
},
{
// 4 colors
{ 204, 87, 97, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 74, 144, 129, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 52, 191, 134, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 151, 85, 147, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 248, 60, 115, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
},
{
// 5 colors
{ 218, 69, 62, 106, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 76, 143, 89, 127, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 21, 233, 94, 131, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 172, 72, 89, 112, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 253, 66, 65, 128, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
},
{
// 6 colors
{ 190, 60, 47, 54, 74, UNUSED_PROB, UNUSED_PROB },
{ 62, 106, 51, 95, 110, UNUSED_PROB, UNUSED_PROB },
{ 52, 180, 69, 72, 107, UNUSED_PROB, UNUSED_PROB },
{ 156, 83, 72, 83, 101, UNUSED_PROB, UNUSED_PROB },
{ 245, 45, 37, 52, 91, UNUSED_PROB, UNUSED_PROB },
},
{
// 7 colors
{ 206, 56, 42, 42, 53, 85, UNUSED_PROB },
{ 70, 100, 45, 68, 77, 94, UNUSED_PROB },
{ 57, 169, 51, 62, 74, 119, UNUSED_PROB },
{ 172, 76, 71, 40, 59, 76, UNUSED_PROB },
{ 248, 47, 36, 53, 61, 110, UNUSED_PROB },
},
{
// 8 colors
{ 208, 52, 38, 34, 34, 44, 66 },
{ 52, 107, 34, 73, 69, 82, 87 },
{ 28, 208, 53, 43, 62, 70, 102 },
{ 184, 64, 45, 37, 37, 69, 105 },
{ 251, 18, 31, 45, 47, 61, 104 },
},
};
const aom_prob av1_default_palette_uv_color_index_prob
[PALETTE_SIZES][PALETTE_COLOR_INDEX_CONTEXTS][PALETTE_COLORS - 1] = {
{
// 2 colors
{ 233, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB, UNUSED_PROB },
{ UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB, UNUSED_PROB },
{ 69, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 240, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB, UNUSED_PROB },
{ 248, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB, UNUSED_PROB },
},
{
// 3 colors
{ 216, 128, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 110, 171, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 40, 239, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 191, 104, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
{ 247, 134, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB,
UNUSED_PROB },
},
{
// 4 colors
{ 202, 89, 132, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 90, 132, 136, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 63, 195, 149, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 152, 84, 152, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 241, 87, 136, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
},
{
// 5 colors
{ 209, 54, 82, 134, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 94, 173, 180, 93, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 10, 251, 127, 84, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 183, 20, 150, 47, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
{ 252, 73, 111, 150, UNUSED_PROB, UNUSED_PROB, UNUSED_PROB },
},
{
// 6 colors
{ 192, 67, 59, 46, 184, UNUSED_PROB, UNUSED_PROB },
{ 59, 92, 61, 100, 130, UNUSED_PROB, UNUSED_PROB },
{ 49, 162, 68, 91, 150, UNUSED_PROB, UNUSED_PROB },
{ 133, 29, 36, 153, 101, UNUSED_PROB, UNUSED_PROB },
{ 247, 71, 44, 90, 129, UNUSED_PROB, UNUSED_PROB },
},
{
// 7 colors
{ 182, 62, 80, 78, 46, 116, UNUSED_PROB },
{ 59, 62, 39, 81, 65, 99, UNUSED_PROB },
{ 54, 177, 48, 58, 93, 104, UNUSED_PROB },
{ 137, 79, 54, 55, 44, 134, UNUSED_PROB },
{ 239, 82, 79, 44, 69, 71, UNUSED_PROB },
},
{
// 8 colors
{ 172, 53, 27, 67, 30, 79, 113 },
{ 63, 57, 45, 81, 62, 35, 47 },
{ 51, 200, 36, 47, 82, 165, 129 },
{ 141, 100, 47, 29, 33, 37, 129 },
{ 236, 42, 50, 91, 24, 154, 65 },
},
};
#undef UNUSED_PROB
#define MAX_COLOR_CONTEXT_HASH 8
// Negative values are invalid
static const int palette_color_index_context_lookup[MAX_COLOR_CONTEXT_HASH +
1] = { -1, -1, 0, -1, -1,
4, 3, 2, 1 };
#endif // CONFIG_PALETTE
// The transform size is coded as an offset to the smallest transform
// block size.
const aom_tree_index av1_tx_size_tree[MAX_TX_DEPTH][TREE_SIZE(TX_SIZES)] = {
{
// Max tx_size is 8X8
-0, -1,
},
{
// Max tx_size is 16X16
-0, 2, -1, -2,
},
{
// Max tx_size is 32X32
-0, 2, -1, 4, -2, -3,
},
#if CONFIG_TX64X64
{
// Max tx_size is 64X64
-0, 2, -1, 4, -2, 6, -3, -4,
},
#endif // CONFIG_TX64X64
};
static const aom_prob default_tx_size_prob[MAX_TX_DEPTH][TX_SIZE_CONTEXTS]
[MAX_TX_DEPTH] = {
{
// Max tx_size is 8X8
{ 100 },
{ 66 },
},
{
// Max tx_size is 16X16
{ 20, 152 },
{ 15, 101 },
},
{
// Max tx_size is 32X32
{ 3, 136, 37 },
{ 5, 52, 13 },
},
#if CONFIG_TX64X64
{
// Max tx_size is 64X64
{ 1, 64, 136, 127 },
{ 1, 32, 52, 67 },
},
#endif // CONFIG_TX64X64
};
#if CONFIG_LOOP_RESTORATION
const aom_tree_index
av1_switchable_restore_tree[TREE_SIZE(RESTORE_SWITCHABLE_TYPES)] = {
-RESTORE_NONE, 2, -RESTORE_WIENER, -RESTORE_SGRPROJ,
};
static const aom_prob
default_switchable_restore_prob[RESTORE_SWITCHABLE_TYPES - 1] = {
32, 128,
};
#endif // CONFIG_LOOP_RESTORATION
#if CONFIG_PALETTE
#define NUM_PALETTE_NEIGHBORS 3 // left, top-left and top.
int av1_get_palette_color_index_context(const uint8_t *color_map, int stride,
int r, int c, int palette_size,
uint8_t *color_order, int *color_idx) {
int i;
// The +10 below should not be needed. But we get a warning "array subscript
// is above array bounds [-Werror=array-bounds]" without it, possibly due to
// this (or similar) bug: https://gcc.gnu.org/bugzilla/show_bug.cgi?id=59124
int scores[PALETTE_MAX_SIZE + 10];
const int weights[NUM_PALETTE_NEIGHBORS] = { 2, 1, 2 };
const int hash_multipliers[NUM_PALETTE_NEIGHBORS] = { 1, 2, 2 };
int color_index_ctx_hash;
int color_index_ctx;
int color_neighbors[NUM_PALETTE_NEIGHBORS];
int inverse_color_order[PALETTE_MAX_SIZE];
assert(palette_size <= PALETTE_MAX_SIZE);
assert(r > 0 || c > 0);
// Get color indices of neighbors.
color_neighbors[0] = (c - 1 >= 0) ? color_map[r * stride + c - 1] : -1;
color_neighbors[1] =
(c - 1 >= 0 && r - 1 >= 0) ? color_map[(r - 1) * stride + c - 1] : -1;
color_neighbors[2] = (r - 1 >= 0) ? color_map[(r - 1) * stride + c] : -1;
for (i = 0; i < PALETTE_MAX_SIZE; ++i) {
color_order[i] = i;
inverse_color_order[i] = i;
}
memset(scores, 0, PALETTE_MAX_SIZE * sizeof(scores[0]));
for (i = 0; i < NUM_PALETTE_NEIGHBORS; ++i) {
if (color_neighbors[i] >= 0) {
scores[color_neighbors[i]] += weights[i];
}
}
// Get the top NUM_PALETTE_NEIGHBORS scores (sorted from large to small).
for (i = 0; i < NUM_PALETTE_NEIGHBORS; ++i) {
int max = scores[i];
int max_idx = i;
int j;
for (j = i + 1; j < palette_size; ++j) {
if (scores[j] > max) {
max = scores[j];
max_idx = j;
}
}
if (max_idx != i) {
// Move the score at index 'max_idx' to index 'i', and shift the scores
// from 'i' to 'max_idx - 1' by 1.
const int max_score = scores[max_idx];
const uint8_t max_color_order = color_order[max_idx];
int k;
for (k = max_idx; k > i; --k) {
scores[k] = scores[k - 1];
color_order[k] = color_order[k - 1];
inverse_color_order[color_order[k]] = k;
}
scores[i] = max_score;
color_order[i] = max_color_order;
inverse_color_order[color_order[i]] = i;
}
}
// Get hash value of context.
color_index_ctx_hash = 0;
for (i = 0; i < NUM_PALETTE_NEIGHBORS; ++i) {
color_index_ctx_hash += scores[i] * hash_multipliers[i];
}
assert(color_index_ctx_hash > 0);
assert(color_index_ctx_hash <= MAX_COLOR_CONTEXT_HASH);
// Lookup context from hash.
color_index_ctx = palette_color_index_context_lookup[color_index_ctx_hash];
assert(color_index_ctx >= 0);
assert(color_index_ctx < PALETTE_COLOR_INDEX_CONTEXTS);
if (color_idx != NULL) {
*color_idx = inverse_color_order[color_map[r * stride + c]];
}
return color_index_ctx;
}
#undef NUM_PALETTE_NEIGHBORS
#undef MAX_COLOR_CONTEXT_HASH
#endif // CONFIG_PALETTE
#if CONFIG_VAR_TX
static const aom_prob default_txfm_partition_probs[TXFM_PARTITION_CONTEXTS] = {
250, 231, 212, 241, 166, 66, 241, 230, 135, 243, 154, 64, 248, 161, 63, 128,
};
#endif
static const aom_prob default_skip_probs[SKIP_CONTEXTS] = { 192, 128, 64 };
#if CONFIG_DUAL_FILTER
static const aom_prob default_switchable_interp_prob
[SWITCHABLE_FILTER_CONTEXTS][SWITCHABLE_FILTERS - 1] = {
{ 235, 192, 128 }, { 36, 243, 48 }, { 34, 16, 128 },
{ 34, 16, 128 }, { 149, 160, 128 }, { 235, 192, 128 },
{ 36, 243, 48 }, { 34, 16, 128 }, { 34, 16, 128 },
{ 149, 160, 128 }, { 235, 192, 128 }, { 36, 243, 48 },
{ 34, 16, 128 }, { 34, 16, 128 }, { 149, 160, 128 },
{ 235, 192, 128 }, { 36, 243, 48 }, { 34, 16, 128 },
{ 34, 16, 128 }, { 149, 160, 128 },
};
#else // CONFIG_DUAL_FILTER
static const aom_prob default_switchable_interp_prob[SWITCHABLE_FILTER_CONTEXTS]
[SWITCHABLE_FILTERS - 1] = {
{ 235, 162 },
{ 36, 255 },
{ 34, 3 },
{ 149, 144 },
};
#endif // CONFIG_DUAL_FILTER
#if CONFIG_EXT_TX
/* clang-format off */
const aom_tree_index av1_ext_tx_inter_tree[EXT_TX_SETS_INTER]
[TREE_SIZE(TX_TYPES)] = {
{ // ToDo(yaowu): remove used entry 0.
0
}, {
-IDTX, 2,
4, 14,
6, 8,
-V_DCT, -H_DCT,
10, 12,
-V_ADST, -H_ADST,
-V_FLIPADST, -H_FLIPADST,
-DCT_DCT, 16,
18, 24,
20, 22,
-ADST_DCT, -DCT_ADST,
-FLIPADST_DCT, -DCT_FLIPADST,
26, 28,
-ADST_ADST, -FLIPADST_FLIPADST,
-ADST_FLIPADST, -FLIPADST_ADST
}, {
-IDTX, 2,
4, 6,
-V_DCT, -H_DCT,
-DCT_DCT, 8,
10, 16,
12, 14,
-ADST_DCT, -DCT_ADST,
-FLIPADST_DCT, -DCT_FLIPADST,
18, 20,
-ADST_ADST, -FLIPADST_FLIPADST,
-ADST_FLIPADST, -FLIPADST_ADST
}, {
-IDTX, -DCT_DCT,
}
};
const aom_tree_index av1_ext_tx_intra_tree[EXT_TX_SETS_INTRA]
[TREE_SIZE(TX_TYPES)] = {
{ // ToDo(yaowu): remove unused entry 0.
0
}, {
-IDTX, 2,
-DCT_DCT, 4,
6, 8,
-V_DCT, -H_DCT,
-ADST_ADST, 10,
-ADST_DCT, -DCT_ADST,
}, {
-IDTX, 2,
-DCT_DCT, 4,
-ADST_ADST, 6,
-ADST_DCT, -DCT_ADST,
}
};
/* clang-format on */
static const aom_prob
default_inter_ext_tx_prob[EXT_TX_SETS_INTER][EXT_TX_SIZES][TX_TYPES - 1] = {
{
// ToDo(yaowu): remove unused entry 0.
#if CONFIG_CB4X4
{ 0 },
#endif
{ 0 },
{ 0 },
{ 0 },
{ 0 },
},
{
#if CONFIG_CB4X4
{ 0 },
#endif
{ 10, 24, 30, 128, 128, 128, 128, 112, 160, 128, 128, 128, 128, 128,
128 },
{ 10, 24, 30, 128, 128, 128, 128, 112, 160, 128, 128, 128, 128, 128,
128 },
{ 10, 24, 30, 128, 128, 128, 128, 112, 160, 128, 128, 128, 128, 128,
128 },
{ 10, 24, 30, 128, 128, 128, 128, 112, 160, 128, 128, 128, 128, 128,
128 },
},
{
#if CONFIG_CB4X4
{ 0 },
#endif
{ 10, 30, 128, 112, 160, 128, 128, 128, 128, 128, 128 },
{ 10, 30, 128, 112, 160, 128, 128, 128, 128, 128, 128 },
{ 10, 30, 128, 112, 160, 128, 128, 128, 128, 128, 128 },
{ 10, 30, 128, 112, 160, 128, 128, 128, 128, 128, 128 },
},
{
#if CONFIG_CB4X4
{ 0 },
#endif
{ 12 },
{ 12 },
{ 12 },
{ 12 },
}
};
// TODO(urvang): 3rd context should be tx_type instead of intra mode just like
// the baseline.
static const aom_prob
default_intra_ext_tx_prob[EXT_TX_SETS_INTRA][EXT_TX_SIZES][INTRA_MODES]
[TX_TYPES - 1] = {
{
// ToDo(yaowu): remove unused entry 0.
#if CONFIG_CB4X4
{
{ 0 },
},
#endif
{
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
#if CONFIG_ALT_INTRA
{ 0 },
#endif // CONFIG_ALT_INTRA
},
{
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
#if CONFIG_ALT_INTRA
{ 0 },
#endif // CONFIG_ALT_INTRA
},
{
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
#if CONFIG_ALT_INTRA
{ 0 },
#endif // CONFIG_ALT_INTRA
},
{
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
{ 0 },
#if CONFIG_ALT_INTRA
{ 0 },
#endif // CONFIG_ALT_INTRA
},
},
{
#if CONFIG_CB4X4
{
{ 0 },
},
#endif
{
{ 8, 224, 32, 128, 64, 128 },
{ 10, 32, 32, 128, 16, 192 },
{ 10, 32, 32, 128, 16, 64 },
{ 9, 200, 32, 128, 64, 128 },
{ 8, 8, 32, 128, 224, 128 },
{ 10, 32, 32, 128, 16, 192 },
{ 10, 32, 32, 128, 16, 64 },
{ 10, 23, 32, 128, 80, 176 },
{ 10, 23, 32, 128, 80, 176 },
{ 10, 32, 32, 128, 16, 64 },
#if CONFIG_ALT_INTRA
{ 10, 32, 32, 128, 16, 64 },
#endif // CONFIG_ALT_INTRA
},
{
{ 8, 224, 32, 128, 64, 128 },
{ 10, 32, 32, 128, 16, 192 },
{ 10, 32, 32, 128, 16, 64 },
{ 9, 200, 32, 128, 64, 128 },
{ 8, 8, 32, 128, 224, 128 },
{ 10, 32, 32, 128, 16, 192 },
{ 10, 32, 32, 128, 16, 64 },
{ 10, 23, 32, 128, 80, 176 },
{ 10, 23, 32, 128, 80, 176 },
{ 10, 32, 32, 128, 16, 64 },
#if CONFIG_ALT_INTRA
{ 10, 32, 32, 128, 16, 64 },
#endif // CONFIG_ALT_INTRA
},
{
{ 8, 224, 32, 128, 64, 128 },
{ 10, 32, 32, 128, 16, 192 },
{ 10, 32, 32, 128, 16, 64 },
{ 9, 200, 32, 128, 64, 128 },
{ 8, 8, 32, 128, 224, 128 },
{ 10, 32, 32, 128, 16, 192 },
{ 10, 32, 32, 128, 16, 64 },
{ 10, 23, 32, 128, 80, 176 },
{ 10, 23, 32, 128, 80, 176 },
{ 10, 32, 32, 128, 16, 64 },
#if CONFIG_ALT_INTRA
{ 10, 32, 32, 128, 16, 64 },
#endif // CONFIG_ALT_INTRA
},
{
{ 8, 224, 32, 128, 64, 128 },
{ 10, 32, 32, 128, 16, 192 },
{ 10, 32, 32, 128, 16, 64 },
{ 9, 200, 32, 128, 64, 128 },
{ 8, 8, 32, 128, 224, 128 },
{ 10, 32, 32, 128, 16, 192 },
{ 10, 32, 32, 128, 16, 64 },
{ 10, 23, 32, 128, 80, 176 },
{ 10, 23, 32, 128, 80, 176 },
{ 10, 32, 32, 128, 16, 64 },
#if CONFIG_ALT_INTRA
{ 10, 32, 32, 128, 16, 64 },
#endif // CONFIG_ALT_INTRA
},
},
{
#if CONFIG_CB4X4
{
{ 0 },
},
#endif
{
{ 8, 224, 64, 128 },
{ 10, 32, 16, 192 },
{ 10, 32, 16, 64 },
{ 9, 200, 64, 128 },
{ 8, 8, 224, 128 },
{ 10, 32, 16, 192 },
{ 10, 32, 16, 64 },
{ 10, 23, 80, 176 },
{ 10, 23, 80, 176 },
{ 10, 32, 16, 64 },
#if CONFIG_ALT_INTRA
{ 10, 32, 16, 64 },
#endif // CONFIG_ALT_INTRA
},
{
{ 8, 224, 64, 128 },
{ 10, 32, 16, 192 },
{ 10, 32, 16, 64 },
{ 9, 200, 64, 128 },
{ 8, 8, 224, 128 },
{ 10, 32, 16, 192 },
{ 10, 32, 16, 64 },
{ 10, 23, 80, 176 },
{ 10, 23, 80, 176 },
{ 10, 32, 16, 64 },
#if CONFIG_ALT_INTRA
{ 10, 32, 16, 64 },
#endif // CONFIG_ALT_INTRA
},
{
{ 8, 224, 64, 128 },
{ 10, 32, 16, 192 },
{ 10, 32, 16, 64 },
{ 9, 200, 64, 128 },
{ 8, 8, 224, 128 },
{ 10, 32, 16, 192 },
{ 10, 32, 16, 64 },
{ 10, 23, 80, 176 },
{ 10, 23, 80, 176 },
{ 10, 32, 16, 64 },
#if CONFIG_ALT_INTRA
{ 10, 32, 16, 64 },
#endif // CONFIG_ALT_INTRA
},
{
{ 8, 224, 64, 128 },
{ 10, 32, 16, 192 },
{ 10, 32, 16, 64 },
{ 9, 200, 64, 128 },
{ 8, 8, 224, 128 },
{ 10, 32, 16, 192 },
{ 10, 32, 16, 64 },
{ 10, 23, 80, 176 },
{ 10, 23, 80, 176 },
{ 10, 32, 16, 64 },
#if CONFIG_ALT_INTRA
{ 10, 32, 16, 64 },
#endif // CONFIG_ALT_INTRA
},
},
};
#else
/* clang-format off */
const aom_tree_index av1_ext_tx_tree[TREE_SIZE(TX_TYPES)] = {
-DCT_DCT, 2,
-ADST_ADST, 4,
-ADST_DCT, -DCT_ADST
};
/* clang-format on */
int av1_ext_tx_ind[TX_TYPES];
int av1_ext_tx_inv[TX_TYPES];
static const aom_prob
default_intra_ext_tx_prob[EXT_TX_SIZES][TX_TYPES][TX_TYPES - 1] = {
#if CONFIG_CB4X4
{ { 240, 85, 128 }, { 4, 1, 248 }, { 4, 1, 8 }, { 4, 248, 128 } },
#endif
{ { 240, 85, 128 }, { 4, 1, 248 }, { 4, 1, 8 }, { 4, 248, 128 } },
{ { 244, 85, 128 }, { 8, 2, 248 }, { 8, 2, 8 }, { 8, 248, 128 } },
{ { 248, 85, 128 }, { 16, 4, 248 }, { 16, 4, 8 }, { 16, 248, 128 } },
};
static const aom_prob default_inter_ext_tx_prob[EXT_TX_SIZES][TX_TYPES - 1] = {
#if CONFIG_CB4X4
{ 160, 85, 128 },
#endif
{ 160, 85, 128 },
{ 176, 85, 128 },
{ 192, 85, 128 },
};
#endif // CONFIG_EXT_TX
#if CONFIG_EXT_INTRA
#if CONFIG_INTRA_INTERP
static const aom_prob
default_intra_filter_probs[INTRA_FILTERS + 1][INTRA_FILTERS - 1] = {
{ 98, 63, 60 }, { 98, 82, 80 }, { 94, 65, 103 },
{ 49, 25, 24 }, { 72, 38, 50 },
};
const aom_tree_index av1_intra_filter_tree[TREE_SIZE(INTRA_FILTERS)] = {
-INTRA_FILTER_LINEAR, 2, -INTRA_FILTER_8TAP, 4, -INTRA_FILTER_8TAP_SHARP,
-INTRA_FILTER_8TAP_SMOOTH,
};
#endif // CONFIG_INTRA_INTERP
#endif // CONFIG_EXT_INTRA
#if CONFIG_FILTER_INTRA
static const aom_prob default_filter_intra_probs[2] = { 230, 230 };
#endif // CONFIG_FILTER_INTRA
#if CONFIG_SUPERTX
static const aom_prob
default_supertx_prob[PARTITION_SUPERTX_CONTEXTS][TX_SIZES] = {
#if CONFIG_CB4X4
#if CONFIG_TX64X64
{ 1, 1, 160, 160, 170, 180 }, { 1, 1, 200, 200, 210, 220 },
#else
{ 1, 1, 160, 160, 170 }, { 1, 1, 200, 200, 210 },
#endif // CONFIG_TX64X64
#else
#if CONFIG_TX64X64
{ 1, 160, 160, 170, 180 }, { 1, 200, 200, 210, 220 },
#else
{ 1, 160, 160, 170 }, { 1, 200, 200, 210 },
#endif // CONFIG_CB4X4
#endif // CONFIG_TX64X64
};
#endif // CONFIG_SUPERTX
// FIXME(someone) need real defaults here
static const aom_prob default_segment_tree_probs[SEG_TREE_PROBS] = {
128, 128, 128, 128, 128, 128, 128
};
// clang-format off
static const aom_prob default_segment_pred_probs[PREDICTION_PROBS] = {
128, 128, 128
};
// clang-format on
#if CONFIG_EC_MULTISYMBOL
static const aom_cdf_prob
default_switchable_interp_cdf[SWITCHABLE_FILTER_CONTEXTS]
[CDF_SIZE(SWITCHABLE_FILTERS)] = {
{ 30080, 31781, 32768, 0 },
{ 4608, 32658, 32768, 0 },
{ 4352, 4685, 32768, 0 },
{ 19072, 26776, 32768, 0 },
};
static const aom_cdf_prob default_seg_tree_cdf[CDF_SIZE(MAX_SEGMENTS)] = {
4096, 8192, 12288, 16384, 20480, 24576, 28672, 32768, 0
};
static const aom_cdf_prob
default_tx_size_cdf[MAX_TX_DEPTH][TX_SIZE_CONTEXTS][CDF_SIZE(MAX_TX_DEPTH +
1)] = {
{ { 12800, 32768, 0 }, { 8448, 32768, 0 } },
{ { 2560, 20496, 32768, 0 }, { 1920, 14091, 32768, 0 } },
{ { 384, 17588, 19782, 32768, 0 }, { 640, 7166, 8466, 32768, 0 } },
#if CONFIG_TX64X64
{ { 128, 8288, 21293, 26986, 32768, 0 },
{ 128, 4208, 10009, 15965, 32768, 0 } },
#endif
};
#if CONFIG_ALT_INTRA
static const aom_cdf_prob
default_if_y_mode_cdf[BLOCK_SIZE_GROUPS][CDF_SIZE(INTRA_MODES)] = {
{ 11264, 12608, 16309, 21086, 23297, 24860, 27022, 28099, 29631, 31126,
32768, 0 },
{ 9600, 11953, 16100, 20922, 22756, 23913, 25435, 26724, 28046, 29927,
32768, 0 },
{ 9344, 11540, 16515, 21763, 23078, 23816, 24725, 25856, 26720, 28208,
32768, 0 },
{ 12288, 14448, 18026, 23346, 23833, 24188, 24724, 25415, 25817, 26876,
32768, 0 },
};
static const aom_cdf_prob
default_uv_mode_cdf[INTRA_MODES][CDF_SIZE(INTRA_MODES)] = {
{ 25472, 25558, 27783, 30779, 30988, 31269, 31492, 31741, 32014, 32420,
32768, 0 },
{ 2176, 2415, 28381, 29574, 29832, 30712, 30881, 31662, 31761, 31922,
32768, 0 },
{ 3328, 3443, 4016, 31099, 31272, 31420, 31504, 31608, 31916, 32598,
32768, 0 },
{ 23424, 23534, 25915, 27831, 28058, 28431, 30142, 31209, 31459, 32369,
32768, 0 },
{ 22784, 22862, 24255, 26287, 28490, 29509, 29776, 30115, 31203, 31674,
32768, 0 },
{ 19712, 19865, 23141, 24428, 25731, 31377, 31622, 32047, 32458, 32767,
32768, 0 },
{ 21376, 21421, 22130, 27688, 28485, 28779, 28935, 29085, 31962, 32450,
32768, 0 },
{ 19712, 19814, 20725, 28510, 28814, 29099, 29457, 29729, 30133, 32408,
32768, 0 },
{ 19584, 19790, 23643, 25501, 25913, 26673, 27578, 30923, 31255, 31870,
32768, 0 },
{ 20864, 21004, 24129, 26308, 27062, 27065, 27488, 28045, 28506, 29272,
32768, 0 },
{ 23680, 23929, 27831, 30446, 30598, 31129, 31244, 31655, 31868, 32234,
32768, 0 },
};
#else
static const aom_cdf_prob default_if_y_mode_cdf[BLOCK_SIZE_GROUPS][CDF_SIZE(
INTRA_MODES)] = {
{ 8320, 11376, 12880, 19959, 23072, 24067, 25461, 26917, 29157, 32768, 0 },
{ 16896, 21112, 21932, 27852, 28667, 28916, 29593, 30089, 30905, 32768, 0 },
{ 22144, 25464, 26006, 30364, 30583, 30655, 31183, 31400, 31646, 32768, 0 },
{ 28288, 30650, 30964, 32288, 32308, 32331, 32495, 32586, 32607, 32768, 0 },
};
static const aom_cdf_prob default_uv_mode_cdf[INTRA_MODES][CDF_SIZE(
INTRA_MODES)] = {
{ 15360, 15836, 20863, 27513, 28269, 29048, 29455, 30154, 31206, 32768, 0 },
{ 6144, 7392, 22657, 25981, 26965, 28779, 29309, 30890, 31763, 32768, 0 },
{ 8576, 9143, 11450, 27575, 28108, 28438, 28658, 28995, 30410, 32768, 0 },
{ 12416, 12814, 16244, 22057, 23492, 24700, 26213, 27954, 29778, 32768, 0 },
{ 10624, 11057, 14619, 19415, 23134, 25679, 26399, 27618, 30676, 32768, 0 },
{ 10240, 10680, 15684, 19118, 21856, 27563, 28234, 29332, 31278, 32768, 0 },
{ 11008, 11433, 14100, 22522, 24365, 25330, 25737, 26341, 30433, 32768, 0 },
{ 10880, 11308, 13991, 23645, 24679, 25433, 25977, 26746, 28463, 32768, 0 },
{ 9856, 10483, 16054, 19959, 21708, 23628, 24949, 28797, 30658, 32768, 0 },
{ 12928, 14556, 22168, 27789, 28543, 29663, 29893, 30645, 31682, 32768, 0 },
};
#endif // CONFIG_ALT_INTRA
#if CONFIG_EXT_PARTITION_TYPES
static const aom_cdf_prob
default_partition_cdf[PARTITION_CONTEXTS][CDF_SIZE(EXT_PARTITION_TYPES)] = {
// 8x8 -> 4x4 only supports the four legacy partition types
{ 25472, 28949, 31052, 32768, 0, 0, 0, 0, 0 },
{ 18816, 22250, 28783, 32768, 0, 0, 0, 0, 0 },
{ 18944, 26126, 29188, 32768, 0, 0, 0, 0, 0 },
{ 15488, 22508, 27077, 32768, 0, 0, 0, 0, 0 },
{ 22272, 23768, 25043, 29996, 30744, 31493, 32130, 32768, 0 },
{ 11776, 13457, 16315, 28229, 29069, 29910, 31339, 32768, 0 },
{ 10496, 14802, 16136, 27127, 29280, 31434, 32101, 32768, 0 },
{ 6784, 8763, 10440, 29110, 30100, 31090, 31929, 32768, 0 },
{ 22656, 23801, 24702, 30721, 31294, 31867, 32317, 32768, 0 },
{ 8704, 9926, 12586, 28885, 29496, 30107, 31437, 32768, 0 },
{ 6656, 10685, 11566, 27857, 29871, 31886, 32327, 32768, 0 },
{ 2176, 3012, 3690, 31253, 31671, 32090, 32429, 32768, 0 },
{ 28416, 28705, 28926, 32258, 32402, 32547, 32657, 32768, 0 },
{ 9216, 9952, 11849, 30134, 30502, 30870, 31819, 32768, 0 },
{ 7424, 9008, 9528, 30664, 31456, 32248, 32508, 32768, 0 },
{ 1280, 1710, 2069, 31978, 32193, 32409, 32588, 32768, 0 },
#if CONFIG_EXT_PARTITION
{ 28416, 28705, 28926, 32258, 32402, 32547, 32657, 32768, 0 },
{ 9216, 9952, 11849, 30134, 30502, 30870, 31819, 32768, 0 },
{ 7424, 9008, 9528, 30664, 31456, 32248, 32508, 32768, 0 },
{ 1280, 1710, 2069, 31978, 32193, 32409, 32588, 32768, 0 },
#endif
};
#else
static const aom_cdf_prob
default_partition_cdf[PARTITION_CONTEXTS][CDF_SIZE(PARTITION_TYPES)] = {
{ 25472, 28949, 31052, 32768, 0 }, { 18816, 22250, 28783, 32768, 0 },
{ 18944, 26126, 29188, 32768, 0 }, { 15488, 22508, 27077, 32768, 0 },
{ 22272, 25265, 27815, 32768, 0 }, { 11776, 15138, 20854, 32768, 0 },
{ 10496, 19109, 21777, 32768, 0 }, { 6784, 10743, 14098, 32768, 0 },
{ 22656, 24947, 26749, 32768, 0 }, { 8704, 11148, 16469, 32768, 0 },
{ 6656, 14714, 16477, 32768, 0 }, { 2176, 3849, 5205, 32768, 0 },
{ 28416, 28994, 29436, 32768, 0 }, { 9216, 10688, 14483, 32768, 0 },
{ 7424, 10592, 11632, 32768, 0 }, { 1280, 2141, 2859, 32768, 0 },
#if CONFIG_EXT_PARTITION
{ 28416, 28994, 29436, 32768, 0 }, { 9216, 10688, 14483, 32768, 0 },
{ 7424, 10592, 11632, 32768, 0 }, { 1280, 2141, 2859, 32768, 0 },
#endif
};
#endif
static const aom_cdf_prob
default_inter_mode_cdf[INTER_MODE_CONTEXTS][CDF_SIZE(INTER_MODES)] = {
{ 256, 22227, 23627, 32768, 0 }, { 896, 18948, 23537, 32768, 0 },
{ 896, 21563, 24320, 32768, 0 }, { 896, 12599, 17799, 32768, 0 },
{ 1024, 8960, 13238, 32768, 0 }, { 2176, 11856, 14388, 32768, 0 },
{ 3200, 6550, 9622, 32768, 0 },
};
#if !CONFIG_EXT_TX
static const aom_cdf_prob
default_intra_ext_tx_cdf[EXT_TX_SIZES][TX_TYPES][CDF_SIZE(TX_TYPES)] = {
{ { 30720, 31400, 32084, 32768, 0 },
{ 512, 638, 31764, 32768, 0 },
{ 512, 638, 1642, 32768, 0 },
{ 512, 31760, 32264, 32768, 0 } },
{ { 31232, 31742, 32255, 32768, 0 },
{ 1024, 1272, 31784, 32768, 0 },
{ 1024, 1272, 2256, 32768, 0 },
{ 1024, 31776, 32272, 32768, 0 } },
{ { 31744, 32084, 32426, 32768, 0 },
{ 2048, 2528, 31823, 32768, 0 },
{ 2048, 2528, 3473, 32768, 0 },
{ 2048, 31808, 32288, 32768, 0 } },
};
static const aom_cdf_prob
default_inter_ext_tx_cdf[EXT_TX_SIZES][CDF_SIZE(TX_TYPES)] = {
{ 20480, 24560, 28664, 32768, 0 },
{ 22528, 25928, 29348, 32768, 0 },
{ 24576, 27296, 30032, 32768, 0 },
};
#endif
// CDF version of 'av1_kf_y_mode_prob'.
const aom_cdf_prob
av1_kf_y_mode_cdf[INTRA_MODES][INTRA_MODES][CDF_SIZE(INTRA_MODES)] = {
#if CONFIG_ALT_INTRA
{
{ 15488, 17513, 20731, 24586, 25921, 26749, 27807, 28602, 29530,
30681, 32768, 0 },
{ 11648, 14783, 21879, 23981, 25213, 26218, 27472, 28465, 29221,
30232, 32768, 0 },
{ 8448, 11108, 13392, 25167, 26295, 26789, 27536, 28088, 29039, 30700,
32768, 0 },
{ 13568, 15293, 18706, 21610, 23139, 24254, 26383, 27630, 28613,
30350, 32768, 0 },
{ 9600, 11772, 14397, 16580, 20091, 22865, 24490, 25395, 27037, 28694,
32768, 0 },
{ 12160, 14092, 17010, 18922, 22683, 25751, 27725, 30109, 31449,
32763, 32768, 0 },
{ 9088, 10383, 12569, 17113, 21351, 22511, 23633, 24382, 28215, 29798,
32768, 0 },
{ 10880, 12248, 15214, 20017, 21922, 22757, 24360, 25280, 26684,
29869, 32768, 0 },
{ 11008, 13133, 15587, 17872, 19579, 21157, 23788, 26629, 27732,
29601, 32768, 0 },
{ 10112, 12325, 15360, 18348, 20452, 20460, 21902, 23982, 25149,
26667, 32768, 0 },
{ 8704, 14250, 17722, 23128, 24217, 24892, 26215, 27392, 28358, 30287,
32768, 0 },
},
{
{ 8448, 10443, 20733, 23689, 24634, 25951, 26670, 27861, 28379, 29305,
32768, 0 },
{ 6656, 9206, 24577, 25792, 26335, 27169, 27913, 28956, 29239, 29680,
32768, 0 },
{ 7168, 8968, 15662, 22937, 23849, 24616, 25603, 26555, 27210, 29142,
32768, 0 },
{ 9600, 11501, 19310, 21731, 22790, 23936, 25627, 27217, 27868, 29170,
32768, 0 },
{ 6912, 8730, 17650, 19377, 21025, 23319, 24537, 26112, 26840, 28345,
32768, 0 },
{ 7808, 9661, 20583, 21996, 23898, 26818, 28120, 30716, 31678, 32764,
32768, 0 },
{ 6784, 8104, 15619, 18584, 20844, 22519, 23760, 25203, 27094, 28801,
32768, 0 },
{ 8832, 10141, 17035, 20764, 21703, 22751, 23964, 25305, 26034, 29006,
32768, 0 },
{ 8192, 9920, 19113, 20594, 21747, 23327, 24581, 26916, 27533, 28944,
32768, 0 },
{ 6656, 8696, 18381, 20537, 21804, 21809, 22751, 24394, 24917, 25990,
32768, 0 },
{ 6400, 9593, 20818, 23519, 24266, 25113, 26608, 27883, 28322, 29364,
32768, 0 },
},
{
{ 12032, 14381, 16608, 24946, 26084, 26582, 27428, 28075, 29395,
30858, 32768, 0 },
{ 9216, 12620, 18287, 24345, 25984, 26715, 27732, 28519, 29399, 30781,
32768, 0 },
{ 6784, 8916, 10220, 26539, 27310, 27483, 28082, 28430, 29362, 31291,
32768, 0 },
{ 11904, 14838, 17359, 21663, 22931, 23619, 25620, 26653, 27823,
30547, 32768, 0 },
{ 10752, 13504, 15536, 19057, 21753, 23883, 25202, 26266, 28196,
30589, 32768, 0 },
{ 10496, 13193, 16787, 21011, 23929, 25651, 27958, 29330, 31022,
32761, 32768, 0 },
{ 8448, 9968, 11749, 18062, 21841, 22669, 23852, 24444, 28118, 30007,
32768, 0 },
{ 9728, 11168, 12602, 20819, 22194, 22764, 24366, 25022, 26414, 30460,
32768, 0 },
{ 9216, 12712, 14357, 18346, 20486, 21549, 23170, 25794, 27129, 29574,
32768, 0 },
{ 7808, 10733, 13057, 20252, 21906, 21912, 23057, 24233, 25700, 27439,
32768, 0 },
{ 6784, 11352, 13778, 23877, 24995, 25424, 26830, 27688, 28779, 30368,
32768, 0 },
},
{
{ 12288, 13728, 16480, 19841, 21570, 22715, 25385, 27000, 28329,
29994, 32768, 0 },
{ 9344, 10991, 18817, 20972, 22137, 23231, 26025, 27711, 28244, 29428,
32768, 0 },
{ 9344, 10900, 13206, 21344, 22332, 22987, 25127, 26440, 27231, 29502,
32768, 0 },
{ 12928, 14478, 15978, 18630, 19852, 20897, 24699, 26464, 27030,
30482, 32768, 0 },
{ 9088, 10476, 13350, 15237, 18175, 20252, 23283, 25321, 26426, 29349,
32768, 0 },
{ 10240, 11912, 15008, 17177, 19979, 23056, 26395, 29681, 30790,
32760, 32768, 0 },
{ 8704, 9738, 11717, 15480, 18656, 20022, 22611, 24357, 27150, 29257,
32768, 0 },
{ 12928, 13548, 17978, 20602, 21814, 22427, 24568, 25881, 26823,
30817, 32768, 0 },
{ 10496, 12149, 14082, 18054, 19032, 19994, 24086, 28427, 29156,
30680, 32768, 0 },
{ 8448, 10158, 13867, 16506, 18584, 18592, 21472, 23767, 24646, 27279,
32768, 0 },
{ 7296, 9684, 13471, 17701, 18934, 19878, 25115, 27238, 27972, 29583,
32768, 0 },
},
{
{ 10880, 12163, 14497, 17112, 20859, 22562, 23599, 24638, 26861,
29399, 32768, 0 },
{ 9984, 12476, 16360, 18889, 21414, 23474, 24563, 25909, 27195, 28828,
32768, 0 },
{ 7168, 9268, 10737, 20063, 22315, 23302, 24152, 25195, 26645, 28845,
32768, 0 },
{ 8960, 10727, 12449, 14263, 16523, 17608, 23352, 24676, 26478, 28886,
32768, 0 },
{ 9856, 11109, 13309, 14975, 19055, 21670, 23144, 24460, 26212, 28107,
32768, 0 },
{ 9984, 11586, 14565, 16562, 21107, 25444, 27218, 29429, 31451, 32763,
32768, 0 },
{ 7168, 8268, 9704, 13144, 18443, 20065, 21653, 23607, 26506, 28854,
32768, 0 },
{ 11520, 13014, 14866, 18136, 20231, 21509, 23004, 24186, 25728,
29468, 32768, 0 },
{ 10240, 12264, 14507, 16388, 18888, 20927, 22731, 24691, 26142,
28394, 32768, 0 },
{ 8064, 10187, 12921, 15952, 19960, 19976, 21275, 23205, 25110, 26636,
32768, 0 },
{ 8448, 11488, 14065, 19113, 21604, 22978, 24508, 25895, 27398, 29055,
32768, 0 },
},
{
{ 10368, 11768, 16772, 19842, 22940, 27394, 28528, 30267, 31371,
32763, 32768, 0 },
{ 9472, 11292, 18507, 20777, 23357, 27587, 28902, 30850, 31607, 32763,
32768, 0 },
{ 8064, 9512, 13782, 20645, 24493, 26242, 28001, 29435, 30438, 32759,
32768, 0 },
{ 8960, 10541, 15664, 17639, 19646, 22145, 25216, 28815, 30050, 32757,
32768, 0 },
{ 9984, 11141, 15365, 16746, 21186, 25766, 27817, 30022, 31309, 32762,
32768, 0 },
{ 9216, 10688, 16639, 17735, 21499, 26657, 28161, 30572, 31490, 32763,
32768, 0 },
{ 8448, 9303, 13611, 16636, 20555, 23414, 24912, 27613, 29727, 32756,
32768, 0 },
{ 9984, 11052, 16142, 19312, 21680, 23870, 25504, 28200, 29324, 32755,
32768, 0 },
{ 10496, 12323, 16955, 18839, 21144, 24861, 26838, 29988, 30976,
32761, 32768, 0 },
{ 2944, 5973, 8904, 11875, 14864, 17853, 20824, 23810, 26784, 29776,
32768, 0 },
{ 7424, 10097, 15588, 20217, 23899, 26460, 28308, 30155, 30951, 32761,
32768, 0 },
},
{
{ 11648, 13133, 15050, 20481, 22470, 23425, 24337, 25160, 28964,
30480, 32768, 0 },
{ 10240, 12616, 16631, 20485, 22290, 23628, 25235, 26353, 28107,
29655, 32768, 0 },
{ 6784, 8002, 9066, 20038, 22926, 23324, 23951, 24537, 26916, 30231,
32768, 0 },
{ 11904, 14105, 15782, 19896, 22283, 23147, 24763, 25983, 27812,
29980, 32768, 0 },
{ 10624, 11922, 13632, 15941, 20469, 22453, 24065, 25187, 27349,
29296, 32768, 0 },
{ 12032, 13085, 15468, 17768, 20613, 24388, 26385, 28430, 30938,
32761, 32768, 0 },
{ 9728, 10538, 11493, 14765, 18460, 19471, 20302, 20935, 28192, 29926,
32768, 0 },
{ 8960, 9890, 10962, 16685, 18880, 19480, 20674, 21477, 23815, 29341,
32768, 0 },
{ 14592, 16367, 17712, 20293, 22544, 23829, 24877, 26326, 27660,
29875, 32768, 0 },
{ 8960, 10448, 12279, 16206, 18672, 18682, 20058, 21547, 25097, 27165,
32768, 0 },
{ 11136, 13840, 15762, 21710, 23038, 23734, 24863, 25882, 27765,
30071, 32768, 0 },
},
{
{ 12544, 14124, 16964, 21907, 23808, 24496, 25724, 26715, 27992,
30455, 32768, 0 },
{ 10368, 13606, 18247, 20869, 22590, 23749, 25088, 26378, 27277,
29808, 32768, 0 },
{ 9088, 11031, 12899, 23497, 24465, 24851, 25995, 26815, 27885, 30555,
32768, 0 },
{ 11520, 14342, 15710, 19196, 21250, 21907, 24665, 26153, 27212,
30750, 32768, 0 },
{ 9984, 11764, 13979, 16405, 19279, 20658, 23354, 25266, 26702, 29380,
32768, 0 },
{ 10112, 12325, 15918, 19060, 21829, 23882, 26277, 27697, 30114,
32758, 32768, 0 },
{ 9344, 10534, 12184, 16208, 19764, 20627, 22524, 23644, 26887, 29782,
32768, 0 },
{ 12928, 14013, 15625, 19107, 20654, 21451, 22910, 23873, 24776,
30239, 32768, 0 },
{ 10368, 12818, 14610, 17350, 19568, 20710, 22971, 25114, 26340,
29127, 32768, 0 },
{ 8960, 11192, 13720, 18429, 20409, 20417, 22250, 23318, 24647, 27248,
32768, 0 },
{ 7808, 11416, 13918, 19028, 20181, 20839, 24380, 26018, 26967, 29845,
32768, 0 },
},
{
{ 9856, 11020, 14928, 18159, 19421, 20921, 23466, 26664, 27475, 28881,
32768, 0 },
{ 8704, 10302, 17323, 18907, 19868, 21184, 24171, 28033, 28625, 29353,
32768, 0 },
{ 7936, 9197, 12604, 20616, 21514, 22371, 24239, 26138, 26863, 29239,
32768, 0 },
{ 11264, 12524, 16083, 18574, 19858, 20841, 24242, 27606, 28352,
29853, 32768, 0 },
{ 8704, 10208, 13292, 15170, 17277, 19226, 22083, 25046, 26041, 27802,
32768, 0 },
{ 9088, 10568, 15511, 17246, 20170, 22791, 25558, 30740, 31635, 32764,
32768, 0 },
{ 7040, 8045, 10653, 13145, 15286, 16614, 19075, 23140, 26224, 28652,
32768, 0 },
{ 10240, 11032, 14258, 17629, 18914, 19898, 22412, 24961, 25815,
29156, 32768, 0 },
{ 11008, 12028, 14702, 16147, 17209, 18160, 21812, 27547, 28709,
30120, 32768, 0 },
{ 7168, 9068, 14160, 16937, 18515, 18521, 20636, 24617, 25317, 26365,
32768, 0 },
{ 6784, 8510, 14195, 17148, 18158, 19201, 23070, 27351, 27901, 29422,
32768, 0 },
},
{
{ 10112, 11528, 15345, 19296, 21394, 21402, 22379, 23840, 24851,
26150, 32768, 0 },
{ 8064, 10187, 17949, 20052, 22051, 22059, 23147, 24688, 25351, 26365,
32768, 0 },
{ 6528, 8373, 11041, 21963, 23089, 23093, 24076, 24925, 25691, 27764,
32768, 0 },
{ 9600, 11229, 14847, 17527, 19738, 19747, 21629, 23761, 24957, 27673,
32768, 0 },
{ 8960, 10262, 13339, 15480, 19925, 19942, 21445, 23037, 24329, 25977,
32768, 0 },
{ 2944, 5973, 8904, 11875, 14864, 17853, 20824, 23810, 26784, 29776,
32768, 0 },
{ 9472, 10564, 13426, 16561, 19685, 19697, 21076, 22583, 24891, 26983,
32768, 0 },
{ 8448, 9493, 12221, 16542, 18394, 18401, 19580, 20971, 22031, 26770,
32768, 0 },
{ 8704, 10772, 14209, 16381, 18911, 18921, 20436, 23374, 24475, 26095,
32768, 0 },
{ 7680, 9444, 13453, 16320, 18650, 18659, 19651, 21291, 22277, 23916,
32768, 0 },
{ 6656, 9920, 14740, 19864, 21495, 21501, 22953, 24372, 25192, 26760,
32768, 0 },
},
{
{ 9728, 13958, 18881, 23624, 24754, 25553, 26709, 27940, 28977, 30413,
32768, 0 },
{ 8832, 12572, 22433, 24653, 25676, 26551, 27571, 28688, 29198, 30174,
32768, 0 },
{ 5888, 8828, 11353, 23482, 24310, 24737, 25804, 26375, 27174, 29840,
32768, 0 },
{ 9984, 13099, 16249, 19443, 20990, 22637, 24576, 25952, 26884, 29435,
32768, 0 },
{ 8448, 11108, 15085, 18134, 20319, 21992, 23549, 24989, 27177, 29208,
32768, 0 },
{ 9856, 13168, 18987, 22481, 24282, 26200, 27868, 30203, 31085, 32761,
32768, 0 },
{ 6784, 9119, 12629, 16877, 20262, 21125, 22307, 23615, 27727, 29972,
32768, 0 },
{ 8320, 10230, 12783, 19005, 20213, 20668, 22039, 23045, 24146, 30478,
32768, 0 },
{ 9088, 11308, 15416, 18118, 19762, 20906, 22574, 25162, 25994, 28455,
32768, 0 },
{ 6912, 10548, 15148, 20026, 21612, 21618, 22707, 24200, 24869, 26844,
32768, 0 },
{ 6656, 12164, 16993, 21568, 22933, 23648, 25322, 26602, 27806, 29841,
32768, 0 },
},
#else
{ { 17536, 19321, 21527, 25360, 27516, 28026, 29323, 30023, 30999, 32768,
0 },
{ 11776, 15466, 22360, 24865, 26991, 27889, 29299, 30519, 31398, 32768,
0 },
{ 9344, 12272, 13793, 25813, 27359, 27654, 28573, 29130, 30551, 32768,
0 },
{ 11648, 14123, 16454, 19948, 22780, 23846, 27087, 28995, 30380, 32768,
0 },
{ 9216, 12436, 15295, 17996, 24006, 25465, 27405, 28725, 30383, 32768,
0 },
{ 9344, 12181, 14433, 16634, 20355, 24317, 26133, 29295, 31344, 32768,
0 },
{ 8576, 10750, 12556, 17996, 22315, 23609, 25040, 26157, 30573, 32768,
0 },
{ 11008, 13303, 15432, 20646, 23506, 24100, 25624, 26824, 28055, 32768,
0 },
{ 9472, 12384, 14534, 17094, 20257, 22155, 24767, 28955, 30474, 32768,
0 },
{ 7552, 14152, 17352, 22654, 25123, 25783, 27911, 29182, 30849, 32768,
0 } },
{ { 8064, 11538, 21987, 24941, 26913, 28136, 29222, 30469, 31331, 32768,
0 },
{ 5504, 10403, 25080, 26762, 27933, 29104, 30092, 31576, 32004, 32768,
0 },
{ 5632, 8706, 15097, 23714, 25344, 26072, 27380, 28580, 29840, 32768,
0 },
{ 7424, 11186, 17593, 20154, 22974, 24351, 26916, 29956, 30967, 32768,
0 },
{ 5888, 10193, 16895, 19031, 23735, 25576, 27514, 29813, 30471, 32768,
0 },
{ 4864, 8352, 16459, 18062, 21263, 25378, 26937, 30376, 31619, 32768,
0 },
{ 4992, 7922, 13842, 18004, 21779, 23527, 25115, 27357, 30232, 32768,
0 },
{ 6656, 9716, 16379, 20053, 22487, 23613, 25437, 27270, 28516, 32768,
0 },
{ 6016, 9674, 16891, 18684, 21147, 23093, 25512, 30132, 30894, 32768,
0 },
{ 4608, 11318, 21038, 23650, 25303, 26262, 28295, 30479, 31212, 32768,
0 } },
{ { 10496, 12758, 14790, 24547, 26342, 26799, 27825, 28443, 30217, 32768,
0 },
{ 7040, 11462, 17121, 24215, 26504, 27267, 28492, 29444, 30846, 32768,
0 },
{ 5376, 8158, 9215, 26451, 27407, 27524, 27995, 28275, 29767, 32768,
0 },
{ 8704, 12652, 14145, 20101, 22879, 23675, 25629, 27079, 28923, 32768,
0 },
{ 7424, 12374, 14366, 18855, 23842, 24358, 25639, 27087, 29706, 32768,
0 },
{ 6400, 10005, 12939, 17753, 22206, 24790, 26785, 28164, 30520, 32768,
0 },
{ 5632, 8176, 9713, 19053, 22343, 23222, 24453, 25070, 29761, 32768,
0 },
{ 7040, 9754, 10833, 21229, 23540, 23943, 24839, 25675, 27033, 32768,
0 },
{ 6784, 11758, 13481, 17236, 20210, 21768, 24303, 26948, 28676, 32768,
0 },
{ 4864, 12712, 14201, 23863, 25952, 26386, 27632, 28635, 30362, 32768,
0 } },
{ { 13184, 15173, 17647, 21576, 24474, 25267, 27699, 29283, 30549, 32768,
0 },
{ 7552, 11295, 18257, 20811, 23213, 24606, 27731, 30407, 31237, 32768,
0 },
{ 7936, 10846, 12816, 22436, 24614, 25130, 26890, 28199, 29091, 32768,
0 },
{ 8576, 11411, 13830, 15918, 18996, 20044, 25114, 27835, 28972, 32768,
0 },
{ 7680, 10816, 13646, 15966, 21162, 22012, 24701, 27506, 29644, 32768,
0 },
{ 6784, 9423, 12524, 14773, 19447, 22804, 26073, 29211, 30642, 32768,
0 },
{ 6784, 8916, 11059, 15861, 21174, 22338, 24620, 27071, 30899, 32768,
0 },
{ 9856, 11557, 13960, 18525, 21788, 22189, 24462, 26603, 27470, 32768,
0 },
{ 7808, 10636, 13143, 15844, 18698, 20272, 24323, 30096, 31787, 32768,
0 },
{ 6016, 10928, 14596, 18926, 21586, 22688, 26626, 29001, 30399, 32768,
0 } },
{ { 8832, 10983, 13451, 16582, 21656, 23109, 24845, 26207, 28796, 32768,
0 },
{ 6784, 10844, 15554, 18073, 22954, 24901, 26776, 28649, 30419, 32768,
0 },
{ 5120, 8252, 10072, 20108, 23535, 24346, 25761, 26418, 28675, 32768,
0 },
{ 7680, 11012, 12627, 14595, 19462, 20888, 23348, 25703, 28159, 32768,
0 },
{ 6656, 9818, 11790, 13813, 22731, 24737, 26557, 28061, 29697, 32768,
0 },
{ 5632, 8918, 11620, 13802, 19950, 23764, 25734, 28537, 31809, 32768,
0 },
{ 4480, 6580, 7808, 12281, 19375, 20970, 22860, 24602, 29929, 32768,
0 },
{ 7040, 9553, 11457, 15102, 20291, 21280, 22985, 24475, 26613, 32768,
0 },
{ 6528, 10423, 12605, 14621, 19031, 21505, 24585, 27558, 29532, 32768,
0 },
{ 6016, 11659, 14463, 18867, 23653, 24903, 27115, 29389, 31382, 32768,
0 } },
{ { 8192, 10016, 13304, 16362, 21107, 25165, 26620, 28901, 30910, 32768,
0 },
{ 5888, 8723, 16237, 18318, 22002, 25923, 27394, 29934, 31428, 32768,
0 },
{ 4608, 7138, 9841, 18442, 22447, 24618, 26337, 27945, 30168, 32768,
0 },
{ 6784, 8916, 12270, 14851, 19886, 22759, 25105, 28368, 29760, 32768,
0 },
{ 5120, 7928, 11324, 13340, 21205, 24224, 25926, 28518, 30560, 32768,
0 },
{ 4480, 6580, 10058, 11237, 16807, 25937, 27218, 30015, 31348, 32768,
0 },
{ 4608, 6808, 9445, 12446, 18461, 21835, 23244, 26109, 30115, 32768,
0 },
{ 5760, 7659, 10798, 14720, 19157, 21955, 23645, 26460, 28702, 32768,
0 },
{ 5760, 8503, 11157, 13071, 17594, 22047, 24099, 29077, 30850, 32768,
0 },
{ 4864, 9660, 14264, 17105, 21528, 24094, 26025, 28580, 30559, 32768,
0 } },
{ { 9600, 11139, 12998, 18660, 22158, 23501, 24659, 25736, 30296, 32768,
0 },
{ 7168, 11068, 15984, 19969, 23169, 24704, 26216, 27572, 31368, 32768,
0 },
{ 4480, 6801, 8018, 20908, 23071, 23583, 24301, 25062, 29427, 32768,
0 },
{ 7168, 10068, 11753, 15843, 19742, 21358, 23809, 26189, 29067, 32768,
0 },
{ 6016, 9047, 10622, 13931, 22462, 23858, 25911, 27277, 29722, 32768,
0 },
{ 5888, 7568, 9931, 13533, 18431, 22063, 23777, 26025, 30555, 32768,
0 },
{ 4352, 6239, 7379, 13739, 16917, 18090, 18835, 19651, 30360, 32768,
0 },
{ 6528, 8988, 10288, 15534, 19495, 20386, 21934, 23034, 26988, 32768,
0 },
{ 7040, 10055, 11652, 14757, 19622, 21715, 23615, 26761, 29483, 32768,
0 },
{ 4736, 10102, 12315, 19078, 21348, 22621, 24246, 26044, 29931, 32768,
0 } },
{ { 10496, 12410, 14955, 19891, 23137, 23792, 25159, 26378, 28125, 32768,
0 },
{ 7936, 12204, 17104, 20191, 23468, 24630, 26156, 27628, 28913, 32768,
0 },
{ 6016, 8629, 10232, 23591, 25349, 25637, 26306, 27063, 28980, 32768,
0 },
{ 8704, 12088, 13461, 16646, 20516, 21455, 24062, 26579, 28368, 32768,
0 },
{ 7296, 11177, 13117, 16196, 23378, 24708, 26440, 27997, 29078, 32768,
0 },
{ 6272, 9377, 12575, 15616, 20919, 23697, 26603, 27566, 29903, 32768,
0 },
{ 6528, 9091, 10478, 16445, 21081, 22320, 23871, 25087, 29258, 32768,
0 },
{ 8704, 11148, 12499, 17340, 20656, 21288, 22588, 23701, 24693, 32768,
0 },
{ 7552, 11394, 12980, 15562, 19942, 21792, 25093, 28211, 28959, 32768,
0 },
{ 5120, 11708, 13847, 19377, 22421, 23160, 25449, 27136, 29182, 32768,
0 } },
{ { 9984, 12031, 15190, 18673, 21422, 22812, 25690, 29118, 30458, 32768,
0 },
{ 6144, 9680, 17436, 19610, 21820, 23485, 26313, 30826, 31843, 32768,
0 },
{ 6016, 8315, 10607, 19333, 21572, 22553, 25266, 27288, 28551, 32768,
0 },
{ 7168, 9668, 12646, 16257, 19648, 20899, 25304, 30465, 31625, 32768,
0 },
{ 6144, 9368, 11836, 14130, 19153, 21157, 24876, 28452, 29396, 32768,
0 },
{ 5504, 8486, 11996, 14412, 17968, 21814, 24424, 30682, 32059, 32768,
0 },
{ 5376, 7195, 9592, 13331, 17569, 19460, 22371, 25458, 28942, 32768,
0 },
{ 7424, 9206, 11783, 16456, 19253, 20390, 23775, 27007, 28425, 32768,
0 },
{ 5888, 8303, 11361, 13440, 15848, 17549, 21532, 29564, 30665, 32768,
0 },
{ 4608, 8788, 13284, 16621, 18983, 20286, 24577, 28960, 30314, 32768,
0 } },
{ { 8320, 15005, 19168, 24282, 26707, 27402, 28681, 29639, 30629, 32768,
0 },
{ 5632, 13900, 22376, 24867, 26804, 27734, 29130, 30722, 31465, 32768,
0 },
{ 4992, 9115, 11055, 24893, 26316, 26661, 27663, 28301, 29418, 32768,
0 },
{ 7424, 12077, 14987, 19596, 22615, 23600, 26465, 28484, 29789, 32768,
0 },
{ 6272, 11447, 14362, 18204, 23418, 24715, 26697, 28547, 29520, 32768,
0 },
{ 5248, 10946, 15379, 18167, 22197, 25432, 27295, 30031, 30576, 32768,
0 },
{ 5120, 9008, 11607, 18210, 22327, 23427, 24887, 26580, 29892, 32768,
0 },
{ 6656, 10124, 12689, 19922, 22480, 22807, 24441, 25579, 26787, 32768,
0 },
{ 5376, 10084, 13983, 17113, 19996, 21614, 24403, 28651, 29938, 32768,
0 },
{ 5504, 14131, 17989, 23324, 25513, 26071, 27850, 29464, 30393, 32768,
0 } },
#endif // CONFIG_ALT_INTRA
};
#endif // CONFIG_EC_MULTISYMBOL
static void init_mode_probs(FRAME_CONTEXT *fc) {
av1_copy(fc->uv_mode_prob, default_uv_probs);
av1_copy(fc->y_mode_prob, default_if_y_probs);
av1_copy(fc->switchable_interp_prob, default_switchable_interp_prob);
av1_copy(fc->partition_prob, default_partition_probs);
av1_copy(fc->intra_inter_prob, default_intra_inter_p);
av1_copy(fc->comp_inter_prob, default_comp_inter_p);
av1_copy(fc->comp_ref_prob, default_comp_ref_p);
#if CONFIG_EXT_REFS
av1_copy(fc->comp_bwdref_prob, default_comp_bwdref_p);
#endif // CONFIG_EXT_REFS
av1_copy(fc->single_ref_prob, default_single_ref_p);
av1_copy(fc->tx_size_probs, default_tx_size_prob);
#if CONFIG_VAR_TX
av1_copy(fc->txfm_partition_prob, default_txfm_partition_probs);
#endif
av1_copy(fc->skip_probs, default_skip_probs);
#if CONFIG_REF_MV
av1_copy(fc->newmv_prob, default_newmv_prob);
av1_copy(fc->zeromv_prob, default_zeromv_prob);
av1_copy(fc->refmv_prob, default_refmv_prob);
av1_copy(fc->drl_prob, default_drl_prob);
#if CONFIG_EXT_INTER
fc->new2mv_prob = default_new2mv_prob;
#endif // CONFIG_EXT_INTER
#endif // CONFIG_REF_MV
av1_copy(fc->inter_mode_probs, default_inter_mode_probs);
#if CONFIG_MOTION_VAR || CONFIG_WARPED_MOTION
av1_copy(fc->motion_mode_prob, default_motion_mode_prob);
#if CONFIG_MOTION_VAR && CONFIG_WARPED_MOTION
av1_copy(fc->obmc_prob, default_obmc_prob);
#endif // CONFIG_MOTION_VAR && CONFIG_WARPED_MOTION
#endif // CONFIG_MOTION_VAR || CONFIG_WARPED_MOTION
#if CONFIG_EXT_INTER
av1_copy(fc->inter_compound_mode_probs, default_inter_compound_mode_probs);
av1_copy(fc->compound_type_prob, default_compound_type_probs);
av1_copy(fc->interintra_prob, default_interintra_prob);
av1_copy(fc->interintra_mode_prob, default_interintra_mode_prob);
av1_copy(fc->wedge_interintra_prob, default_wedge_interintra_prob);
#endif // CONFIG_EXT_INTER
#if CONFIG_SUPERTX
av1_copy(fc->supertx_prob, default_supertx_prob);
#endif // CONFIG_SUPERTX
av1_copy(fc->seg.tree_probs, default_segment_tree_probs);
av1_copy(fc->seg.pred_probs, default_segment_pred_probs);
#if CONFIG_EXT_INTRA
#if CONFIG_INTRA_INTERP
av1_copy(fc->intra_filter_probs, default_intra_filter_probs);
#endif // CONFIG_INTRA_INTERP
#endif // CONFIG_EXT_INTRA
#if CONFIG_FILTER_INTRA
av1_copy(fc->filter_intra_probs, default_filter_intra_probs);
#endif // CONFIG_FILTER_INTRA
av1_copy(fc->inter_ext_tx_prob, default_inter_ext_tx_prob);
av1_copy(fc->intra_ext_tx_prob, default_intra_ext_tx_prob);
#if CONFIG_LOOP_RESTORATION
av1_copy(fc->switchable_restore_prob, default_switchable_restore_prob);
#endif // CONFIG_LOOP_RESTORATION
#if CONFIG_EC_MULTISYMBOL
av1_copy(fc->y_mode_cdf, default_if_y_mode_cdf);
av1_copy(fc->uv_mode_cdf, default_uv_mode_cdf);
av1_copy(fc->switchable_interp_cdf, default_switchable_interp_cdf);
av1_copy(fc->partition_cdf, default_partition_cdf);
av1_copy(fc->inter_mode_cdf, default_inter_mode_cdf);
#if !CONFIG_EXT_TX
av1_copy(fc->intra_ext_tx_cdf, default_intra_ext_tx_cdf);
av1_copy(fc->inter_ext_tx_cdf, default_inter_ext_tx_cdf);
#endif
av1_copy(fc->seg.tree_cdf, default_seg_tree_cdf);
av1_copy(fc->tx_size_cdf, default_tx_size_cdf);
#endif
#if CONFIG_DELTA_Q
av1_copy(fc->delta_q_prob, default_delta_q_probs);
#if CONFIG_EC_MULTISYMBOL
av1_copy(fc->delta_q_cdf, default_delta_q_cdf);
#endif
#endif
}
#if CONFIG_EC_MULTISYMBOL
int av1_switchable_interp_ind[SWITCHABLE_FILTERS];
int av1_switchable_interp_inv[SWITCHABLE_FILTERS];
#if !CONFIG_EC_ADAPT
void av1_set_mode_cdfs(struct AV1Common *cm) {
FRAME_CONTEXT *fc = cm->fc;
int i, j;
if (cm->seg.enabled && cm->seg.update_map) {
av1_tree_to_cdf(av1_segment_tree, cm->fc->seg.tree_probs,
cm->fc->seg.tree_cdf);
}
for (i = 0; i < INTRA_MODES; ++i)
av1_tree_to_cdf(av1_intra_mode_tree, fc->uv_mode_prob[i],
fc->uv_mode_cdf[i]);
#if CONFIG_EXT_PARTITION_TYPES
for (i = 0; i < PARTITION_PLOFFSET; ++i)
av1_tree_to_cdf(av1_partition_tree, fc->partition_prob[i],
fc->partition_cdf[i]);
// Logical index (enum value) to inorder index (tree_to_cdf order)
aom_cdf_prob inorder_partition_cdf[CDF_SIZE(EXT_PARTITION_TYPES)] = {};
// TODO(aconverse): Generate this dynamically. The assumptions that
// av1_indices_from_tree() makes don't hold for this tree.
static const uint8_t av1_ext_partition_index_map[EXT_PARTITION_TYPES] = {
0, 1, 4, 7, 2, 3, 5, 6,
};
for (; i < PARTITION_CONTEXTS; ++i) {
av1_tree_to_cdf(av1_ext_partition_tree, fc->partition_prob[i],
inorder_partition_cdf);
aom_cdf_prob cum_prob = 0;
for (j = 0; j < EXT_PARTITION_TYPES; ++j) {
int inorder_idx = av1_ext_partition_index_map[j];
aom_cdf_prob prob =
inorder_partition_cdf[inorder_idx] -
(inorder_idx > 0 ? inorder_partition_cdf[inorder_idx - 1] : 0);
fc->partition_cdf[i][j] = (cum_prob += prob);
}
assert(cum_prob == CDF_PROB_TOP);
}
#else
for (i = 0; i < PARTITION_CONTEXTS; ++i)
av1_tree_to_cdf(av1_partition_tree, fc->partition_prob[i],
fc->partition_cdf[i]);
#endif
for (i = 0; i < INTRA_MODES; ++i)
for (j = 0; j < INTRA_MODES; ++j)
av1_tree_to_cdf(av1_intra_mode_tree, cm->kf_y_prob[i][j],
cm->fc->kf_y_cdf[i][j]);
for (j = 0; j < SWITCHABLE_FILTER_CONTEXTS; ++j)
av1_tree_to_cdf(av1_switchable_interp_tree, fc->switchable_interp_prob[j],
fc->switchable_interp_cdf[j]);
for (i = 0; i < INTER_MODE_CONTEXTS; ++i)
av1_tree_to_cdf(av1_inter_mode_tree, fc->inter_mode_probs[i],
fc->inter_mode_cdf[i]);
for (i = 0; i < BLOCK_SIZE_GROUPS; ++i)
av1_tree_to_cdf(av1_intra_mode_tree, fc->y_mode_prob[i], fc->y_mode_cdf[i]);
#if !CONFIG_EXT_TX
for (i = TX_4X4; i < EXT_TX_SIZES; ++i)
for (j = 0; j < TX_TYPES; ++j)
av1_tree_to_cdf(av1_ext_tx_tree, fc->intra_ext_tx_prob[i][j],
fc->intra_ext_tx_cdf[i][j]);
for (i = TX_4X4; i < EXT_TX_SIZES; ++i)
av1_tree_to_cdf(av1_ext_tx_tree, fc->inter_ext_tx_prob[i],
fc->inter_ext_tx_cdf[i]);
#endif
for (i = 0; i < MAX_TX_DEPTH; i++) {
for (j = 0; j < TX_SIZE_CONTEXTS; j++) {
av1_tree_to_cdf(av1_tx_size_tree[i], fc->tx_size_probs[i][j],
fc->tx_size_cdf[i][j]);
}
}
}
#endif // !CONFIG_EC_ADAPT
#endif
#if CONFIG_DUAL_FILTER
const aom_tree_index av1_switchable_interp_tree[TREE_SIZE(SWITCHABLE_FILTERS)] =
{
-EIGHTTAP_REGULAR, 2, 4, -MULTITAP_SHARP, -EIGHTTAP_SMOOTH,
-EIGHTTAP_SMOOTH2,
};
#else
const aom_tree_index av1_switchable_interp_tree[TREE_SIZE(SWITCHABLE_FILTERS)] =
{ -EIGHTTAP_REGULAR, 2, -EIGHTTAP_SMOOTH, -MULTITAP_SHARP };
#endif // CONFIG_DUAL_FILTER
void av1_adapt_inter_frame_probs(AV1_COMMON *cm) {
int i, j;
FRAME_CONTEXT *fc = cm->fc;
const FRAME_CONTEXT *pre_fc = &cm->frame_contexts[cm->frame_context_idx];
const FRAME_COUNTS *counts = &cm->counts;
for (i = 0; i < INTRA_INTER_CONTEXTS; i++)
fc->intra_inter_prob[i] = av1_mode_mv_merge_probs(
pre_fc->intra_inter_prob[i], counts->intra_inter[i]);
for (i = 0; i < COMP_INTER_CONTEXTS; i++)
fc->comp_inter_prob[i] = av1_mode_mv_merge_probs(pre_fc->comp_inter_prob[i],
counts->comp_inter[i]);
#if CONFIG_EXT_REFS
for (i = 0; i < REF_CONTEXTS; i++)
for (j = 0; j < (FWD_REFS - 1); j++)
fc->comp_ref_prob[i][j] = mode_mv_merge_probs(pre_fc->comp_ref_prob[i][j],
counts->comp_ref[i][j]);
for (i = 0; i < REF_CONTEXTS; i++)
for (j = 0; j < (BWD_REFS - 1); j++)
fc->comp_bwdref_prob[i][j] = mode_mv_merge_probs(
pre_fc->comp_bwdref_prob[i][j], counts->comp_bwdref[i][j]);
#else
for (i = 0; i < REF_CONTEXTS; i++)
for (j = 0; j < (COMP_REFS - 1); j++)
fc->comp_ref_prob[i][j] = mode_mv_merge_probs(pre_fc->comp_ref_prob[i][j],
counts->comp_ref[i][j]);
#endif // CONFIG_EXT_REFS
for (i = 0; i < REF_CONTEXTS; i++)
for (j = 0; j < (SINGLE_REFS - 1); j++)
fc->single_ref_prob[i][j] = av1_mode_mv_merge_probs(
pre_fc->single_ref_prob[i][j], counts->single_ref[i][j]);
#if CONFIG_REF_MV
for (i = 0; i < NEWMV_MODE_CONTEXTS; ++i)
fc->newmv_prob[i] =
av1_mode_mv_merge_probs(pre_fc->newmv_prob[i], counts->newmv_mode[i]);
for (i = 0; i < ZEROMV_MODE_CONTEXTS; ++i)
fc->zeromv_prob[i] =
av1_mode_mv_merge_probs(pre_fc->zeromv_prob[i], counts->zeromv_mode[i]);
for (i = 0; i < REFMV_MODE_CONTEXTS; ++i)
fc->refmv_prob[i] =
av1_mode_mv_merge_probs(pre_fc->refmv_prob[i], counts->refmv_mode[i]);
for (i = 0; i < DRL_MODE_CONTEXTS; ++i)
fc->drl_prob[i] =
av1_mode_mv_merge_probs(pre_fc->drl_prob[i], counts->drl_mode[i]);
#if CONFIG_EXT_INTER
fc->new2mv_prob =
av1_mode_mv_merge_probs(pre_fc->new2mv_prob, counts->new2mv_mode);
#endif // CONFIG_EXT_INTER
#else
for (i = 0; i < INTER_MODE_CONTEXTS; i++)
aom_tree_merge_probs(av1_inter_mode_tree, pre_fc->inter_mode_probs[i],
counts->inter_mode[i], fc->inter_mode_probs[i]);
#endif
#if CONFIG_MOTION_VAR || CONFIG_WARPED_MOTION
for (i = BLOCK_8X8; i < BLOCK_SIZES; ++i)
aom_tree_merge_probs(av1_motion_mode_tree, pre_fc->motion_mode_prob[i],
counts->motion_mode[i], fc->motion_mode_prob[i]);
#if CONFIG_MOTION_VAR && CONFIG_WARPED_MOTION
for (i = BLOCK_8X8; i < BLOCK_SIZES; ++i)
fc->obmc_prob[i] =
av1_mode_mv_merge_probs(pre_fc->obmc_prob[i], counts->obmc[i]);
#endif // CONFIG_MOTION_VAR && CONFIG_WARPED_MOTION
#endif // CONFIG_MOTION_VAR || CONFIG_WARPED_MOTION
#if CONFIG_SUPERTX
for (i = 0; i < PARTITION_SUPERTX_CONTEXTS; ++i) {
for (j = TX_8X8; j < TX_SIZES; ++j) {
fc->supertx_prob[i][j] = av1_mode_mv_merge_probs(
pre_fc->supertx_prob[i][j], counts->supertx[i][j]);
}
}
#endif // CONFIG_SUPERTX
#if CONFIG_EXT_INTER
for (i = 0; i < INTER_MODE_CONTEXTS; i++)
aom_tree_merge_probs(
av1_inter_compound_mode_tree, pre_fc->inter_compound_mode_probs[i],
counts->inter_compound_mode[i], fc->inter_compound_mode_probs[i]);
for (i = 0; i < BLOCK_SIZE_GROUPS; ++i) {
if (is_interintra_allowed_bsize_group(i))
fc->interintra_prob[i] = av1_mode_mv_merge_probs(
pre_fc->interintra_prob[i], counts->interintra[i]);
}
for (i = 0; i < BLOCK_SIZE_GROUPS; i++) {
aom_tree_merge_probs(
av1_interintra_mode_tree, pre_fc->interintra_mode_prob[i],
counts->interintra_mode[i], fc->interintra_mode_prob[i]);
}
for (i = 0; i < BLOCK_SIZES; ++i) {
if (is_interintra_allowed_bsize(i) && is_interintra_wedge_used(i))
fc->wedge_interintra_prob[i] = av1_mode_mv_merge_probs(
pre_fc->wedge_interintra_prob[i], counts->wedge_interintra[i]);
}
for (i = 0; i < BLOCK_SIZES; ++i) {
aom_tree_merge_probs(av1_compound_type_tree, pre_fc->compound_type_prob[i],
counts->compound_interinter[i],
fc->compound_type_prob[i]);
}
#endif // CONFIG_EXT_INTER
for (i = 0; i < BLOCK_SIZE_GROUPS; i++)
aom_tree_merge_probs(av1_intra_mode_tree, pre_fc->y_mode_prob[i],
counts->y_mode[i], fc->y_mode_prob[i]);
if (cm->interp_filter == SWITCHABLE) {
for (i = 0; i < SWITCHABLE_FILTER_CONTEXTS; i++)
aom_tree_merge_probs(
av1_switchable_interp_tree, pre_fc->switchable_interp_prob[i],
counts->switchable_interp[i], fc->switchable_interp_prob[i]);
}
}
void av1_adapt_intra_frame_probs(AV1_COMMON *cm) {
int i, j;
FRAME_CONTEXT *fc = cm->fc;
const FRAME_CONTEXT *pre_fc = &cm->frame_contexts[cm->frame_context_idx];
const FRAME_COUNTS *counts = &cm->counts;
if (cm->tx_mode == TX_MODE_SELECT) {
for (i = 0; i < MAX_TX_DEPTH; ++i) {
for (j = 0; j < TX_SIZE_CONTEXTS; ++j)
aom_tree_merge_probs(av1_tx_size_tree[i], pre_fc->tx_size_probs[i][j],
counts->tx_size[i][j], fc->tx_size_probs[i][j]);
}
}
#if CONFIG_VAR_TX
if (cm->tx_mode == TX_MODE_SELECT) {
for (i = 0; i < TXFM_PARTITION_CONTEXTS; ++i)
fc->txfm_partition_prob[i] = av1_mode_mv_merge_probs(
pre_fc->txfm_partition_prob[i], counts->txfm_partition[i]);
}
#endif
for (i = 0; i < SKIP_CONTEXTS; ++i)
fc->skip_probs[i] =
av1_mode_mv_merge_probs(pre_fc->skip_probs[i], counts->skip[i]);
#if CONFIG_EXT_TX
for (i = TX_4X4; i < EXT_TX_SIZES; ++i) {
int s;
for (s = 1; s < EXT_TX_SETS_INTER; ++s) {
if (use_inter_ext_tx_for_txsize[s][i]) {
aom_tree_merge_probs(
av1_ext_tx_inter_tree[s], pre_fc->inter_ext_tx_prob[s][i],
counts->inter_ext_tx[s][i], fc->inter_ext_tx_prob[s][i]);
}
}
for (s = 1; s < EXT_TX_SETS_INTRA; ++s) {
if (use_intra_ext_tx_for_txsize[s][i]) {
for (j = 0; j < INTRA_MODES; ++j)
aom_tree_merge_probs(
av1_ext_tx_intra_tree[s], pre_fc->intra_ext_tx_prob[s][i][j],
counts->intra_ext_tx[s][i][j], fc->intra_ext_tx_prob[s][i][j]);
}
}
}
#else
for (i = TX_4X4; i < EXT_TX_SIZES; ++i) {
for (j = 0; j < TX_TYPES; ++j) {
aom_tree_merge_probs(av1_ext_tx_tree, pre_fc->intra_ext_tx_prob[i][j],
counts->intra_ext_tx[i][j],
fc->intra_ext_tx_prob[i][j]);
}
}
for (i = TX_4X4; i < EXT_TX_SIZES; ++i) {
aom_tree_merge_probs(av1_ext_tx_tree, pre_fc->inter_ext_tx_prob[i],
counts->inter_ext_tx[i], fc->inter_ext_tx_prob[i]);
}
#endif // CONFIG_EXT_TX
if (cm->seg.temporal_update) {
for (i = 0; i < PREDICTION_PROBS; i++)
fc->seg.pred_probs[i] = av1_mode_mv_merge_probs(pre_fc->seg.pred_probs[i],
counts->seg.pred[i]);
aom_tree_merge_probs(av1_segment_tree, pre_fc->seg.tree_probs,
counts->seg.tree_mispred, fc->seg.tree_probs);
} else {
aom_tree_merge_probs(av1_segment_tree, pre_fc->seg.tree_probs,
counts->seg.tree_total, fc->seg.tree_probs);
}
for (i = 0; i < INTRA_MODES; ++i)
aom_tree_merge_probs(av1_intra_mode_tree, pre_fc->uv_mode_prob[i],
counts->uv_mode[i], fc->uv_mode_prob[i]);
#if CONFIG_EXT_PARTITION_TYPES
for (i = 0; i < PARTITION_PLOFFSET; ++i)
aom_tree_merge_probs(av1_partition_tree, pre_fc->partition_prob[i],
counts->partition[i], fc->partition_prob[i]);
for (; i < PARTITION_CONTEXTS_PRIMARY; ++i)
aom_tree_merge_probs(av1_ext_partition_tree, pre_fc->partition_prob[i],
counts->partition[i], fc->partition_prob[i]);
#else
for (i = 0; i < PARTITION_CONTEXTS_PRIMARY; ++i) {
aom_tree_merge_probs(av1_partition_tree, pre_fc->partition_prob[i],
counts->partition[i], fc->partition_prob[i]);
}
#endif // CONFIG_EXT_PARTITION_TYPES
#if CONFIG_UNPOISON_PARTITION_CTX
for (i = PARTITION_CONTEXTS_PRIMARY;
i < PARTITION_CONTEXTS_PRIMARY + PARTITION_BLOCK_SIZES; ++i) {
unsigned int ct[2] = { counts->partition[i][PARTITION_VERT],
counts->partition[i][PARTITION_SPLIT] };
assert(counts->partition[i][PARTITION_NONE] == 0);
assert(counts->partition[i][PARTITION_HORZ] == 0);
assert(fc->partition_prob[i][PARTITION_NONE] == 0);
assert(fc->partition_prob[i][PARTITION_HORZ] == 0);
fc->partition_prob[i][PARTITION_VERT] =
av1_mode_mv_merge_probs(pre_fc->partition_prob[i][PARTITION_VERT], ct);
}
for (i = PARTITION_CONTEXTS_PRIMARY + PARTITION_BLOCK_SIZES;
i < PARTITION_CONTEXTS_PRIMARY + 2 * PARTITION_BLOCK_SIZES; ++i) {
unsigned int ct[2] = { counts->partition[i][PARTITION_HORZ],
counts->partition[i][PARTITION_SPLIT] };
assert(counts->partition[i][PARTITION_NONE] == 0);
assert(counts->partition[i][PARTITION_VERT] == 0);
assert(fc->partition_prob[i][PARTITION_NONE] == 0);
assert(fc->partition_prob[i][PARTITION_VERT] == 0);
fc->partition_prob[i][PARTITION_HORZ] =
av1_mode_mv_merge_probs(pre_fc->partition_prob[i][PARTITION_HORZ], ct);
}
#endif
#if CONFIG_DELTA_Q
for (i = 0; i < DELTA_Q_PROBS; ++i)
fc->delta_q_prob[i] =
mode_mv_merge_probs(pre_fc->delta_q_prob[i], counts->delta_q[i]);
#endif
#if CONFIG_EXT_INTRA
#if CONFIG_INTRA_INTERP
for (i = 0; i < INTRA_FILTERS + 1; ++i) {
aom_tree_merge_probs(av1_intra_filter_tree, pre_fc->intra_filter_probs[i],
counts->intra_filter[i], fc->intra_filter_probs[i]);
}
#endif // CONFIG_INTRA_INTERP
#endif // CONFIG_EXT_INTRA
#if CONFIG_FILTER_INTRA
for (i = 0; i < PLANE_TYPES; ++i) {
fc->filter_intra_probs[i] = av1_mode_mv_merge_probs(
pre_fc->filter_intra_probs[i], counts->filter_intra[i]);
}
#endif // CONFIG_FILTER_INTRA
}
static void set_default_lf_deltas(struct loopfilter *lf) {
lf->mode_ref_delta_enabled = 1;
lf->mode_ref_delta_update = 1;
lf->ref_deltas[INTRA_FRAME] = 1;
lf->ref_deltas[LAST_FRAME] = 0;
#if CONFIG_EXT_REFS
lf->ref_deltas[LAST2_FRAME] = lf->ref_deltas[LAST_FRAME];
lf->ref_deltas[LAST3_FRAME] = lf->ref_deltas[LAST_FRAME];
lf->ref_deltas[BWDREF_FRAME] = lf->ref_deltas[LAST_FRAME];
#endif // CONFIG_EXT_REFS
lf->ref_deltas[GOLDEN_FRAME] = -1;
lf->ref_deltas[ALTREF_FRAME] = -1;
lf->mode_deltas[0] = 0;
lf->mode_deltas[1] = 0;
}
void av1_setup_past_independence(AV1_COMMON *cm) {
// Reset the segment feature data to the default stats:
// Features disabled, 0, with delta coding (Default state).
struct loopfilter *const lf = &cm->lf;
int i;
av1_clearall_segfeatures(&cm->seg);
cm->seg.abs_delta = SEGMENT_DELTADATA;
if (cm->last_frame_seg_map && !cm->frame_parallel_decode)
memset(cm->last_frame_seg_map, 0, (cm->mi_rows * cm->mi_cols));
if (cm->current_frame_seg_map)
memset(cm->current_frame_seg_map, 0, (cm->mi_rows * cm->mi_cols));
// Reset the mode ref deltas for loop filter
av1_zero(lf->last_ref_deltas);
av1_zero(lf->last_mode_deltas);
set_default_lf_deltas(lf);
// To force update of the sharpness
lf->last_sharpness_level = -1;
av1_default_coef_probs(cm);
init_mode_probs(cm->fc);
av1_init_mv_probs(cm);
#if CONFIG_ADAPT_SCAN
av1_init_scan_order(cm);
#endif
av1_convolve_init(cm);
cm->fc->initialized = 1;
if (cm->frame_type == KEY_FRAME || cm->error_resilient_mode ||
cm->reset_frame_context == RESET_FRAME_CONTEXT_ALL) {
// Reset all frame contexts.
for (i = 0; i < FRAME_CONTEXTS; ++i) cm->frame_contexts[i] = *cm->fc;
} else if (cm->reset_frame_context == RESET_FRAME_CONTEXT_CURRENT) {
// Reset only the frame context specified in the frame header.
cm->frame_contexts[cm->frame_context_idx] = *cm->fc;
}
// prev_mip will only be allocated in encoder.
if (frame_is_intra_only(cm) && cm->prev_mip && !cm->frame_parallel_decode)
memset(cm->prev_mip, 0,
cm->mi_stride * (cm->mi_rows + 1) * sizeof(*cm->prev_mip));
cm->frame_context_idx = 0;
}