1cabdff1aSopenharmony_ci/*
2cabdff1aSopenharmony_ci * Copyright (C) 2007 Marco Gerards <marco@gnu.org>
3cabdff1aSopenharmony_ci * Copyright (C) 2009 David Conrad
4cabdff1aSopenharmony_ci *
5cabdff1aSopenharmony_ci * This file is part of FFmpeg.
6cabdff1aSopenharmony_ci *
7cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or
8cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public
9cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either
10cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version.
11cabdff1aSopenharmony_ci *
12cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful,
13cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of
14cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
15cabdff1aSopenharmony_ci * Lesser General Public License for more details.
16cabdff1aSopenharmony_ci *
17cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public
18cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software
19cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
20cabdff1aSopenharmony_ci */
21cabdff1aSopenharmony_ci
22cabdff1aSopenharmony_ci/**
23cabdff1aSopenharmony_ci * @file
24cabdff1aSopenharmony_ci * Arithmetic decoder for Dirac
25cabdff1aSopenharmony_ci * @author Marco Gerards <marco@gnu.org>
26cabdff1aSopenharmony_ci */
27cabdff1aSopenharmony_ci
28cabdff1aSopenharmony_ci#include "dirac_arith.h"
29cabdff1aSopenharmony_ci
30cabdff1aSopenharmony_ci
31cabdff1aSopenharmony_cistatic const uint16_t dirac_prob[256] = {
32cabdff1aSopenharmony_ci    0,    2,    5,    8,    11,   15,   20,   24,
33cabdff1aSopenharmony_ci    29,   35,   41,   47,   53,   60,   67,   74,
34cabdff1aSopenharmony_ci    82,   89,   97,   106,  114,  123,  132,  141,
35cabdff1aSopenharmony_ci    150,  160,  170,  180,  190,  201,  211,  222,
36cabdff1aSopenharmony_ci    233,  244,  256,  267,  279,  291,  303,  315,
37cabdff1aSopenharmony_ci    327,  340,  353,  366,  379,  392,  405,  419,
38cabdff1aSopenharmony_ci    433,  447,  461,  475,  489,  504,  518,  533,
39cabdff1aSopenharmony_ci    548,  563,  578,  593,  609,  624,  640,  656,
40cabdff1aSopenharmony_ci    672,  688,  705,  721,  738,  754,  771,  788,
41cabdff1aSopenharmony_ci    805,  822,  840,  857,  875,  892,  910,  928,
42cabdff1aSopenharmony_ci    946,  964,  983,  1001, 1020, 1038, 1057, 1076,
43cabdff1aSopenharmony_ci    1095, 1114, 1133, 1153, 1172, 1192, 1211, 1231,
44cabdff1aSopenharmony_ci    1251, 1271, 1291, 1311, 1332, 1352, 1373, 1393,
45cabdff1aSopenharmony_ci    1414, 1435, 1456, 1477, 1498, 1520, 1541, 1562,
46cabdff1aSopenharmony_ci    1584, 1606, 1628, 1649, 1671, 1694, 1716, 1738,
47cabdff1aSopenharmony_ci    1760, 1783, 1806, 1828, 1851, 1874, 1897, 1920,
48cabdff1aSopenharmony_ci    1935, 1942, 1949, 1955, 1961, 1968, 1974, 1980,
49cabdff1aSopenharmony_ci    1985, 1991, 1996, 2001, 2006, 2011, 2016, 2021,
50cabdff1aSopenharmony_ci    2025, 2029, 2033, 2037, 2040, 2044, 2047, 2050,
51cabdff1aSopenharmony_ci    2053, 2056, 2058, 2061, 2063, 2065, 2066, 2068,
52cabdff1aSopenharmony_ci    2069, 2070, 2071, 2072, 2072, 2072, 2072, 2072,
53cabdff1aSopenharmony_ci    2072, 2071, 2070, 2069, 2068, 2066, 2065, 2063,
54cabdff1aSopenharmony_ci    2060, 2058, 2055, 2052, 2049, 2045, 2042, 2038,
55cabdff1aSopenharmony_ci    2033, 2029, 2024, 2019, 2013, 2008, 2002, 1996,
56cabdff1aSopenharmony_ci    1989, 1982, 1975, 1968, 1960, 1952, 1943, 1934,
57cabdff1aSopenharmony_ci    1925, 1916, 1906, 1896, 1885, 1874, 1863, 1851,
58cabdff1aSopenharmony_ci    1839, 1827, 1814, 1800, 1786, 1772, 1757, 1742,
59cabdff1aSopenharmony_ci    1727, 1710, 1694, 1676, 1659, 1640, 1622, 1602,
60cabdff1aSopenharmony_ci    1582, 1561, 1540, 1518, 1495, 1471, 1447, 1422,
61cabdff1aSopenharmony_ci    1396, 1369, 1341, 1312, 1282, 1251, 1219, 1186,
62cabdff1aSopenharmony_ci    1151, 1114, 1077, 1037, 995,  952,  906,  857,
63cabdff1aSopenharmony_ci    805,  750,  690,  625,  553,  471,  376,  255
64cabdff1aSopenharmony_ci};
65cabdff1aSopenharmony_ci
66cabdff1aSopenharmony_ciconst uint8_t ff_dirac_next_ctx[DIRAC_CTX_COUNT] = {
67cabdff1aSopenharmony_ci    [CTX_ZPZN_F1]   = CTX_ZP_F2,
68cabdff1aSopenharmony_ci    [CTX_ZPNN_F1]   = CTX_ZP_F2,
69cabdff1aSopenharmony_ci    [CTX_ZP_F2]     = CTX_ZP_F3,
70cabdff1aSopenharmony_ci    [CTX_ZP_F3]     = CTX_ZP_F4,
71cabdff1aSopenharmony_ci    [CTX_ZP_F4]     = CTX_ZP_F5,
72cabdff1aSopenharmony_ci    [CTX_ZP_F5]     = CTX_ZP_F6,
73cabdff1aSopenharmony_ci    [CTX_ZP_F6]     = CTX_ZP_F6,
74cabdff1aSopenharmony_ci    [CTX_NPZN_F1]   = CTX_NP_F2,
75cabdff1aSopenharmony_ci    [CTX_NPNN_F1]   = CTX_NP_F2,
76cabdff1aSopenharmony_ci    [CTX_NP_F2]     = CTX_NP_F3,
77cabdff1aSopenharmony_ci    [CTX_NP_F3]     = CTX_NP_F4,
78cabdff1aSopenharmony_ci    [CTX_NP_F4]     = CTX_NP_F5,
79cabdff1aSopenharmony_ci    [CTX_NP_F5]     = CTX_NP_F6,
80cabdff1aSopenharmony_ci    [CTX_NP_F6]     = CTX_NP_F6,
81cabdff1aSopenharmony_ci    [CTX_DELTA_Q_F] = CTX_DELTA_Q_F,
82cabdff1aSopenharmony_ci};
83cabdff1aSopenharmony_ci
84cabdff1aSopenharmony_ciint16_t ff_dirac_prob_branchless[256][2];
85cabdff1aSopenharmony_ci
86cabdff1aSopenharmony_ciav_cold void ff_dirac_init_arith_tables(void)
87cabdff1aSopenharmony_ci{
88cabdff1aSopenharmony_ci    int i;
89cabdff1aSopenharmony_ci
90cabdff1aSopenharmony_ci    for (i = 0; i < 256; i++) {
91cabdff1aSopenharmony_ci        ff_dirac_prob_branchless[i][0] =  dirac_prob[255-i];
92cabdff1aSopenharmony_ci        ff_dirac_prob_branchless[i][1] = -dirac_prob[i];
93cabdff1aSopenharmony_ci    }
94cabdff1aSopenharmony_ci}
95cabdff1aSopenharmony_ci
96cabdff1aSopenharmony_civoid ff_dirac_init_arith_decoder(DiracArith *c, GetBitContext *gb, int length)
97cabdff1aSopenharmony_ci{
98cabdff1aSopenharmony_ci    int i;
99cabdff1aSopenharmony_ci    align_get_bits(gb);
100cabdff1aSopenharmony_ci
101cabdff1aSopenharmony_ci    length = FFMIN(length, get_bits_left(gb)/8);
102cabdff1aSopenharmony_ci
103cabdff1aSopenharmony_ci    c->bytestream     = gb->buffer + get_bits_count(gb)/8;
104cabdff1aSopenharmony_ci    c->bytestream_end = c->bytestream + length;
105cabdff1aSopenharmony_ci    skip_bits_long(gb, length*8);
106cabdff1aSopenharmony_ci
107cabdff1aSopenharmony_ci    c->low = 0;
108cabdff1aSopenharmony_ci    for (i = 0; i < 4; i++) {
109cabdff1aSopenharmony_ci        c->low <<= 8;
110cabdff1aSopenharmony_ci        if (c->bytestream < c->bytestream_end)
111cabdff1aSopenharmony_ci            c->low |= *c->bytestream++;
112cabdff1aSopenharmony_ci        else
113cabdff1aSopenharmony_ci            c->low |= 0xff;
114cabdff1aSopenharmony_ci    }
115cabdff1aSopenharmony_ci
116cabdff1aSopenharmony_ci    c->counter = -16;
117cabdff1aSopenharmony_ci    c->range   = 0xffff;
118cabdff1aSopenharmony_ci    c->error   = 0;
119cabdff1aSopenharmony_ci    c->overread= 0;
120cabdff1aSopenharmony_ci
121cabdff1aSopenharmony_ci    for (i = 0; i < DIRAC_CTX_COUNT; i++)
122cabdff1aSopenharmony_ci        c->contexts[i] = 0x8000;
123cabdff1aSopenharmony_ci}
124