source: SHVCSoftware/trunk/source/Lib/TLibCommon/ContextTables.h @ 460

Last change on this file since 460 was 345, checked in by seregin, 11 years ago

merge SHM-3.0-dev branch

  • Property svn:eol-style set to native
File size: 11.3 KB
Line 
1/* The copyright in this software is being made available under the BSD
2 * License, included below. This software may be subject to other third party
3 * and contributor rights, including patent rights, and no such rights are
4 * granted under this license. 
5 *
6 * Copyright (c) 2010-2013, ITU/ISO/IEC
7 * All rights reserved.
8 *
9 * Redistribution and use in source and binary forms, with or without
10 * modification, are permitted provided that the following conditions are met:
11 *
12 *  * Redistributions of source code must retain the above copyright notice,
13 *    this list of conditions and the following disclaimer.
14 *  * Redistributions in binary form must reproduce the above copyright notice,
15 *    this list of conditions and the following disclaimer in the documentation
16 *    and/or other materials provided with the distribution.
17 *  * Neither the name of the ITU/ISO/IEC nor the names of its contributors may
18 *    be used to endorse or promote products derived from this software without
19 *    specific prior written permission.
20 *
21 * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
22 * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
23 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
24 * ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS
25 * BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
26 * CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
27 * SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
28 * INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
29 * CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
30 * ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF
31 * THE POSSIBILITY OF SUCH DAMAGE.
32 */
33
34/** \file     ContextTables.h
35    \brief    Defines constants and tables for SBAC
36    \todo     number of context models is not matched to actual use, should be fixed
37*/
38
39#ifndef __CONTEXTTABLES__
40#define __CONTEXTTABLES__
41
42//! \ingroup TLibCommon
43//! \{
44#define FIX827 1 ///< Fix for issue #827: CABAC init tables
45#define FIX712 1 ///< Fix for issue #712: CABAC init tables
46
47// ====================================================================================================================
48// Constants
49// ====================================================================================================================
50
51#define MAX_NUM_CTX_MOD             512       ///< maximum number of supported contexts
52
53#define NUM_SPLIT_FLAG_CTX            3       ///< number of context models for split flag
54#define NUM_SKIP_FLAG_CTX             3       ///< number of context models for skip flag
55
56#define NUM_MERGE_FLAG_EXT_CTX        1       ///< number of context models for merge flag of merge extended
57#define NUM_MERGE_IDX_EXT_CTX         1       ///< number of context models for merge index of merge extended
58
59#define NUM_PART_SIZE_CTX             4       ///< number of context models for partition size
60#define NUM_CU_AMP_CTX                1       ///< number of context models for partition size (AMP)
61#define NUM_PRED_MODE_CTX             1       ///< number of context models for prediction mode
62
63#define NUM_ADI_CTX                   1       ///< number of context models for intra prediction
64
65#define NUM_CHROMA_PRED_CTX           2       ///< number of context models for intra prediction (chroma)
66#define NUM_INTER_DIR_CTX             5       ///< number of context models for inter prediction direction
67#define NUM_MV_RES_CTX                2       ///< number of context models for motion vector difference
68
69#define NUM_REF_NO_CTX                2       ///< number of context models for reference index
70#define NUM_TRANS_SUBDIV_FLAG_CTX     3       ///< number of context models for transform subdivision flags
71#define NUM_QT_CBF_CTX                5       ///< number of context models for QT CBF
72#define NUM_QT_ROOT_CBF_CTX           1       ///< number of context models for QT ROOT CBF
73#define NUM_DELTA_QP_CTX              3       ///< number of context models for dQP
74
75#define NUM_SIG_CG_FLAG_CTX           2       ///< number of context models for MULTI_LEVEL_SIGNIFICANCE
76
77#define NUM_SIG_FLAG_CTX              42      ///< number of context models for sig flag
78#define NUM_SIG_FLAG_CTX_LUMA         27      ///< number of context models for luma sig flag
79#define NUM_SIG_FLAG_CTX_CHROMA       15      ///< number of context models for chroma sig flag
80
81#define NUM_CTX_LAST_FLAG_XY          15      ///< number of context models for last coefficient position
82
83#define NUM_ONE_FLAG_CTX              24      ///< number of context models for greater than 1 flag
84#define NUM_ONE_FLAG_CTX_LUMA         16      ///< number of context models for greater than 1 flag of luma
85#define NUM_ONE_FLAG_CTX_CHROMA        8      ///< number of context models for greater than 1 flag of chroma
86#define NUM_ABS_FLAG_CTX               6      ///< number of context models for greater than 2 flag
87#define NUM_ABS_FLAG_CTX_LUMA          4      ///< number of context models for greater than 2 flag of luma
88#define NUM_ABS_FLAG_CTX_CHROMA        2      ///< number of context models for greater than 2 flag of chroma
89
90#define NUM_MVP_IDX_CTX               2       ///< number of context models for MVP index
91
92#define NUM_SAO_MERGE_FLAG_CTX        1       ///< number of context models for SAO merge flags
93#define NUM_SAO_TYPE_IDX_CTX          1       ///< number of context models for SAO type index
94
95#define NUM_TRANSFORMSKIP_FLAG_CTX    1       ///< number of context models for transform skipping
96#define NUM_CU_TRANSQUANT_BYPASS_FLAG_CTX  1
97#define CNU                          154      ///< dummy initialization value for unused context models 'Context model Not Used'
98
99// ====================================================================================================================
100// Tables
101// ====================================================================================================================
102
103// initial probability for cu_transquant_bypass flag
104static const UChar
105INIT_CU_TRANSQUANT_BYPASS_FLAG[3][NUM_CU_TRANSQUANT_BYPASS_FLAG_CTX] =
106{
107  { 154 }, 
108  { 154 }, 
109  { 154 }, 
110};
111
112// initial probability for split flag
113static const UChar
114INIT_SPLIT_FLAG[3][NUM_SPLIT_FLAG_CTX] = 
115{
116  { 107,  139,  126, },
117  { 107,  139,  126, }, 
118  { 139,  141,  157, }, 
119};
120
121static const UChar
122INIT_SKIP_FLAG[3][NUM_SKIP_FLAG_CTX] = 
123{
124  { 197,  185,  201, }, 
125  { 197,  185,  201, }, 
126  { CNU,  CNU,  CNU, }, 
127};
128
129static const UChar
130INIT_MERGE_FLAG_EXT[3][NUM_MERGE_FLAG_EXT_CTX] = 
131{
132  { 154, }, 
133  { 110, }, 
134  { CNU, }, 
135};
136
137static const UChar
138INIT_MERGE_IDX_EXT[3][NUM_MERGE_IDX_EXT_CTX] = 
139{
140  { 137, }, 
141  { 122, }, 
142  { CNU, }, 
143};
144
145static const UChar
146INIT_PART_SIZE[3][NUM_PART_SIZE_CTX] = 
147{
148  { 154,  139,  CNU,  CNU, }, 
149  { 154,  139,  CNU,  CNU, }, 
150  { 184,  CNU,  CNU,  CNU, }, 
151};
152
153static const UChar
154INIT_CU_AMP_POS[3][NUM_CU_AMP_CTX] = 
155{
156  { 154, }, 
157  { 154, }, 
158  { CNU, }, 
159};
160
161static const UChar
162INIT_PRED_MODE[3][NUM_PRED_MODE_CTX] = 
163{
164  { 134, }, 
165  { 149, }, 
166  { CNU, }, 
167};
168
169static const UChar
170INIT_INTRA_PRED_MODE[3][NUM_ADI_CTX] = 
171{
172  { 183, }, 
173  { 154, }, 
174  { 184, }, 
175};
176
177static const UChar
178INIT_CHROMA_PRED_MODE[3][NUM_CHROMA_PRED_CTX] = 
179{
180  { 152,  139, }, 
181  { 152,  139, }, 
182  {  63,  139, }, 
183};
184
185static const UChar
186INIT_INTER_DIR[3][NUM_INTER_DIR_CTX] = 
187{
188  {  95,   79,   63,   31,  31, }, 
189  {  95,   79,   63,   31,  31, }, 
190  { CNU,  CNU,  CNU,  CNU, CNU, }, 
191};
192
193static const UChar
194INIT_MVD[3][NUM_MV_RES_CTX] = 
195{
196  { 169,  198, }, 
197  { 140,  198, }, 
198  { CNU,  CNU, }, 
199};
200
201static const UChar
202INIT_REF_PIC[3][NUM_REF_NO_CTX] = 
203{
204  { 153,  153 }, 
205  { 153,  153 }, 
206  { CNU,  CNU }, 
207};
208
209static const UChar
210INIT_DQP[3][NUM_DELTA_QP_CTX] = 
211{
212  { 154,  154,  154, }, 
213  { 154,  154,  154, }, 
214  { 154,  154,  154, }, 
215};
216
217static const UChar
218INIT_QT_CBF[3][2*NUM_QT_CBF_CTX] = 
219{
220  { 153,  111,  CNU,  CNU,  CNU,  149,   92,  167,  CNU,  CNU, }, 
221  { 153,  111,  CNU,  CNU,  CNU,  149,  107,  167,  CNU,  CNU, }, 
222  { 111,  141,  CNU,  CNU,  CNU,   94,  138,  182,  CNU,  CNU, }, 
223};
224
225static const UChar
226INIT_QT_ROOT_CBF[3][NUM_QT_ROOT_CBF_CTX] = 
227{
228  {  79, }, 
229  {  79, }, 
230  { CNU, }, 
231};
232
233static const UChar
234INIT_LAST[3][2*NUM_CTX_LAST_FLAG_XY] = 
235{
236  { 125,  110,  124,  110,   95,   94,  125,  111,  111,   79,  125,  126,  111,  111,   79,
237    108,  123,   93,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU, 
238  }, 
239  { 125,  110,   94,  110,   95,   79,  125,  111,  110,   78,  110,  111,  111,   95,   94,
240    108,  123,  108,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,
241  }, 
242  { 110,  110,  124,  125,  140,  153,  125,  127,  140,  109,  111,  143,  127,  111,   79, 
243    108,  123,   63,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU,  CNU, 
244  }, 
245};
246
247static const UChar
248INIT_SIG_CG_FLAG[3][2 * NUM_SIG_CG_FLAG_CTX] = 
249{
250  { 121,  140, 
251    61,  154, 
252  }, 
253  { 121,  140, 
254    61,  154, 
255  }, 
256  {  91,  171, 
257    134,  141, 
258  }, 
259};
260
261static const UChar
262INIT_SIG_FLAG[3][NUM_SIG_FLAG_CTX] = 
263{
264  { 170,  154,  139,  153,  139,  123,  123,   63,  124,  166,  183,  140,  136,  153,  154,  166,  183,  140,  136,  153,  154,  166,  183,  140,  136,  153,  154,  170,  153,  138,  138,  122,  121,  122,  121,  167,  151,  183,  140,  151,  183,  140,  }, 
265  { 155,  154,  139,  153,  139,  123,  123,   63,  153,  166,  183,  140,  136,  153,  154,  166,  183,  140,  136,  153,  154,  166,  183,  140,  136,  153,  154,  170,  153,  123,  123,  107,  121,  107,  121,  167,  151,  183,  140,  151,  183,  140,  }, 
266  { 111,  111,  125,  110,  110,   94,  124,  108,  124,  107,  125,  141,  179,  153,  125,  107,  125,  141,  179,  153,  125,  107,  125,  141,  179,  153,  125,  140,  139,  182,  182,  152,  136,  152,  136,  153,  136,  139,  111,  136,  139,  111,  }, 
267};
268
269static const UChar
270INIT_ONE_FLAG[3][NUM_ONE_FLAG_CTX] = 
271{
272  { 154,  196,  167,  167,  154,  152,  167,  182,  182,  134,  149,  136,  153,  121,  136,  122,  169,  208,  166,  167,  154,  152,  167,  182, }, 
273  { 154,  196,  196,  167,  154,  152,  167,  182,  182,  134,  149,  136,  153,  121,  136,  137,  169,  194,  166,  167,  154,  167,  137,  182, }, 
274  { 140,   92,  137,  138,  140,  152,  138,  139,  153,   74,  149,   92,  139,  107,  122,  152,  140,  179,  166,  182,  140,  227,  122,  197, }, 
275};
276
277static const UChar
278INIT_ABS_FLAG[3][NUM_ABS_FLAG_CTX] = 
279{
280  { 107,  167,   91,  107,  107,  167, }, 
281  { 107,  167,   91,  122,  107,  167, }, 
282  { 138,  153,  136,  167,  152,  152, }, 
283};
284
285static const UChar
286INIT_MVP_IDX[3][NUM_MVP_IDX_CTX] = 
287{
288  { 168,  CNU, }, 
289  { 168,  CNU, }, 
290  { CNU,  CNU, }, 
291};
292
293static const UChar
294INIT_SAO_MERGE_FLAG[3][NUM_SAO_MERGE_FLAG_CTX] = 
295{
296  { 153,  }, 
297  { 153,  }, 
298  { 153,  }, 
299};
300
301static const UChar
302INIT_SAO_TYPE_IDX[3][NUM_SAO_TYPE_IDX_CTX] = 
303{
304#if FIX827
305  { 160, },
306  { 185, },
307  { 200, },
308#else
309  { 200, },
310  { 185, }, 
311  { 160, },
312#endif
313};
314
315static const UChar
316INIT_TRANS_SUBDIV_FLAG[3][NUM_TRANS_SUBDIV_FLAG_CTX] =
317{
318#if FIX712
319  { 224,  167,  122, },
320  { 124,  138,   94, },
321  { 153,  138,  138, },
322#else
323  { 153,  138,  138, },
324  { 124,  138,   94, },
325  { 224,  167,  122, },
326#endif
327};
328
329static const UChar
330INIT_TRANSFORMSKIP_FLAG[3][2*NUM_TRANSFORMSKIP_FLAG_CTX] = 
331{
332  { 139,  139}, 
333  { 139,  139}, 
334  { 139,  139}, 
335};
336//! \}
337
338
339#endif
Note: See TracBrowser for help on using the repository browser.