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

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

?? dlgarith.cpp

?? 經典編著《Visual C++數字圖像處理典型算法及實現》光盤源程序。
?? CPP
字號:
/////////////////////////////////////////////////////////////////////////////
// CDlgArith dialog
#include "stdafx.h"
#include "ImageProcessing.h"
#include "DlgCoding.h"

#include <math.h>

#ifdef _DEBUG
#define new DEBUG_NEW
#undef THIS_FILE
static char THIS_FILE[] = __FILE__;
#endif

#define fPro4Zero  0.25;
#define fPro4One   0.75;
CDlgArith::CDlgArith(CWnd* pParent /*=NULL*/)
	: CDialog(CDlgArith::IDD, pParent)
{
	//{{AFX_DATA_INIT(CDlgArith)
	m_ArithSerial = _T("");
	m_ArithOutput = _T("");
	m_ArithDecode = _T("");
	//}}AFX_DATA_INIT
}


void CDlgArith::DoDataExchange(CDataExchange* pDX)
{
	CDialog::DoDataExchange(pDX);
	//{{AFX_DATA_MAP(CDlgArith)
	DDX_Control(pDX, IDC_EDIT1, m_ConArithSer);
	DDX_Control(pDX, IDCODING, m_coding);
	DDX_Control(pDX, IDDECODING, m_decoding);
	DDX_Text(pDX, IDC_EDIT1, m_ArithSerial);
	DDV_MaxChars(pDX, m_ArithSerial, 15);
	DDX_Text(pDX, IDC_EDIT2, m_ArithOutput);
	DDX_Text(pDX, IDC_EDIT4, m_ArithDecode);
	//}}AFX_DATA_MAP
}


BEGIN_MESSAGE_MAP(CDlgArith, CDialog)
	//{{AFX_MSG_MAP(CDlgArith)
	ON_BN_CLICKED(IDDECODING, OnDecoding)
	ON_BN_CLICKED(IDCODING, OnCoding)
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// CDlgArith message handlers

//void CDlgArith::OnOK() 
//{
//	CDialog::OnOK();
//}
///////////////////////////////////////////////////////////////
// DlgCodingIArith dialog



/***********************************************************
 實現對已經編碼的碼字進行解碼的功能
 *********************************************************
*/

void CDlgArith::OnDecoding() 
{
	// 二值序列的長度
	int nOutLength;

	// 算術編碼的長度
	int nInLength;

	// 編碼區間的上限和下限  
	double dHigh=1.0;
	double dLow=0.0;

	// 編碼區間的長度
	double dRange=1.0;

	// 判斷二值序列是否全零
	int nNo1=0;
	
	// 循環變量
	int i;
	
	// 二進制表示為十進制
	double dTenCode=0;
	
	// 中間變量
	double d2Pow;
	double dTemp;

	// 接收數據
	UpdateData(TRUE);

	// 解碼顯示清空
	m_ArithDecode = _T("");
	
	// 顯示數據
	UpdateData(FALSE);
	
	// 算術編碼的長度
	nInLength =m_ArithOutput.GetLength();
	
	// 將二進制序列轉化為十進制,并判斷是否為零
	for (i=0; i<nInLength;i++ )
	{
		// 二進制的每位對應十進制的值
		d2Pow = pow(0.5,i+1);
		if(m_ArithOutput.Mid(i,1)=='1')
		{
			dTenCode=dTenCode+d2Pow;
			nNo1++;
		}
	}

	// 二值序列的長度
	nOutLength = m_ArithSerial.GetLength();

	// 分全零和非全零兩種情況解碼
	if(nNo1!=0)
	{
		for(i=0;i<nOutLength;i++)
		{
			dTemp=dLow+dRange*fPro4Zero;

			if(dTemp>dTenCode)
			{
				// 輸出0
				m_ArithDecode=m_ArithDecode+'0';
				
				// 編碼區間上下限的計算
				dLow=dLow;
				dHigh=dLow+dRange*fPro4Zero;
				
				// 區間范圍
				dRange=dHigh-dLow;
			}
			else
			{
				// 輸出1
				m_ArithDecode=m_ArithDecode+'1';
				
				// 編碼區間上下限的計算
				dLow=dLow+dRange*fPro4Zero;
				dHigh=dHigh;

				// 區間范圍
				dRange=dHigh-dLow;
			}
		}
	}
	else
	{
		for(i=0;i<nOutLength;i++)
			m_ArithDecode=m_ArithDecode+'1';
	}
	

	// 數據輸出更新
	UpdateData(FALSE);

	// 在重新輸入編碼前不允許輸入
	m_decoding.EnableWindow(FALSE);

	// 允許輸入
	m_ConArithSer.EnableWindow(TRUE);
	
	// 允許解碼
	m_coding.EnableWindow(TRUE);
	
}

/***********************************************************
 實現對輸入二進制序列進行編碼的功能
 *********************************************************
*/

void CDlgArith::OnCoding() 
{
	
	// 輸入二值序列長度
	int nInLength;

	// 輸出碼字長度
	int nOutLength;

	// 循環變量
	int i;

	// 中間變量
	double dTemp;

	// 編碼區間的上限和下限  
	double dHigh=1.0;
	double dLow=0.0;

	// 編碼區間的長度
	double dRange=1.0;

	// 累積概率
	double dAccuPro=1.0;
	
    // 接收輸入的數據
	UpdateData(TRUE);
	
	// 清除輸出的編碼碼字
	m_ArithOutput = _T("");
	
	// 輸出
	UpdateData(FALSE);
	
	// 令編碼按鈕無效
	m_decoding.EnableWindow(FALSE);
	
	// 輸入的二值序列長度
	nInLength = m_ArithSerial.GetLength();
 
	//  對二值序列進行編碼
	for (i = 0; i < nInLength; i++ )
	{
		
		// 如果輸入為1
		if(m_ArithSerial.Mid(i,1) == "1")
		{
			// 編碼區間上下限的計算
			dHigh = dHigh;
			dLow  = dLow + dRange*fPro4Zero;

			// 編碼區間長度
			dRange = dHigh - dLow;

			// 二值序列出現概率的計算
			dAccuPro = dAccuPro * fPro4One;			
		}
		// 如果輸入為0
		else if(m_ArithSerial.Mid(i,1) == "0")
		{
			// 編碼區間上下限的計算
			dHigh = dLow + dRange*fPro4Zero;
			dLow  = dLow;

			// 編碼區間長度
			dRange = dHigh - dLow;

			// 二值序列出現概率的計算
			dAccuPro = dAccuPro * fPro4Zero;			
		}
		// 如果輸入非二值序列
		else
		{
			// 重新輸入
			MessageBox("請輸入二值序列!", "系統提示" , 
			MB_ICONINFORMATION | MB_OK);
			return;
		}
	}

	// 計算輸出碼字的長度
	dTemp = floor( -log10(dAccuPro) / log10(2) ) + 1;
	nOutLength = (int)dTemp;

	dTemp = dLow;
	double d2Pow;
	
	// 將十進制的小數轉化成二進制的小數表示
	for (i = 0; i < nOutLength; i++ )
	{
		// 二進制小數第i對應的十進制值
		d2Pow = pow(0.5,i + 1);
		
		// 判斷當前位賦值0或者1
		if(dTemp >= d2Pow)
		{
			m_ArithOutput = m_ArithOutput + "1";
			dTemp = dTemp - d2Pow;
		}
		else 
			m_ArithOutput = m_ArithOutput + "0";
	}
	
	// 轉化后是否有余數
	if(dTemp > 0)
	{
		// 二進制小數進行進位
		for(i = nOutLength-1; i >= 0; i--)
		{
			// 進位,1轉化為0
			if(m_ArithOutput.Mid(i,1) == '1')
			{
				m_ArithOutput.Delete(i,1);
				m_ArithOutput.Insert(i,"0");
			}
			// 進位完成,最后的0位轉化為1
			else
			{
				m_ArithOutput.Delete(i,1);
				m_ArithOutput.Insert(i,"1");
				break;
			}
		}
	}
     
	// 編碼完成,數據更新
	UpdateData(FALSE);

	// 允許進行解碼
	m_decoding.EnableWindow(TRUE);

	// 解碼前禁止編碼
	m_coding.EnableWindow(FALSE);

	// 解碼前禁止輸入新的二進制序列
	m_ConArithSer.EnableWindow(FALSE);

}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区二区免费在线| 欧美吻胸吃奶大尺度电影| 亚洲成人在线观看视频| 亚洲欧美日韩系列| 亚洲图片你懂的| av电影天堂一区二区在线| 日本电影欧美片| 成人av网在线| 91网站最新地址| 色婷婷久久久久swag精品| aaa欧美日韩| 91社区在线播放| 欧美亚洲动漫另类| 欧美丰满一区二区免费视频| 欧美精品一二三| 欧美精品第1页| 精品区一区二区| 中文字幕国产一区| 日韩高清不卡一区| 欧美精品久久99| 制服丝袜激情欧洲亚洲| 久久久影视传媒| 国产欧美久久久精品影院| 国产精品女人毛片| 一区二区三区色| 蜜臂av日日欢夜夜爽一区| 国产精品综合一区二区三区| 成人黄色a**站在线观看| 色婷婷精品大在线视频| 777精品伊人久久久久大香线蕉| 精品久久免费看| 欧美激情中文不卡| 一区二区三区自拍| 久久激情综合网| 91麻豆精品在线观看| 欧美一区二区久久| 亚洲国产精品精华液2区45| 欧美日韩一区在线观看| 日韩亚洲欧美在线| 久久精品夜色噜噜亚洲aⅴ| 国产精品丝袜在线| 丝袜国产日韩另类美女| 久久精品99国产精品日本| 成+人+亚洲+综合天堂| 色婷婷综合中文久久一本| 欧美日韩一区高清| 亚洲色图视频网| 久久精品国产亚洲高清剧情介绍 | av一二三不卡影片| 欧美日韩色一区| 中文字幕乱码亚洲精品一区| 偷拍与自拍一区| 一本大道久久a久久精品综合| 欧美一二三区在线观看| 亚洲欧美aⅴ...| 国产精品一区在线观看乱码| 欧美精品欧美精品系列| 亚洲欧美激情插 | 久久夜色精品国产欧美乱极品| 国产精品久久久久9999吃药| 蜜桃精品视频在线| 欧美日韩在线三级| 亚洲摸摸操操av| aaa欧美日韩| 欧美高清在线一区| 国产一区二区三区不卡在线观看| 欧美精品少妇一区二区三区| 亚洲视频1区2区| 成人h精品动漫一区二区三区| 精品久久久久久久人人人人传媒| 亚洲成av人片| 欧美午夜精品一区二区三区 | 亚洲一区二区在线免费观看视频| 国产乱对白刺激视频不卡| 欧美va亚洲va国产综合| 男人操女人的视频在线观看欧美| 欧美日韩电影一区| 日韩高清在线观看| 日韩一区二区三区在线观看| 日本中文字幕不卡| 91精品国产综合久久精品图片| 亚洲一区二区三区爽爽爽爽爽| 91在线丨porny丨国产| 亚洲日本丝袜连裤袜办公室| 日韩你懂的在线观看| 日韩和欧美一区二区| 欧美二区三区的天堂| 美日韩一区二区| 欧美mv日韩mv国产网站app| 美国三级日本三级久久99| 日韩精品一区二区在线观看| 国产麻豆午夜三级精品| 国产日韩欧美a| 91视频www| 免费精品视频在线| 久久一夜天堂av一区二区三区| 国产精品亚洲第一区在线暖暖韩国| 久久久av毛片精品| 91网址在线看| 日本伊人色综合网| 国产日产欧美一区二区视频| 色呦呦日韩精品| 免费精品视频在线| 欧美激情在线观看视频免费| 在线免费观看日本欧美| 奇米精品一区二区三区在线观看| 久久久久国产精品人| 一本大道av一区二区在线播放 | 欧美成人官网二区| 99视频在线精品| 日韩精品午夜视频| 久久精品欧美一区二区三区麻豆| 99在线精品一区二区三区| 三级不卡在线观看| 亚洲国产成人一区二区三区| 欧美日韩视频第一区| 风间由美一区二区av101| 亚洲欧美日韩小说| www国产成人免费观看视频 深夜成人网| 波波电影院一区二区三区| 免费成人在线视频观看| 国产精品久久二区二区| 日韩一级免费一区| 在线中文字幕一区| 国产成人99久久亚洲综合精品| 午夜一区二区三区视频| 中文在线免费一区三区高中清不卡| 欧美三级在线看| a在线播放不卡| 精品一区二区三区免费毛片爱| 亚洲高清中文字幕| 国产精品大尺度| 久久久91精品国产一区二区精品 | 日韩视频免费观看高清完整版在线观看 | 精品一区在线看| 午夜电影一区二区| 国产精品久久久久影院色老大 | 国产麻豆成人精品| 免费国产亚洲视频| 婷婷综合另类小说色区| 亚洲欧美中日韩| 国产人成亚洲第一网站在线播放 | 成人欧美一区二区三区1314| 欧美成人aa大片| 欧美一级片在线看| 51午夜精品国产| 欧美无乱码久久久免费午夜一区 | 国产福利不卡视频| 国产又黄又大久久| 国产精品主播直播| 国产乱码精品一区二区三区忘忧草| 日韩成人精品在线观看| 亚洲国产sm捆绑调教视频| 亚洲最色的网站| 亚洲精品伦理在线| 最新国产精品久久精品| 日韩久久一区二区| 一区二区三区四区激情| 亚洲精品欧美在线| 亚洲二区在线视频| 日韩精品成人一区二区三区| 日本中文字幕不卡| 精东粉嫩av免费一区二区三区| 青青草伊人久久| 久久99这里只有精品| 国内外精品视频| 国产69精品久久久久毛片| 播五月开心婷婷综合| 91浏览器打开| 777色狠狠一区二区三区| 欧美一区二区三区影视| 亚洲精品在线免费观看视频| 久久久亚洲综合| 综合婷婷亚洲小说| 视频一区视频二区中文| 日韩成人免费看| 久久国产精品72免费观看| 国产精品一线二线三线精华| 成人av在线网| 欧美日韩午夜在线| 久久久久高清精品| 亚洲美女精品一区| 日韩av电影天堂| 成人一区二区三区中文字幕| 日本高清不卡aⅴ免费网站| 欧美日韩免费不卡视频一区二区三区| 91麻豆精品91久久久久久清纯| 久久综合av免费| 中文字幕av一区二区三区高| 亚洲欧美日韩在线播放| 美国欧美日韩国产在线播放 | 亚洲视频1区2区| 青娱乐精品视频| 高清成人在线观看| 欧美喷水一区二区| 国产精品三级av在线播放| 午夜激情综合网| 成人免费毛片高清视频| 欧美一区在线视频| 亚洲激情第一区|