annotate ffmpeg/libavcodec/lagarithrac.c @ 13:844d341cf643 tip

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