annotate ffmpeg/libavcodec/golomb-test.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 * Copyright (c) 2003 Michael Niedermayer <michaelni@gmx.at>
yading@10 3 *
yading@10 4 * This file is part of FFmpeg.
yading@10 5 *
yading@10 6 * FFmpeg is free software; you can redistribute it and/or
yading@10 7 * modify it under the terms of the GNU Lesser General Public
yading@10 8 * License as published by the Free Software Foundation; either
yading@10 9 * version 2.1 of the License, or (at your option) any later version.
yading@10 10 *
yading@10 11 * FFmpeg is distributed in the hope that it will be useful,
yading@10 12 * but WITHOUT ANY WARRANTY; without even the implied warranty of
yading@10 13 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
yading@10 14 * Lesser General Public License for more details.
yading@10 15 *
yading@10 16 * You should have received a copy of the GNU Lesser General Public
yading@10 17 * License along with FFmpeg; if not, write to the Free Software
yading@10 18 * Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA
yading@10 19 */
yading@10 20
yading@10 21 #include <stdint.h>
yading@10 22 #include <stdio.h>
yading@10 23
yading@10 24 #include "libavutil/mem.h"
yading@10 25
yading@10 26 #include "get_bits.h"
yading@10 27 #include "golomb.h"
yading@10 28 #include "put_bits.h"
yading@10 29
yading@10 30 #define COUNT 8191
yading@10 31 #define SIZE (COUNT * 4)
yading@10 32
yading@10 33 int main(void)
yading@10 34 {
yading@10 35 int i, ret = 0;
yading@10 36 uint8_t *temp;
yading@10 37 PutBitContext pb;
yading@10 38 GetBitContext gb;
yading@10 39
yading@10 40 temp = av_malloc(SIZE);
yading@10 41 if (!temp)
yading@10 42 return 2;
yading@10 43
yading@10 44 init_put_bits(&pb, temp, SIZE);
yading@10 45 for (i = 0; i < COUNT; i++)
yading@10 46 set_ue_golomb(&pb, i);
yading@10 47 flush_put_bits(&pb);
yading@10 48
yading@10 49 init_get_bits(&gb, temp, 8 * SIZE);
yading@10 50 for (i = 0; i < COUNT; i++) {
yading@10 51 int j, s = show_bits(&gb, 25);
yading@10 52
yading@10 53 j = get_ue_golomb(&gb);
yading@10 54 if (j != i) {
yading@10 55 fprintf(stderr, "get_ue_golomb: expected %d, got %d. bits: %7x\n",
yading@10 56 i, j, s);
yading@10 57 ret = 1;
yading@10 58 }
yading@10 59 }
yading@10 60
yading@10 61 #define EXTEND(i) (i << 3 | i & 7)
yading@10 62 init_put_bits(&pb, temp, SIZE);
yading@10 63 for (i = 0; i < COUNT; i++)
yading@10 64 set_ue_golomb(&pb, EXTEND(i));
yading@10 65 flush_put_bits(&pb);
yading@10 66
yading@10 67 init_get_bits(&gb, temp, 8 * SIZE);
yading@10 68 for (i = 0; i < COUNT; i++) {
yading@10 69 int j, s = show_bits_long(&gb, 32);
yading@10 70
yading@10 71 j = get_ue_golomb_long(&gb);
yading@10 72 if (j != EXTEND(i)) {
yading@10 73 fprintf(stderr, "get_ue_golomb_long: expected %d, got %d. "
yading@10 74 "bits: %8x\n", EXTEND(i), j, s);
yading@10 75 ret = 1;
yading@10 76 }
yading@10 77 }
yading@10 78
yading@10 79 init_put_bits(&pb, temp, SIZE);
yading@10 80 for (i = 0; i < COUNT; i++)
yading@10 81 set_se_golomb(&pb, i - COUNT / 2);
yading@10 82 flush_put_bits(&pb);
yading@10 83
yading@10 84 init_get_bits(&gb, temp, 8 * SIZE);
yading@10 85 for (i = 0; i < COUNT; i++) {
yading@10 86 int j, s = show_bits(&gb, 25);
yading@10 87
yading@10 88 j = get_se_golomb(&gb);
yading@10 89 if (j != i - COUNT / 2) {
yading@10 90 fprintf(stderr, "get_se_golomb: expected %d, got %d. bits: %7x\n",
yading@10 91 i - COUNT / 2, j, s);
yading@10 92 ret = 1;
yading@10 93 }
yading@10 94 }
yading@10 95
yading@10 96 av_free(temp);
yading@10 97
yading@10 98 return ret;
yading@10 99 }