1cabdff1aSopenharmony_ci/* 2cabdff1aSopenharmony_ci * Lagarith range decoder 3cabdff1aSopenharmony_ci * Copyright (c) 2009 Nathan Caldwell <saintdev (at) gmail.com> 4cabdff1aSopenharmony_ci * Copyright (c) 2009 David Conrad 5cabdff1aSopenharmony_ci * 6cabdff1aSopenharmony_ci * This file is part of FFmpeg. 7cabdff1aSopenharmony_ci * 8cabdff1aSopenharmony_ci * FFmpeg is free software; you can redistribute it and/or 9cabdff1aSopenharmony_ci * modify it under the terms of the GNU Lesser General Public 10cabdff1aSopenharmony_ci * License as published by the Free Software Foundation; either 11cabdff1aSopenharmony_ci * version 2.1 of the License, or (at your option) any later version. 12cabdff1aSopenharmony_ci * 13cabdff1aSopenharmony_ci * FFmpeg is distributed in the hope that it will be useful, 14cabdff1aSopenharmony_ci * but WITHOUT ANY WARRANTY; without even the implied warranty of 15cabdff1aSopenharmony_ci * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU 16cabdff1aSopenharmony_ci * Lesser General Public License for more details. 17cabdff1aSopenharmony_ci * 18cabdff1aSopenharmony_ci * You should have received a copy of the GNU Lesser General Public 19cabdff1aSopenharmony_ci * License along with FFmpeg; if not, write to the Free Software 20cabdff1aSopenharmony_ci * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA 21cabdff1aSopenharmony_ci */ 22cabdff1aSopenharmony_ci 23cabdff1aSopenharmony_ci/** 24cabdff1aSopenharmony_ci * @file 25cabdff1aSopenharmony_ci * Lagarith range decoder 26cabdff1aSopenharmony_ci * @author Nathan Caldwell 27cabdff1aSopenharmony_ci * @author David Conrad 28cabdff1aSopenharmony_ci */ 29cabdff1aSopenharmony_ci 30cabdff1aSopenharmony_ci#include "get_bits.h" 31cabdff1aSopenharmony_ci#include "lagarithrac.h" 32cabdff1aSopenharmony_ci 33cabdff1aSopenharmony_civoid ff_lag_rac_init(lag_rac *l, GetBitContext *gb, int length) 34cabdff1aSopenharmony_ci{ 35cabdff1aSopenharmony_ci int i, j, left; 36cabdff1aSopenharmony_ci 37cabdff1aSopenharmony_ci /* According to reference decoder "1st byte is garbage", 38cabdff1aSopenharmony_ci * however, it gets skipped by the call to align_get_bits() 39cabdff1aSopenharmony_ci */ 40cabdff1aSopenharmony_ci align_get_bits(gb); 41cabdff1aSopenharmony_ci left = get_bits_left(gb) >> 3; 42cabdff1aSopenharmony_ci l->bytestream_start = 43cabdff1aSopenharmony_ci l->bytestream = gb->buffer + get_bits_count(gb) / 8; 44cabdff1aSopenharmony_ci l->bytestream_end = l->bytestream_start + left; 45cabdff1aSopenharmony_ci 46cabdff1aSopenharmony_ci l->range = 0x80; 47cabdff1aSopenharmony_ci l->low = *l->bytestream >> 1; 48cabdff1aSopenharmony_ci l->hash_shift = FFMAX(l->scale, 10) - 10; 49cabdff1aSopenharmony_ci l->overread = 0; 50cabdff1aSopenharmony_ci 51cabdff1aSopenharmony_ci for (i = j = 0; i < 1024; i++) { 52cabdff1aSopenharmony_ci unsigned r = i << l->hash_shift; 53cabdff1aSopenharmony_ci while (l->prob[j + 1] <= r) 54cabdff1aSopenharmony_ci j++; 55cabdff1aSopenharmony_ci l->range_hash[i] = j; 56cabdff1aSopenharmony_ci } 57cabdff1aSopenharmony_ci} 58