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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? arithmeticcoder.cpp

?? 有關(guān)幾個(gè)數(shù)字編碼的C++ 程序
?? CPP
字號(hào):
// ArithmeticCoder.cpp: implementation of the CArithmeticCoder class.
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
#include "ArithmeticCoder.h"
#include "bitio.h"

//--------------------------------------------------------------
//---------------Construction/Destruction-----------------------
CArithmeticCoder::CArithmeticCoder()
{
	name_filein = "g:\\mine.doc";
	name_fileout = "g:\\mine.out";

	m_pModel = new CModel;
	m_pBitIO = new CBitIO;

}

CArithmeticCoder::~CArithmeticCoder()
{
	delete m_pModel;
	delete m_pBitIO;
}
//===============================================================

//---------------------------------------------------------------
//------- output bits plus following opposite bits---------------
void CArithmeticCoder::bit_plus_follow(int bit)
{
	m_pBitIO->output_bit(bit);
	while(bits_to_follow>0)
	{
		m_pBitIO->output_bit(!bit);
		bits_to_follow -= 1;
	}
}
//================================================================

//----------------------------------------------------------------
//-------------start encoding a stream of symbols-----------------
void CArithmeticCoder::start_encoding()
{
	low = 0;
	high = top_value;
	bits_to_follow = 0;
}
//================================================================

//----------------------------------------------------------------
//----------------encode a symbol---------------------------------
void CArithmeticCoder::encode_symbol(int symbol, int cum_freq[])
{
	long range;
	range = (long)(high-low)+1;
	
	// narrow the code region to that allotted to this symbol
 	high = low + (range*cum_freq[symbol-1])/cum_freq[0]-1;
	low = low + (range*cum_freq[symbol])/cum_freq[0];
	for(;;)
	{
		if ( high < half )
		{
			bit_plus_follow(0);	// output 0 in low half
		}
		else if ( low >= half )		// output 1 in high half
		{
			bit_plus_follow(1);
			low -= half;
			high -= half;
		}
		else if ( low >= first_qtr && high < third_qtr )
		{
			bits_to_follow += 1;
			low -= first_qtr;
			high -= first_qtr;
		}
		else
			break;
		low = 2*low;
		high = 2*high + 1;
	}
}
//================================================================

//----------------------------------------------------------------
//---------------finish encoding the stream-----------------------
void CArithmeticCoder::done_encoding()
{
	bits_to_follow += 1;
	if ( low < first_qtr )
		bits_to_follow = 0;
	else
		bits_to_follow = 1;
}
//================================================================

//----------------------------------------------------------------
//--------------------start the coding----------------------------
void CArithmeticCoder::start_decoding()
{
	int i; 
	value = 0; 
	for(i=1; i<=Code_value_bits; i++)
	{ 
		value = 2*value+m_pBitIO->input_bit();
	}
	low = 0; 
	high = top_value; 
}
//================================================================

//----------------------------------------------------------------
//----------------decode the next symbol--------------------------
int CArithmeticCoder::decode_symbol(int cum_freq[])
{ 
	long range; 
	int cum;
	int symbol;
	range = (long) (high-low) + 1;
	cum = (((long)(value-low)+1)*cum_freq[0]-1)/range; 
	// boring linear search
	for(symbol=1; cum_freq[symbol]>cum; symbol++)
	{ ; } 
	high = low + (range*cum_freq[symbol-1])/cum_freq[0]-1; 
	low = low + (range*cum_freq[symbol])/cum_freq[0];
	for(;;) 
	{
		if ( high < half ) 
		{ }
		else if ( low >= half ) 
		{
			value -= half;
			low -= half; 
			high -= half; } 
		else if 
			( low >= first_qtr && high < third_qtr )
		{ 
			value -= first_qtr;
			low -= first_qtr;
			high -= first_qtr; 
		} 
		else break; 
		low = 2*low;
		high = 2*high + 1; 
		value = 2*value + m_pBitIO->input_bit(); 
	}
	return symbol;

} 
//================================================================

//----------------------------------------------------------------
//------------------------Encode----------------------------------
void CArithmeticCoder::Encode()
{
	int ch;
    int symbol;

	filein = fopen(name_filein, "rb");
	fileout = fopen(name_fileout, "wb");

	m_pBitIO->start_outputing_bits(fileout);

	start_encoding();
	
	for(;;)
	{
		ch = getc(filein);
		if ( ch == EOF ) break;
		symbol = m_pModel->char_to_index[ch];
		encode_symbol(symbol, m_pModel->cum_freq);
		m_pModel->update(symbol);
	}
	encode_symbol(EOF_symbol, m_pModel->cum_freq);
	done_encoding();
	m_pBitIO->done_outputing_bits();
}
//==================================================================

//------------------------------------------------------------------
//----------------------------Attach---------------------------------
bool CArithmeticCoder::Attach(CModel *pmodel)
{
	if(pmodel == 0)
		return false;
	else {
		m_pModel = pmodel;
		return true;
	}
}

bool CArithmeticCoder::Attach(CBitIO *pBitIO)
{
	if(pBitIO == 0)
		return false;
	else {
		m_pBitIO = pBitIO;
		return true;
	}
}
//===============================================================

void CArithmeticCoder::SetOutputFileName(char *outfilename)
{
	name_fileout = outfilename;
}

void CArithmeticCoder::Decode()
{
    int ch;
    int symbol;
	
	filein = fopen(name_filein, "rb");
	fileout = fopen(name_fileout, "wb");

    m_pBitIO->start_inputing_bits(filein);
    start_decoding();
	
	for(;;)
    {
	symbol = decode_symbol(m_pModel->cum_freq);
	if ( symbol == EOF_symbol )
	    break;
	ch = m_pModel->index_to_char[symbol];
	putc(ch,fileout);
        m_pModel->update(symbol);
    }
    //return;
}

void CArithmeticCoder::SetInputFileName(char *infilename)
{
	name_filein = infilename;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久草av在线| 亚洲欧美日韩在线不卡| 欧美少妇bbb| 色综合久久久网| 91麻豆swag| 色香色香欲天天天影视综合网| 国产99久久久国产精品潘金网站| 久久精品av麻豆的观看方式| 欧美aⅴ一区二区三区视频| 亚洲bt欧美bt精品| 午夜精品一区二区三区电影天堂 | 美女高潮久久久| 亚洲777理论| 日韩av一区二区在线影视| 日韩av一区二| 国内不卡的二区三区中文字幕| 九九视频精品免费| 国产成人高清在线| 99国产精品久久久| 欧美探花视频资源| 欧美电视剧免费观看| 国产亚洲精久久久久久| 国产精品免费久久久久| 亚洲美腿欧美偷拍| 日韩av电影免费观看高清完整版在线观看| 三级欧美在线一区| 久久99精品国产| 99久久99久久精品免费看蜜桃| 91视频在线看| 91精品国产一区二区三区香蕉| 精品国产乱码久久久久久免费| 国产目拍亚洲精品99久久精品| 中文字幕在线观看一区| 亚欧色一区w666天堂| 久久成人久久鬼色| 99久久精品免费看| 日韩视频在线永久播放| 国产精品视频一二三| 亚洲大型综合色站| 国产成人在线电影| 欧美性生活一区| 欧美精品一区二区三区久久久| 国产精品久久网站| 毛片一区二区三区| 97久久超碰国产精品| 日韩精品一区二区三区在线| 中文字幕亚洲一区二区av在线| 日韩高清电影一区| 9久草视频在线视频精品| 91麻豆精品国产无毒不卡在线观看 | 2023国产精品自拍| 一区二区三区中文免费| 精品午夜久久福利影院| 在线一区二区三区四区| 国产欧美日韩精品a在线观看| 日韩**一区毛片| 91浏览器打开| 国产欧美精品一区二区色综合朱莉| 亚洲电影一级片| 91亚洲国产成人精品一区二三| 国产亚洲欧美一级| 美女脱光内衣内裤视频久久影院| 在线观看免费亚洲| 国产精品短视频| 福利电影一区二区| 久久综合中文字幕| 免费欧美在线视频| 欧美日韩另类国产亚洲欧美一级| 中文字幕在线不卡国产视频| 国产乱一区二区| 精品美女一区二区| 经典一区二区三区| 日韩欧美你懂的| 欧美a级理论片| 91精品国产欧美一区二区| 亚洲第一福利视频在线| 欧美日韩一区精品| 亚洲国产乱码最新视频 | 色婷婷激情一区二区三区| 国产亚洲1区2区3区| 国产黄人亚洲片| 国产欧美日韩久久| 不卡av在线免费观看| 国产精品网站在线播放| 成人免费va视频| 国产精品高清亚洲| 色欧美乱欧美15图片| 一区二区理论电影在线观看| 欧美性高清videossexo| 午夜精品久久一牛影视| 91精品国产福利在线观看| 男女激情视频一区| 2022国产精品视频| 成人一二三区视频| 亚洲激情中文1区| 欧美视频完全免费看| 日本va欧美va瓶| 久久网站最新地址| 成人午夜视频在线观看| 伊人夜夜躁av伊人久久| 69久久夜色精品国产69蝌蚪网| 久久电影网站中文字幕| 国产精品嫩草影院av蜜臀| 色婷婷久久久久swag精品| 天天操天天干天天综合网| 欧美精品一区二区三区蜜臀| 波多野结衣视频一区| 一区二区三区四区蜜桃| 日韩欧美的一区| aa级大片欧美| 美国毛片一区二区| 亚洲欧美一区二区视频| 欧美精品久久久久久久多人混战 | 亚洲曰韩产成在线| 日韩一级片在线观看| 成人激情黄色小说| 三级在线观看一区二区| 久久精品这里都是精品| 在线观看一区日韩| 国产丶欧美丶日本不卡视频| 亚洲宅男天堂在线观看无病毒| 日韩精品一区二区三区视频| 91视频在线观看| 精品一区二区三区免费| 亚洲第一狼人社区| 国产精品午夜在线| 欧美成人一级视频| 91成人免费电影| 成人爱爱电影网址| 久久99热狠狠色一区二区| 亚洲精品中文字幕在线观看| 久久久综合激的五月天| 欧美一区二区人人喊爽| 成人av影院在线| 捆绑紧缚一区二区三区视频| 一区二区不卡在线播放 | 免费高清不卡av| 亚洲综合一二区| 中文字幕在线播放不卡一区| 精品美女被调教视频大全网站| 欧美日韩一区二区不卡| 一本大道久久a久久精二百| 国产老肥熟一区二区三区| 麻豆成人久久精品二区三区红| 亚洲国产一区视频| 亚洲激情图片一区| 亚洲欧洲99久久| 国产精品二区一区二区aⅴ污介绍| 欧美xxx久久| 欧美一区二区私人影院日本| 欧美日本在线一区| 欧美日韩免费观看一区二区三区| 一本久道久久综合中文字幕| 99久久99久久免费精品蜜臀| 高清在线不卡av| 成人免费高清在线观看| 99视频精品全部免费在线| 成人av动漫网站| 99视频在线观看一区三区| 成人爱爱电影网址| av亚洲精华国产精华精华| 成人黄色软件下载| eeuss鲁一区二区三区| 97久久精品人人做人人爽| 色域天天综合网| 欧美三级视频在线| 在线播放中文一区| 欧美一级专区免费大片| 日韩精品中文字幕一区| 久久久美女毛片| 亚洲欧洲av在线| 亚洲成人一二三| 久久99精品久久久久久动态图 | 国产精品综合久久| 成人午夜在线免费| 91黄色免费版| 日韩欧美一区二区视频| 国产欧美日韩亚州综合| 亚洲欧美日韩系列| 午夜激情久久久| 黄色日韩网站视频| 91在线观看视频| 7777精品伊人久久久大香线蕉完整版| 日韩精品中文字幕在线不卡尤物 | 欧美电影免费观看高清完整版| 国产性做久久久久久| 一区二区三区不卡视频| 麻豆国产91在线播放| 成人精品一区二区三区中文字幕| 一本到三区不卡视频| 欧美一级欧美一级在线播放| 国产色一区二区| 亚洲自拍偷拍图区| 国产精品12区| 欧美日韩精品三区| 国产精品婷婷午夜在线观看| 视频一区国产视频| 91欧美一区二区| 欧美精品一区二区三区久久久| 一卡二卡欧美日韩|