亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? word.c

?? 視頻編碼的碼率控制
?? C
?? 第 1 頁 / 共 2 頁
字號:
/******************************************************************************
File: 		word.c

Authors: 	John Carpinelli   (johnfc@ecr.mu.oz.au)
	 	Wayne Salamonsen  (wbs@mundil.cs.mu.oz.au)

Purpose:	Data compression using a word-based model and revised 
		arithmetic coding method.

Based on: 	A. Moffat, R. Neal, I.H. Witten, "Arithmetic Coding Revisted",
		Proc. IEEE Data Compression Conference, Snowbird, Utah, 
		March 1995.


Copyright 1995 John Carpinelli and Wayne Salamonsen, All Rights Reserved.

These programs are supplied free of charge for research purposes only,
and may not sold or incorporated into any commercial product.  There is
ABSOLUTELY NO WARRANTY of any sort, nor any undertaking that they are
fit for ANY PURPOSE WHATSOEVER.  Use them at your own risk.  If you do
happen to find a bug, or have modifications to suggest, please report
the same to Alistair Moffat, alistair@cs.mu.oz.au.  The copyright
notice above and this statement of conditions must remain an integral
part of each and every copy made of these files.

******************************************************************************/

#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <unistd.h>
#include "hashtable.h"
#include "stats.h"
#include "coder.h"
#ifdef SYSV
#include <sys/times.h>
#include <limits.h>
#endif

#define ENCODE          0
#define DECODE          1
#define	WORD		0		/* flag to process a word */
#define NON_WORD	1		/* flag to process a non-word */

#define INIT_CONTEXT	1023		/* initial size of word contexts */
#define CHAR_CONTEXT	256		/* length of character contexts */

#define BUFFER_SIZE	512		/* size of file input buffer */
#define MEGABYTE	(1 << 20)	/* size of one megabyte */

#define DEFAULT_MEM	1		/* default 1 megabyte limit */
#define MIN_MBYTES      1	       	/* minimum allowable memory size */
#define MAX_MBYTES      255		/* maximum no for 8 bit int */
#define MAGICNO         "123w"         	/* Magic Number for files */
#define MAGICNO_LENGTH	4		/* length of magic number */


/* Macro to specify what a word is */
#define ISWORD(c) (((c >= 'A') && (c <= 'Z')) || \
                   ((c >= 'a') && (c <= 'z')) || \
                   ((c >= '0') && (c <= '9')))


/* function prototypes */
void init_word_model(hash_table *tables[], context *words[]);
void purge_word_model(hash_table *tables[], context *words[]);
void init_char_model(context *characters[], context *lengths[]);
void encode_file(unsigned char tempstore[], int templength);
void decode_file();
void read_word(char buffer[], int *buffer_length, int *curr_pos, 
	       string *pWord, int type);
void print_results(int operation);


/* global variables */
int mbytes = DEFAULT_MEM; 	/* stores no. megabytes allowable for mem */
int total_memory;		/* total memory used by all models */
int base_memory;	       	/* memory used by character model */
int verbose = 0;		/* flag set if stats are to be printed */
int purge_counter=0;		/* counts number of memory purges */
unsigned int nWords[2]; 	/* counts number of words */
unsigned int nDistinctWords[2];	/* counts number of distinct words */


/* 
 * parse command line arguments. Decide whether to decode or encode
 * and optional memory size. Also sets filename to stdin if none specified 
 */
int 
main(int argc, char *argv[])
{	
    int i;			/* loop counter */
    int what = ENCODE;		/* flag as to whether to encode or decode */
    unsigned char tempstore[MAGICNO_LENGTH];	/* stores magic no */
    int templength = 0;		/* number of bytes read for magic number */
    int	selected = -1;		/* stores if decode set at command line */
    
    /*
     * parse command line arguments. Sets up whether to decode or encode
     * and optional memory limit. Also replaces stdin with input file 
     */
    for (i = 1; i < argc; ) 
    {
	if (argv[i][0] == '-') 
	{
	    switch(argv[i][1]) 
	    {
	      case 'e':		/* do encode */
		selected = ENCODE;
		i++;
		break;
	      case 'd':		/* do decode */
		selected = DECODE;
		i++;
		break;
	      case 'm':		/* set memory size */
		i++;
		mbytes = atoi(argv[i]);
		i++;
		break;
	      case 'v':		/* set verbose flag to print stats */
		verbose = 1;
		i++;
		break;
	      case 'f':		/* set number of F bits */
		i++;
		f_bits = atoi(argv[i]);
		max_frequency = 1<<f_bits;
		i++;
		break;
	      default:		/* incorrect args */
		fprintf(stderr, 
		   "Usage: %s [-e [-m n] | -d] [-v] [-f n] [file]\n", argv[0]);
		exit(1);
	    }
	}
	else if (freopen(argv[i++], "r", stdin) == (FILE *)NULL) 
	{
	    fprintf(stderr, "%s: cannot read %s\n",
		    argv[0], argv[--i]);
	    exit(1);
	}
    }
    
    /* check if memory limit is within allowable range */ 
    if (mbytes < MIN_MBYTES || mbytes > MAX_MBYTES)
    {
	fprintf(stderr, "memory limit must be between %d and %d\n", 
		MIN_MBYTES, MAX_MBYTES);
	exit(1);
    }
    
    /* check if f_bits is within allowable range */
    if (f_bits < MIN_F_BITS || f_bits > MAX_F_BITS)
    {
	fprintf(stderr, "number of f bits must be between %d and %d\n",
		MIN_F_BITS, MAX_F_BITS);
	exit(1);
    }

    /* Check input file for Magic Number. */
    if (selected != ENCODE)
    {
	templength = fread(tempstore, 1, MAGICNO_LENGTH, stdin);
        bytes_input += templength; 
	if (memcmp(tempstore, MAGICNO, MAGICNO_LENGTH) == 0)
	    what = DECODE;
	else if (selected == DECODE)
	{
	    fprintf(stderr, "Bad Magic Number\n");
	    exit(1);
	}
    }
	
    if (what == ENCODE)					/* do ENCODE */
    {
	/* write magic number to output file */
	fwrite(MAGICNO, 1, MAGICNO_LENGTH, stdout);
	bytes_output += MAGICNO_LENGTH;

	/* store memory limit being used in output */
	putc(mbytes, stdout);
	bytes_output += 1;

	/* store number of f_bits being used in output */
	putc(f_bits, stdout);
	bytes_output += 1;

	encode_file(tempstore, templength);
    }
    else						/* do DECODE */
    {
	/* read memory limit to be used and store in mbytes */
	mbytes = getc(stdin);
        bytes_input += 1;
	
	/* get number of f_bits to be used and store in f_bits */
	f_bits = getc(stdin);
	max_frequency = 1<<f_bits;
        bytes_input++;
	decode_file();
    }
    
    /* statistics section if using verbose flag */
    if (verbose)
	print_results(what);
    return 0;			/* exited cleanly */
}


/*
 *
 * print the results of compressing/decompressing a file
 *
 */
void print_results(int operation)
{
    if (operation == ENCODE)
    {
	fprintf(stderr, 
		"                              words           non-words\n");
	fprintf(stderr, "Words read             : %10u          %10u\n", 
		nWords[0], nWords[1]);
	fprintf(stderr, "Distinct words         : %10u          %10u\n",
		nDistinctWords[0], nDistinctWords[1]);
	fprintf(stderr, "Input file size        : %10u bytes\n", bytes_input);
    }
    fprintf(stderr, "Output file size       : %10u bytes\n", bytes_output);
    if (purge_counter != 0)
	fprintf(stderr, "Memory purges          : %10d times\n", purge_counter);
    if ((operation == ENCODE) && (bytes_input > 0))
	fprintf(stderr, "Compression rate       : %10.3f bpc (%0.2f%%) \n", 
		8.0 * bytes_output / bytes_input, 
		(float)bytes_output/bytes_input*100);

    /* only provide timing details if "times" function is available */
#ifdef 	SYSV
{
    struct tms cpu_usage;
    float cpu_used, comp_rate;

    times(&cpu_usage);    	/* determine the cpu time used */
    cpu_used = ((float) cpu_usage.tms_utime) / sysconf(_SC_CLK_TCK);

    if (cpu_used == 0)
	comp_rate = 0;
    else
    {
        if (operation == ENCODE)
	    comp_rate = ((float) bytes_input) / (1024 * cpu_used);
        else
	    comp_rate = ((float) bytes_output) / (1024 * cpu_used);
    }

    fprintf(stderr, "Compression time       : %10.2f seconds (%0.2f Kb/s)\n",
	    cpu_used, comp_rate);
}
#endif
}

/*
 *
 * call the standard C function realloc after checking that the memory
 * limit isn't exceeded. If limit is exceeded return NULL
 *
 */
void 
*do_realloc(void *ptr, size_t size)
{
    total_memory += size;
    if ((total_memory / MEGABYTE) >= mbytes)
	return NULL;
    else
        return (realloc(ptr, size));
}


/*
 *
 * call the standard C function malloc after checking against the memory
 * limit. If the limit is exceeded return NULL

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美视频一区二区三区四区| 亚洲图片欧美一区| 午夜久久久久久| 国产成人无遮挡在线视频| 欧美影院一区二区三区| 国产亚洲污的网站| 热久久免费视频| 色婷婷久久一区二区三区麻豆| wwww国产精品欧美| 水野朝阳av一区二区三区| 91免费版在线| 中文字幕一区二区三区色视频| 奇米色一区二区| 欧美精品一卡两卡| 亚洲综合色在线| 色综合色狠狠天天综合色| 中文字幕 久热精品 视频在线 | 国内精品久久久久影院一蜜桃| 在线视频一区二区免费| 国产精品理论片在线观看| 国产精品一区二区久激情瑜伽 | 欧美日韩极品在线观看一区| 国产精品国产三级国产| 国产成人aaaa| 国产精品少妇自拍| 国产·精品毛片| 国产精品天干天干在线综合| 国内欧美视频一区二区| 精品精品欲导航| 国产尤物一区二区| 欧美韩国日本不卡| 成人动漫在线一区| 亚洲天堂网中文字| 色哟哟一区二区| 亚洲影院免费观看| 欧美久久高跟鞋激| 美女久久久精品| 精品国产3级a| 国产.欧美.日韩| 国产欧美一区二区在线| 成人精品免费视频| 一区二区免费在线播放| 欧美亚州韩日在线看免费版国语版| 亚洲美腿欧美偷拍| 欧美日韩国产另类不卡| 男女激情视频一区| 国产丝袜欧美中文另类| eeuss鲁片一区二区三区在线观看| 18涩涩午夜精品.www| 色吊一区二区三区| 亚洲成人av一区| 欧美tickling网站挠脚心| 国产精品88888| 亚洲色图19p| 欧美电影一区二区| 国产精品一区久久久久| 亚洲精品中文在线影院| 欧美精品久久99久久在免费线| 九九九精品视频| 国产精品第13页| 7777精品伊人久久久大香线蕉最新版| 卡一卡二国产精品| 国产精品视频一区二区三区不卡| 91国产精品成人| 精品综合久久久久久8888| 国产精品嫩草影院av蜜臀| 欧美三级电影网| 国产一区欧美日韩| 亚洲最新视频在线观看| 欧美成人vr18sexvr| 91国偷自产一区二区使用方法| 美女国产一区二区三区| 亚洲品质自拍视频网站| 亚洲精品一区二区三区四区高清| 成人aa视频在线观看| 久久精品久久精品| 依依成人综合视频| 亚洲免费资源在线播放| 欧美一级国产精品| 日本韩国欧美一区| 国产精品一区专区| 首页国产欧美久久| 亚洲三级在线看| 久久婷婷久久一区二区三区| 欧美午夜精品一区| 成人av在线播放网址| 蜜桃视频一区二区三区在线观看| 亚洲女子a中天字幕| 国产偷国产偷亚洲高清人白洁| 91精品国产综合久久久久| 91免费视频网| 成人一区二区三区视频| 久久精品国产一区二区三| 亚洲制服丝袜av| 中文字幕中文字幕在线一区 | 久久99久久99| 日韩国产在线一| 亚洲日本韩国一区| 国产精品久久久久aaaa| 26uuu国产电影一区二区| 91精品国产综合久久久蜜臀粉嫩 | 久久久久久日产精品| 555www色欧美视频| 欧美视频在线观看一区二区| 成人国产精品免费网站| 粉嫩高潮美女一区二区三区| 精品一区二区三区免费视频| 五月婷婷综合网| 午夜视频一区二区| 天天综合天天做天天综合| 一区二区三区中文在线| 亚洲人精品午夜| 自拍av一区二区三区| 国产精品传媒入口麻豆| 国产精品九色蝌蚪自拍| 国产精品乱码妇女bbbb| 国产亚洲综合av| 国产日韩一级二级三级| 欧美高清在线一区| 中文字幕亚洲区| 亚洲人成在线播放网站岛国| 亚洲欧美日韩小说| 亚洲一区二区三区中文字幕 | 91精品国产综合久久蜜臀| 日韩一区二区在线免费观看| 日韩欧美一区二区免费| 久久这里只有精品视频网| 久久久久青草大香线综合精品| 中文字幕精品三区| 亚洲欧美激情在线| 日韩专区中文字幕一区二区| 久久99久久精品| 成人动漫视频在线| 欧美无砖砖区免费| 日韩区在线观看| 国产精品婷婷午夜在线观看| 一区二区三区中文字幕电影| 风间由美一区二区三区在线观看| 成人av在线网站| 欧美三级电影网| 久久人人97超碰com| 亚洲欧洲精品一区二区三区不卡| 一区二区三区四区精品在线视频 | 国产一区二区三区| 色综合夜色一区| 欧美精品一二三| 久久久国产综合精品女国产盗摄| 中文字幕中文乱码欧美一区二区| 亚洲一区二区三区视频在线| 久久精品国产99国产精品| av中文字幕一区| 欧美一级理论片| 国产精品国产三级国产aⅴ无密码| 香蕉影视欧美成人| 国产成人精品www牛牛影视| 91久久久免费一区二区| 久久久五月婷婷| 亚洲小说欧美激情另类| 国产一区免费电影| 欧美日韩免费一区二区三区视频| 久久久久久影视| 日韩在线观看一区二区| 不卡一卡二卡三乱码免费网站| 欧美精品视频www在线观看| 国产精品午夜在线观看| 另类小说欧美激情| 91久久人澡人人添人人爽欧美 | 粉嫩高潮美女一区二区三区| 欧美精品高清视频| 综合在线观看色| 国产成人综合网站| 欧美成人三级电影在线| 一级精品视频在线观看宜春院| 国产精品亚洲人在线观看| 久久精品人人做人人综合| 五月婷婷另类国产| 色婷婷av一区| 国产精品国产三级国产有无不卡 | 自拍偷拍欧美激情| 国产成人av网站| 欧美变态tickle挠乳网站| 亚洲v中文字幕| 一本一道久久a久久精品 | 天天综合天天做天天综合| 91麻豆精东视频| 国产精品欧美一级免费| 国产一区激情在线| 欧美成va人片在线观看| 美腿丝袜在线亚洲一区| 欧美理论电影在线| 天天亚洲美女在线视频| 欧美优质美女网站| 一区二区三区精品视频在线| 成人av资源下载| 亚洲欧美电影一区二区| 色婷婷精品久久二区二区蜜臂av| 中文字幕一区二区三区在线观看| 成人h动漫精品一区二区| 国产农村妇女精品| www.色精品|