⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 vlc.c

📁 图象压缩程序
💻 C
字号:
/***************************************************************************** * vlc.c: VLC lookup table generation. ***************************************************************************** * Copyright (C) 2003 Laurent Aimar * $Id: vlc.c,v 1.1.1.1 2003/11/09 23:23:22 fenrir Exp $ * * Authors: Laurent Aimar <fenrir@via.ecp.fr> * * This program is free software; you can redistribute it and/or modify * it under the terms of the GNU General Public License as published by * the Free Software Foundation; either version 2 of the License, or * (at your option) any later version. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place - Suite 330, Boston, MA  02111, USA. *****************************************************************************/#include <stdlib.h>#include <stdio.h>#include <inttypes.h>#include "../core/common.h"#include "../core/vlc.h"#include "vlc.h"static int  vlc_table_realloc( x264_vlc_table_t *table, int i_size ){    int i_index;    i_index = table->i_lookup;    table->i_lookup += i_size;    table->lookup = x264_realloc( table->lookup, sizeof( vlc_lookup_t ) * table->i_lookup );    return( i_index );}static int vlc_table_create_part( x264_vlc_table_t *table, const vlc_t *vlc, int i_lookup_bits, int i_nb_vlc, int i_prefix_code, int i_prefix_length ){    int i;    int i_nb_lookup;    vlc_lookup_t *lookup;    int i_table_index;    i_nb_lookup = 1 << i_lookup_bits;    i_table_index = vlc_table_realloc( table, i_nb_lookup );    lookup = &table->lookup[i_table_index];    for( i = 0; i < i_nb_lookup; i++ )    {        lookup[i].i_value  = -1;        lookup[i].i_size = 0;    }    for( i = 0; i < i_nb_vlc; i++ )    {        int i_bits;        if( vlc[i].i_size <= 0 )        {            continue;        }        i_bits = vlc[i].i_size - i_prefix_length;        if( i_bits > 0 && ( vlc[i].i_bits >> i_bits ) == i_prefix_code )        {            if( i_bits <= i_lookup_bits )            {                int i_lookup_index;                int nb;                i_lookup_index = ( vlc[i].i_bits << ( i_lookup_bits - i_bits ) )%i_nb_lookup;                nb = 1 << ( i_lookup_bits - i_bits );                for( nb = 0; nb < (1 << ( i_lookup_bits - i_bits)); nb++ )                {                    lookup[i_lookup_index].i_value = i; /* vlc[i].i_value; */                    lookup[i_lookup_index].i_size = i_bits;                    i_lookup_index++;                }            }            else            {                int i_bits_max;                int i_lookup_index;                /* need another table */                i_lookup_index = ( vlc[i].i_bits >> (i_bits - i_lookup_bits ) )%i_nb_lookup;                i_bits_max =  -lookup[i_lookup_index].i_size;                if( i_bits_max < i_bits - i_lookup_bits )                {                    i_bits_max = i_bits - i_lookup_bits;                }                lookup[i_lookup_index].i_size = -i_bits_max;            }        }    }    /* create other level table */    for( i = 0; i < i_nb_lookup; i++ )    {        if( lookup[i].i_size < 0 )        {            int i_bits;            int i_index;            i_bits = -lookup[i].i_size;            if( i_bits > i_lookup_bits )            {                lookup[i].i_size = -i_lookup_bits;                i_bits = i_lookup_bits;            }            i_index = vlc_table_create_part( table, vlc, i_bits, i_nb_vlc,                                             (i_prefix_code << i_lookup_bits)|i,                                              i_lookup_bits+i_prefix_length );            lookup = &table->lookup[i_table_index]; // reallocated            lookup[i].i_value = i_index;        }    }    return( i_table_index );}x264_vlc_table_t *x264_vlc_table_lookup_new( const vlc_t *vlc, int i_vlc, int i_lookup_bits ){    x264_vlc_table_t *table = x264_malloc( sizeof( x264_vlc_table_t ) );    table->i_lookup_bits = i_lookup_bits;    table->i_lookup = 0;    table->lookup   = NULL;    vlc_table_create_part( table, vlc, i_lookup_bits, i_vlc, 0, 0 );    return table;}void x264_vlc_table_lookup_delete( x264_vlc_table_t *table ){    x264_free( table->lookup );    x264_free( table );}#if 0void x264_vlc_table_lookup_print( x264_vlc_table_t *table ){    int idx;    fprintf( stderr, "       " );    for( idx = 0; idx < table->i_lookup; idx++ )    {        if( table->lookup[idx].i_value == -1 )        {            fprintf( stderr, " MKVLCLU(    -1,  0 )," );        }        else        {            fprintf( stderr, " MKVLCLU( 0x%.3x, % 2d ),", table->lookup[idx].i_value, table->lookup[idx].i_size );        }        if( (idx+1)%4 == 0 && idx < table->i_lookup - 1)        {            fprintf( stderr, "\n       " );        }    }    fprintf( stderr, "\n" );}int main(void){    int i;    x264_vlc_table_t *table;    printf( "typedef struct\n    int i_value;\n    int i_size;\n} vlc_lookup_t;\n\n#define MKVLCLU(a,b) { .i_value=a, .i_size=b}" );    /* create vlc  entry table and then vlc_lookup_t table */    /* x264_coeff_token */    fprintf( stderr, "static const vlc_lookup_t x264_coeff_token_lookup[5][]=\n{\n" );    for( i = 0; i < 5; i++ )    {        fprintf( stderr, "    {\n" );        table = x264_vlc_table_lookup_new( x264_coeff_token[i], 17*4, 6 );        x264_vlc_table_lookup_print( table );        x264_vlc_table_lookup_delete( table );        fprintf( stderr, "    },\n" );    }    fprintf( stderr, "};\n" );#if 0    vlce = convert_vlc_to_vlce( x264_level_prefix, 16 );    do_vlc_table_create( vlce, 16, "x264_level_prefix_lookup", 8 );    free( vlce );    for( i_table = 0; i_table < 15; i_table++ )    {        char name[512];        vlce = convert_vlc_to_vlce( x264_total_zeros[i_table], 16 );        sprintf( name, "x264_total_zeros_%d", i_table );        do_vlc_table_create( vlce, 16, name, 6 );        free( vlce );    }    for( i_table = 0; i_table < 3; i_table++ )    {        char name[512];        vlce = convert_vlc_to_vlce( x264_total_zeros_dc[i_table], 4 );        sprintf( name, "x264_total_zeros_dc_%d", i_table );        do_vlc_table_create( vlce, 4, name, 3 );        free( vlce );    }    for( i_table = 0; i_table < 7; i_table++ )    {        char name[512];        vlce = convert_vlc_to_vlce( x264_run_before[i_table], 15 );        sprintf( name, "x264_run_before_%d", i_table );        do_vlc_table_create( vlce, 15, name, 6 );        free( vlce );    }#endif    return 0;}#endif

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -