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

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

?? dlgarith.cpp

?? 提供了圖像識別
?? 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一区二区三区免费野_久草精品视频
欧美不卡在线视频| 韩国视频一区二区| 久久免费视频一区| 国产91高潮流白浆在线麻豆| 亚洲人一二三区| 5858s免费视频成人| 97久久精品人人澡人人爽| 高清成人在线观看| 国产麻豆精品视频| 视频一区二区三区入口| ...av二区三区久久精品| 欧美大片免费久久精品三p| 欧美日韩一区二区三区在线 | 国产xxx精品视频大全| 日精品一区二区三区| 一区二区高清视频在线观看| 国产精品久久久久久户外露出| 精品粉嫩超白一线天av| 精品入口麻豆88视频| 日韩一二三四区| 日韩精品资源二区在线| 3d动漫精品啪啪1区2区免费 | 亚洲最快最全在线视频| 亚洲三级视频在线观看| 国产精品美女一区二区三区| 国产精品久久久久久久午夜片| 国产亚洲精品中文字幕| 欧美激情一区在线观看| 日本一区二区不卡视频| 国产精品美女久久久久av爽李琼 | 欧美极品aⅴ影院| 久久久午夜精品| 国产婷婷色一区二区三区| 久久久综合九色合综国产精品| 精品美女在线观看| 久久精品人人做人人综合| 国产色综合久久| 亚洲色图视频网站| 亚洲在线视频一区| 久久99久久久久| 国产精品一级在线| 91蝌蚪porny成人天涯| 欧美午夜精品一区| 日韩欧美在线综合网| 久久久影视传媒| 一区二区三区成人| 美国十次综合导航| www.视频一区| 欧美精品乱码久久久久久按摩| 精品嫩草影院久久| 亚洲丝袜另类动漫二区| 婷婷中文字幕综合| 国内精品久久久久影院薰衣草| 91免费版在线| 日韩精品一区二区三区视频在线观看 | 国产一区二区看久久| av影院午夜一区| 欧美精品在线视频| 国产亚洲午夜高清国产拍精品| 自拍av一区二区三区| 蜜臀久久99精品久久久画质超高清| 国产河南妇女毛片精品久久久| 一本大道久久a久久综合婷婷| 91精品国产免费久久综合| 国产精品美女视频| 久久精品国产99国产精品| caoporn国产精品| 欧美色男人天堂| 337p日本欧洲亚洲大胆精品| 国产精品传媒入口麻豆| 亚洲一区二区精品3399| 成人激情电影免费在线观看| 欧美日韩美少妇| 国产精品成人免费| 国产乱子伦视频一区二区三区| 成人av午夜电影| 精品国产伦一区二区三区免费| 亚洲一区二区三区视频在线播放| 久久精品国产精品亚洲精品| 欧美三级韩国三级日本一级| 中文字幕精品一区二区三区精品| 自拍偷在线精品自拍偷无码专区| 亚洲美女视频在线| www.日本不卡| 国产亚洲精品bt天堂精选| 蜜臀国产一区二区三区在线播放 | caoporn国产精品| 国产欧美在线观看一区| 国产一区在线观看视频| 欧美videos大乳护士334| 亚洲va在线va天堂| 精品视频1区2区3区| 一区二区三区免费网站| 99精品欧美一区二区三区小说 | 久久婷婷久久一区二区三区| 青青草国产精品亚洲专区无| 欧美三片在线视频观看 | 91成人在线精品| 夜夜精品浪潮av一区二区三区| jlzzjlzz亚洲日本少妇| 国产精品久久久久四虎| 国产东北露脸精品视频| 欧美国产视频在线| 国产精品一区三区| 日本一区二区三区在线观看| 国产精品18久久久久久久久久久久 | 午夜久久久久久久久| 一本久久a久久免费精品不卡| 亚洲美女偷拍久久| 欧美日韩精品久久久| 亚洲成人资源网| 日韩一级免费观看| 国产在线精品不卡| 专区另类欧美日韩| 欧美群妇大交群中文字幕| 麻豆传媒一区二区三区| 亚洲精品在线网站| 高清久久久久久| 一区二区三区四区在线免费观看| 欧美亚洲一区二区在线观看| 一个色综合网站| 精品精品国产高清a毛片牛牛| 国产综合久久久久久鬼色| 国产精品三级电影| 欧美日韩一二三| 国产精品小仙女| 午夜精品一区二区三区免费视频 | 五月婷婷另类国产| 久久久久久电影| 色香蕉成人二区免费| 美国av一区二区| 国产精品女上位| 91精选在线观看| voyeur盗摄精品| 蜜臀av性久久久久蜜臀aⅴ四虎| 中文字幕精品综合| 欧美群妇大交群中文字幕| 成人一区二区三区视频在线观看| 亚洲一区二区三区四区五区黄| 国产肉丝袜一区二区| 91碰在线视频| 日本va欧美va欧美va精品| xf在线a精品一区二区视频网站| 成人av在线播放网址| 久久精品久久综合| 亚洲美女区一区| 国产日韩成人精品| 欧美一区二区精品| 欧美在线不卡一区| 成人禁用看黄a在线| 激情综合网av| 天天影视涩香欲综合网| 1024精品合集| 日本一二三不卡| 久久男人中文字幕资源站| 欧美酷刑日本凌虐凌虐| 972aa.com艺术欧美| 极品销魂美女一区二区三区| 亚洲午夜一区二区三区| 中文字幕在线免费不卡| 久久精品视频网| xf在线a精品一区二区视频网站| 一本一道综合狠狠老| 国内成人免费视频| 免费不卡在线观看| 日本午夜精品视频在线观看| 亚洲午夜免费视频| 日韩欧美中文字幕公布| 色一区在线观看| 色国产综合视频| 在线观看av一区二区| 91麻豆国产福利在线观看| bt7086福利一区国产| 成人av免费在线观看| 粉嫩av亚洲一区二区图片| 丁香亚洲综合激情啪啪综合| 99视频超级精品| av福利精品导航| 91丨porny丨蝌蚪视频| 99综合影院在线| 97久久精品人人澡人人爽| 91香蕉视频污在线| 色欧美片视频在线观看在线视频| 97久久超碰精品国产| 在线视频综合导航| 欧美日韩精品系列| 日韩欧美美女一区二区三区| 在线免费不卡视频| 久久精品999| 成人永久免费视频| 欧美精品精品一区| 国产女主播一区| 青青草91视频| 99久久综合狠狠综合久久| 91精品国产91久久综合桃花| 欧美高清在线视频| 日本欧美一区二区在线观看| 国产69精品一区二区亚洲孕妇| 91麻豆精品国产91久久久| 国产精品人成在线观看免费|