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

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

?? hyperspectraldatacompressdlg.cpp

?? 改進的JPEG-LS算法
?? CPP
?? 第 1 頁 / 共 3 頁
字號:
		R[i]=new double[HEncode.BandNumber];
		for(j=0;j<HEncode.BandNumber;j++)R[i][j]=0;
	}
	if(HEncode.HyperspectralDataFormat==BFILE||HEncode.HyperspectralDataFormat==BSQ_H)
	{//逐波段統計
		allLine=HEncode.BandNumber*HEncode.BandNumber/2;
		bg=0;a=0;
		for(i=0;i<HEncode.BandNumber;i++)
		{
			for(j=0;j<HEncode.Height;j++)
			{//統計均方及均值
				HEncode.GetOneLineImageData(lpImageData1[j],i,j);
				StatisticOneLineImage(lpImageData1[j],HEncode.OnePixelBytes,
										HEncode.Width,Mse,M);
				R[i][i]+=Mse;
				AllM[i]+=M;
			}
			a++;
			if(((a*100)/allLine)>bg)
			{//向主窗口報告當前執行的進度
				bg=(a*100)/allLine;
				PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,2,bg);
				if(TestRelativeThreadRun==FALSE)break;//檢查是否有中止標志
			}
			if(i<HEncode.BandNumber-1)
			{
				for(k=i+1;k<HEncode.BandNumber;k++)
				{
					a++;
					if(((a*100)/allLine)>bg)
					{//向主窗口報告當前執行的進度
						bg=(a*100)/allLine;
						PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,2,bg);
						if(TestRelativeThreadRun==FALSE)break;//檢查是否有中止標志
					}
					for(j=0;j<HEncode.Height;j++)
					{//統計相關函數
						HEncode.GetOneLineImageData(lpImageData2,k,j);
						StatisticOneLineTwoImage(lpImageData1[j],
												lpImageData2,
												HEncode.OnePixelBytes,
												HEncode.Width,
												Relative);
						R[i][k]+=Relative;
					}
				}
				if(k<HEncode.BandNumber)break;
			}
		}
	}
	else
	{//逐行統計
		allLine=HEncode.Height;
		bg=0;
		for(j=0;j<HEncode.Height;j++)
		{
			if((j*100/allLine)>bg)
			{//向主窗口報告當前執行的進度
				bg=j*100/allLine;
				PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,2,bg);
				if(TestRelativeThreadRun==FALSE)break;//檢查是否有中止標志
			}
			for(i=0;i<HEncode.BandNumber;i++)
			{
				HEncode.GetOneLineImageData(lpImageData1[i],i,j);
				StatisticOneLineImage(lpImageData1[i],HEncode.OnePixelBytes,
										HEncode.Width,Mse,M);
				R[i][i]+=Mse;
				AllM[i]+=M;
				if(i<HEncode.BandNumber-1)
				{
					for(k=i+1;k<HEncode.BandNumber;k++)
					{
						//統計相關函數
						HEncode.GetOneLineImageData(lpImageData2,k,j);
						StatisticOneLineTwoImage(lpImageData1[i],
												lpImageData2,
												HEncode.OnePixelBytes,
												HEncode.Width,
												Relative);
						R[i][k]+=Relative;
					}
				}
			}
		}
	}
	for(i=0;i<HEncode.Height;i++)
	{
		delete lpImageData1[i];
	}
	delete lpImageData1;
	delete lpImageData2;
	if(TestRelativeThreadRun==FALSE)
	{
		delete AllM;
		for(i=0;i<HEncode.BandNumber;i++)
		{
			delete R[i];
		}
		delete R;
		HEncode.EndHyperspectralCode();
		PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,3,0);
		return;
	}
	for(i=0;i<HEncode.BandNumber;i++)
	{
		AllM[i]/=HEncode.Height;//均值
		R[i][i]/=HEncode.Height;
		R[i][i]=sqrt(R[i][i]-AllM[i]*AllM[i]);//方差
	}
	for(i=0;i<HEncode.BandNumber;i++)
	{
		if(i<HEncode.BandNumber-1)
		{
			for(k=i+1;k<HEncode.BandNumber;k++)
			{
				R[i][k]/=HEncode.Height;
				R[i][k]-=AllM[i]*AllM[k];//協方差
				R[i][k]/=(R[i][i]*R[k][k]);//相關系數
				R[k][i]=R[i][k];//矩陣對稱
			}
		}
		R[i][i]=1;
	}
	int *lpPredictBand=new int[HEncode.BandNumber];
	lpPredictBand[0]=-1;//第一個波段是不進行波段間預測的。
	for(i=1;i<HEncode.BandNumber;i++)
	{
		for(j=0,M=0;j<i;j++)
		{//從前面的波段中尋找預測波段。
			if(M<R[i][j])
			{
				M=R[i][j];
				lpPredictBand[i]=j;
			}
		}
		if(M<0.85)lpPredictBand[i]=-1;
	}
	delete AllM;
	for(i=0;i<HEncode.BandNumber;i++)
	{
		delete R[i];
	}
	delete R;
	PredictBandList.Empty();
	CString s;
	for(i=0;i<HEncode.BandNumber;i++)
	{
		s.Format(_T("%d "),lpPredictBand[i]);
		PredictBandList+=s;
	}
	delete lpPredictBand;
	TestRelativeComplate=TRUE;
	HEncode.EndHyperspectralCode();
	PostMessage(WM_USER_HYPERSPECTRAL_COMPRESS_DLG,3,0);
}
void CHyperspectralDataCompressDlg::StatisticOneLineImage(LPBYTE lpImageLine1,
														  int BytesPerPixel,
														  int OneLineWidth,
														  double &Mse1,
														  double &M1)
{//統計圖像行均值與均方值
	int i,p1;
	Mse1=M1=0;
	if(OneLineWidth<=0||BytesPerPixel<=0)return;
	if(BytesPerPixel==1)
	{
		for(i=0;i<OneLineWidth;i++)
		{
			p1=((unsigned char)lpImageLine1[i]);
			M1+=p1;
			Mse1+=p1*p1;
		}
	}
	else if(BytesPerPixel==2)
	{
		OneLineWidth*=2;
		for(i=0;i<OneLineWidth;i+=2)
		{
			p1=*((unsigned short int *)(lpImageLine1+i));
			M1+=p1;
			Mse1+=p1*p1;
		}
		OneLineWidth/=2;
	}
	M1/=OneLineWidth;
	Mse1/=OneLineWidth;
}
void CHyperspectralDataCompressDlg::StatisticOneLineTwoImage(LPBYTE lpImageLine1,
															LPBYTE lpImageLine2,
															int BytesPerPixel,
															int OneLineWidth,
															double &Relative)
{//統計兩圖像行的相關函數
	int i,p1,p2;
	Relative=0;
	if(OneLineWidth<=0||BytesPerPixel<=0)return;
	if(BytesPerPixel==1)
	{
		for(i=0;i<OneLineWidth;i++)
		{
			p1=((unsigned char)lpImageLine1[i]);
			p2=((unsigned char)lpImageLine2[i]);
			Relative+=p1*p2;
		}
	}
	else if(BytesPerPixel==2)
	{
		OneLineWidth*=2;
		for(i=0;i<OneLineWidth;i+=2)
		{
			p1=*((unsigned short int *)(lpImageLine1+i));
			p2=*((unsigned short int *)(lpImageLine2+i));
			Relative+=p1*p2;
		}
		OneLineWidth/=2;
	}
	Relative/=OneLineWidth;
}
void CHyperspectralDataCompressDlg::OnKillfocusImageWidth() 
{
	UpdateData(TRUE);
	if(PureImageFormat==TRUE)
	{
		AllDataWidth=m_ImageWidth;
	}
}

void CHyperspectralDataCompressDlg::OnKillfocusAuxDataWidth() 
{
	//輔助數據寬度的輸入控制
	UpdateData(TRUE);
	if(m_AuxDataWidth>=0&&m_AuxDataWidth<AllDataWidth)
	{
		if(PureImageFormat==FALSE)m_ImageWidth=AllDataWidth-m_AuxDataWidth;
		else if(m_AuxDataWidth>0)m_AuxDataWidth=0;
		UpdateData(FALSE);
	}
}

void CHyperspectralDataCompressDlg::OnKillfocusLinesPerBlock() 
{
	//壓縮塊行數的輸入控制
	UpdateData(TRUE);
	if(m_LinesPerBlock<MIN_LINES_PER_BLOCK)
	{
		m_LinesPerBlock=MIN_LINES_PER_BLOCK;
		UpdateData(FALSE);
	}
	else if(m_LinesPerBlock>m_ImageHeight)
	{
		m_LinesPerBlock=m_ImageHeight;
		UpdateData(FALSE);
	}
	else if(m_LinesPerBlock>MAX_LINES_PER_BLOCK)
	{
		m_LinesPerBlock=MAX_LINES_PER_BLOCK;
		UpdateData(FALSE);
	}
}
void CHyperspectralDataCompressDlg::UpdateControlList(BOOL UpdateMode)//FALSE: 數據->控件,TRUE:控件->數據
{
	int i,j,Seat;
	CString s;
	LVITEM lvitem;
	TCHAR Blist[32];
	if(UpdateMode==TRUE)
	{//控件->數據
		UpdateData(TRUE);
		PredictBandList.Empty();
		j=m_RelativeList.GetItemCount();
		s=_T(" ");
		for (i = 0; i < j; i++)
		{
			PredictBandList+=m_RelativeList.GetItemText(i,1);
			PredictBandList+=s;
		}
	}
	else
	{//數據->控件
		m_RelativeList.DeleteAllItems();
		lvitem.mask = LVIF_TEXT | LVIF_STATE| LVIF_DI_SETITEM;
		for (i = 0,Seat=0; i < m_BandNumber; i++)
		{
			s.Format(_T("%d"),i);
			lvitem.iItem = i;
			lvitem.iSubItem = 0;
			lvitem.pszText = s.GetBuffer(s.GetLength());
			lvitem.cchTextMax=4;
			lvitem.lParam=i;
			lvitem.stateMask=LVM_EDITLABEL;
			lvitem.state=LVM_EDITLABEL;
			j = m_RelativeList.InsertItem(&lvitem);

			GetNextDataSeat((LPCTSTR)PredictBandList,Blist,Seat);
			lvitem.iItem = j;
			lvitem.iSubItem = 1;
			lvitem.pszText = Blist;
			lvitem.cchTextMax=4;
			lvitem.lParam=i|(lvitem.iSubItem<<16);
			lvitem.stateMask=LVM_EDITLABEL;
			lvitem.state=LVM_EDITLABEL;
			m_RelativeList.SetItem(&lvitem);
		}
		UpdateData(FALSE);
	}
}
int CHyperspectralDataCompressDlg::GetNextDataSeat(LPCTSTR lpAsc,LPSTR lpOne,int &Seat)
{
	int i=0;
	for(;lpAsc[Seat]!='-'&&(lpAsc[Seat]>'9'||lpAsc[Seat]<'0')&&lpAsc[Seat]!='\0';Seat++);
	if(lpAsc[Seat]!='\0')
	{
		for(;(lpAsc[Seat]=='-'||(lpAsc[Seat]<='9'&&lpAsc[Seat]>='0'))&&lpAsc[Seat]!='\0';Seat++)
		{
			lpOne[i++]=lpAsc[Seat];
		}
		lpOne[i]='\0';
	}
	return i;
}
void CHyperspectralDataCompressDlg::InitPredictBandString()
{
	PredictBandList.Empty();
	for(int i=0;i<m_BandNumber;i++)
	{
		PredictBandList+=_T("-1 ");
	}
}

void CHyperspectralDataCompressDlg::OnDblclkCompressRelativeList(NMHDR* pNMHDR, LRESULT* pResult) 
{
	NM_LISTVIEW* pNMListView = (NM_LISTVIEW*)pNMHDR;
	// 雙擊列表某項,如可編輯,則響應之。
	// 實現方法:創建僅含編輯控件無頭對話框,將其大小和位置置于列表項處,當輸入聚焦移開此編輯框但
	// 未移開本程序時,就認為輸入確認。響應Esc鍵就認為是取消。
	CRect Rect,ListRect;
	int ColLeft;//存放列左邊界位置
	int ItemTop,ItemNumber,ItemHeight,i,x,y;
	m_RelativeList.GetWindowRect(&ListRect);//取控鍵屏幕矩形
	m_RelativeList.GetSubItemRect(0,0,LVIR_BOUNDS,Rect);//取初始列表對象矩形,為空時值不定
//目的是確定列表對象縱向初始位置和單對象的高度
	ItemNumber=m_RelativeList.GetItemCount();//列表數目
	ItemTop=Rect.top;//列表對象縱向初始位置
	ItemHeight=Rect.Height();//列表對象的高度
	//計算列左邊界位置
	ColLeft=m_RelativeList.GetColumnWidth(0);
	x=pNMListView->ptAction.x;//當前的點擊坐標,相對于ListCtrl控鍵
	y=pNMListView->ptAction.y;
	i=(y-ItemTop)/ItemHeight;//計算點擊點所在的列表項
	//計算點擊點所在的列
	if(x<=ColLeft){*pResult = 0;return;}
	m_RelativeList.GetSubItemRect(i,1,LVIR_BOUNDS,Rect);//獲取子項的矩形
	Rect.top+=(ListRect.top+2);//將子項矩形映射成屏幕矩形
	Rect.left+=(ListRect.left+2);
	Rect.bottom+=(ListRect.top+2);
	Rect.right+=(ListRect.left+2);
	TCHAR asc[1024];
	CString s,str;
	CSmallEdit *pEdit=new CSmallEdit;
	if(pEdit!=NULL)
	{
		pEdit->Rect=Rect;//將創建的編輯框矩形置成子項矩形
		m_RelativeList.GetItemText( i, 1, asc, 255);
		pEdit->m_Text=asc;
		pEdit->Item.x=i;//為返回具體子項提供信息
		pEdit->Item.y=1;
		pEdit->RemoveEditStyle=ES_MULTILINE|ES_AUTOVSCROLL;
		if(pEdit->Create(NULL,NULL,0,CRect(0,0,0,0),this)==TRUE)//用無模態對話框,是要在對話框外可響應
		{// ES_READONLY ES_WANTRETURN                   注:this 是接收返回WM_USER_SMALL_EDIT消息的窗口
			pEdit->ShowWindow(SW_SHOW);
		}
	}
	*pResult = 0;
}
LRESULT CHyperspectralDataCompressDlg::OnSmallEditRecvMessage(WPARAM wParam, LPARAM lParam)
{
	CSmallEdit *pEdit=(CSmallEdit *)lParam;

	m_RelativeList.SetItemText(pEdit->Item.x,pEdit->Item.y,(LPCTSTR)pEdit->m_Text);
	UpdateControlList(TRUE);
	return 0;
}
/////////////////////////////////////////////////////////////////////////////
// HyperspectralCompressThread

IMPLEMENT_DYNCREATE(HyperspectralCompressThread, CWinThread)

HyperspectralCompressThread::HyperspectralCompressThread()
{
	m_bDone = FALSE;
	m_pOwner = NULL;
	m_bAutoDelete = FALSE;
}

HyperspectralCompressThread::~HyperspectralCompressThread()
{
}

BOOL HyperspectralCompressThread::InitInstance()
{
	// TODO:  perform and per-thread initialization here
	return TRUE;
}

int HyperspectralCompressThread::ExitInstance()
{
	// TODO:  perform any per-thread cleanup here
	return CWinThread::ExitInstance();
}

BEGIN_MESSAGE_MAP(HyperspectralCompressThread, CWinThread)
	//{{AFX_MSG_MAP(HyperspectralCompressThread)
		// NOTE - the ClassWizard will add and remove mapping macros here.
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// HyperspectralCompressThread message handlers

int HyperspectralCompressThread::Run() 
{
	// TODO: Add your specialized code here and/or call the base class
	m_pOwner->OkCompressProce();
	
	return 0;
}
/////////////////////////////////////////////////////////////////////////////
// HyperspectralTestRelativeThread

IMPLEMENT_DYNCREATE(HyperspectralTestRelativeThread, CWinThread)

HyperspectralTestRelativeThread::HyperspectralTestRelativeThread()
{
	m_bDone = FALSE;
	m_pOwner = NULL;
	m_bAutoDelete = FALSE;
}

HyperspectralTestRelativeThread::~HyperspectralTestRelativeThread()
{
}

BOOL HyperspectralTestRelativeThread::InitInstance()
{
	// TODO:  perform and per-thread initialization here
	return TRUE;
}

int HyperspectralTestRelativeThread::ExitInstance()
{
	// TODO:  perform any per-thread cleanup here
	return CWinThread::ExitInstance();
}

BEGIN_MESSAGE_MAP(HyperspectralTestRelativeThread, CWinThread)
	//{{AFX_MSG_MAP(HyperspectralTestRelativeThread)
		// NOTE - the ClassWizard will add and remove mapping macros here.
	//}}AFX_MSG_MAP
END_MESSAGE_MAP()

/////////////////////////////////////////////////////////////////////////////
// HyperspectralTestRelativeThread message handlers

int HyperspectralTestRelativeThread::Run() 
{
	// TODO: Add your specialized code here and/or call the base class
	m_pOwner->OkTestRelativeProce();
	
	return 0;
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美在线观看禁18| 91丝袜国产在线播放| 亚洲激情在线激情| 日韩伦理av电影| 国产精品美女久久久久高潮 | 国产自产v一区二区三区c| 日韩精品一二三区| 日本人妖一区二区| 精油按摩中文字幕久久| 狠狠色综合色综合网络| 国产精品白丝jk黑袜喷水| 成人午夜av电影| 91美女片黄在线观看91美女| 欧美自拍偷拍一区| 7777精品久久久大香线蕉| 欧美一个色资源| 国产免费观看久久| 亚洲欧美视频在线观看视频| 亚洲国产一二三| 蜜臀久久99精品久久久画质超高清| 成人黄色在线网站| 在线一区二区三区四区| 4438x成人网最大色成网站| 欧美成人一区二区三区| 久久九九全国免费| 亚洲美女视频在线观看| 青青草原综合久久大伊人精品优势| 美国毛片一区二区三区| 99热99精品| 欧美精品一二三| 国产日韩三级在线| 天堂精品中文字幕在线| 国产v日产∨综合v精品视频| 色哟哟一区二区三区| 日韩欧美一区二区免费| 国产精品免费视频一区| 日韩激情视频网站| 99天天综合性| 精品美女被调教视频大全网站| 中文字幕永久在线不卡| 日韩精品高清不卡| 97se亚洲国产综合自在线| 日韩精品最新网址| 亚洲一区中文在线| 成人福利在线看| 日韩欧美二区三区| 亚洲在线视频免费观看| 国产伦理精品不卡| 国产精品久久久久久一区二区三区| 亚洲欧美偷拍三级| 国产成人精品影视| 91精品国产福利| 亚洲精品乱码久久久久| 成人夜色视频网站在线观看| 精品国产伦一区二区三区观看方式 | 亚洲成人动漫av| 成人丝袜视频网| 久久综合色天天久久综合图片| 亚洲综合色噜噜狠狠| 99视频在线观看一区三区| 久久青草国产手机看片福利盒子| 亚洲高清不卡在线| 欧美日韩专区在线| 亚洲激情五月婷婷| 一本大道综合伊人精品热热| 中文字幕av资源一区| 国产成人亚洲综合a∨猫咪| 日韩色视频在线观看| 丝袜脚交一区二区| 6080国产精品一区二区| 婷婷亚洲久悠悠色悠在线播放| 色国产综合视频| 一区二区三区在线观看视频 | 亚洲一区二区三区中文字幕在线| 成人国产精品免费网站| 久久久久久久久久久久久久久99| 久久精品国产亚洲高清剧情介绍| 91精品国产91久久综合桃花| 日韩国产在线观看一区| 欧美一区二区在线不卡| 美女视频网站久久| 精品成人免费观看| 国产成人亚洲综合a∨猫咪| 欧美激情一区二区三区全黄| 成人国产精品免费观看视频| 亚洲图片激情小说| 一本久道久久综合中文字幕| 亚洲综合一二三区| 9191久久久久久久久久久| 美国毛片一区二区| 国产婷婷色一区二区三区在线| 成人黄色国产精品网站大全在线免费观看| 精品国产sm最大网站免费看| 国产v综合v亚洲欧| 亚洲激情五月婷婷| 日韩欧美的一区二区| 高清shemale亚洲人妖| 国产精品福利在线播放| 在线看一区二区| 蜜乳av一区二区| 国产精品久久久久久久久久免费看| 成人午夜免费电影| 亚洲福利视频一区二区| 精品国偷自产国产一区| 国产一区二区三区免费在线观看| 日本一区二区三区四区在线视频 | 日韩国产欧美在线观看| 精品女同一区二区| 91麻豆成人久久精品二区三区| 视频一区免费在线观看| 2020日本不卡一区二区视频| 色综合天天综合在线视频| 免费在线观看一区| 一色桃子久久精品亚洲| 欧美一卡2卡三卡4卡5免费| 成人一区在线观看| 麻豆国产精品一区二区三区| 亚洲视频一区在线| 日韩视频免费观看高清完整版| 成人激情校园春色| 精品一区二区三区免费观看| 亚洲一二三区视频在线观看| 国产午夜精品福利| 日韩欧美在线网站| 欧美午夜理伦三级在线观看| 国产一区视频网站| 亚洲国产wwwccc36天堂| 国产精品欧美一区喷水| 欧美mv日韩mv国产网站| 色综合久久中文综合久久牛| 国产成人午夜精品影院观看视频 | 成人精品在线视频观看| 天堂成人国产精品一区| 亚洲伦理在线免费看| 久久久午夜精品理论片中文字幕| 欧美三区在线观看| 色综合中文综合网| 国产激情精品久久久第一区二区 | 91免费视频网| 国产精品自产自拍| 久久精品噜噜噜成人av农村| 视频一区二区不卡| 午夜欧美视频在线观看| 亚洲蜜桃精久久久久久久| 中文字幕一区二区三中文字幕| 69久久99精品久久久久婷婷| 欧美人牲a欧美精品| 欧美日韩一二区| 欧美亚洲尤物久久| 在线观看视频91| 欧美日韩在线播| 欧美另类videos死尸| 欧美日韩成人综合在线一区二区| 色狠狠一区二区三区香蕉| 日本韩国视频一区二区| 欧美视频精品在线观看| 欧美特级限制片免费在线观看| 在线免费观看日本一区| 在线亚洲一区二区| 欧美三级韩国三级日本三斤| 欧美午夜一区二区| 欧美一区二区在线观看| 精品国产乱码久久久久久老虎| 精品美女在线播放| 亚洲国产精品传媒在线观看| 亚洲欧洲av另类| 亚洲一二三四在线观看| 亚洲成人自拍偷拍| 麻豆精品视频在线观看| 国产91在线|亚洲| caoporn国产精品| 欧美性xxxxx极品少妇| 91精品国产综合久久精品麻豆| 91精品国产免费久久综合| 久久久99久久| 亚洲欧美日韩国产另类专区| 亚洲高清免费观看 | 亚洲一二三四区不卡| 日韩不卡一二三区| 国产美女在线观看一区| 91亚洲精品一区二区乱码| 欧美三级中文字幕| 久久人人97超碰com| 一区二区三区成人| 韩国精品一区二区| 99re免费视频精品全部| 欧美日本在线一区| 国产蜜臀av在线一区二区三区| 国产激情视频一区二区三区欧美| 韩国v欧美v日本v亚洲v| 91精品国产综合久久久蜜臀图片| 日韩一区二区免费在线电影 | 久久久久久一二三区| 国产精品久久久久久户外露出| 亚洲一区二区视频| 高清不卡一二三区| 欧美一级淫片007| 亚洲激情av在线| 久久丁香综合五月国产三级网站| 色综合久久久久综合|