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

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

?? houghline.cpp

?? 清華大學出版社出版的《數字圖像處理實訓教程》一書以提高動手能力為目標
?? CPP
字號:
#include "dimage.h"
#include <math.h>
#define houghthresh 10

void diedaiyz(BYTE *image[2000],int w,int h);
void sanfenyz(BYTE *image[2000],int w,int h);
void sobel(BYTE *image_in[2000],int w,int h,BYTE *image_out[2000]);
void lapla1(BYTE *image_in[2000],int w,int h,BYTE *image_out[2000]);
void lapla2(BYTE *image_in[2000],int w,int h,BYTE *image_out[2000]);
void zzlb(BYTE *image_in[2000],int w,int h,BYTE *image_out[2000]);
void houghtrans1(BYTE *image_in[2000],int w,int h);
void houghtrans2(BYTE *image_in[2000],int w,int h);
void makeline1(BYTE *image_in[2000],int w,int h,double t,int k,int r,BYTE *image_out[2000]);
void makeline2(BYTE *image_in[2000],int w,int h,double t,int k,int r,BYTE *image_out[2000]);
int medianvalue(int *value);

int main()
{
	int w=512,h=512;
	Welcom();
	BYTE *image[2000];
	InitImage(image,w,h);
	ReadRawFile(image,w,h,"D:\\peacock.raw");
	//圖像讀取的路徑為:D:\\peacock.raw ,在保存的時候存在了E盤
	//且均以peacock_后綴.raw命名,例如:peacock_lapla2.raw,peacock_hough.raw
	
	//我們將所有的函數按不同的順序進行組合,以期得到最好的邊緣提取效果

//	diedaiyz(image,w,h);    //迭代法選取閾值,二值化,并將二值化后的圖像保存
//	sanfenyz(image,w,h);    //T=max-(max-min)/3,二值化,并將二值化后的圖像保存

//	BYTE *image2[2000];
//	InitImage(image2,w,h);
//	zzlb(image,w,h,image2);    //中值濾波,并將濾波后的圖像保存
	//前面的為輸入數組,如image;后面的為輸出數組,如image2。以下均同,請注意之!

	BYTE *image1[2000];
	InitImage(image1,w,h);
//	sobel(image,w,h,image1);    //sobel算子對圖像進行梯度銳化,并將梯度銳化后的圖像保存
//	lapla1(image,w,h,image1);    //拉普拉斯算子,模板一:{0,-1,0,-1,4,-1,0,-1,0},并將梯度銳化后的圖像保存
	lapla2(image,w,h,image1);    //拉普拉斯算子,模板二:{-1,-1,-1,-1,8,-1, -1,-1,-1},并將梯度銳化后的圖像保存

//	BYTE *image2[2000];
//	InitImage(image2,w,h);
//	zzlb(image1,w,h,image2);    //中值濾波

//	diedaiyz(image1,w,h);    //迭代法選取閾值,二值化
	sanfenyz(image1,w,h);    //T=max-(max-min)/3,二值化

//	BYTE *image2[2000];
//	InitImage(image2,w,h);
//	zzlb(image1,w,h,image2);    //中值濾波

//	houghtrans1(image1,w,h);    //hough變換第一種算法:5x5模板
	houghtrans2(image1,w,h);    //hough變換第二種算法:循環hough,多次提取最長直線
	return 1;
}

void houghtrans1(BYTE *image_in[2000],int w,int h)  //hough變換第一種算法
{
	double t=3.1415926;
	t=t/180;
	int rmax=w+h+1;
	int *hough[180];
	int k,r;
	for(k=0;k<180;k++)
		hough[k]=(int *)new int[rmax];
	for(k=0;k<180;k++)
		for(r=0;r<rmax;r++)
			hough[k][r]=0;
	int i,j;
	for(i=0;i<h;i++)     //將大于0的點標記為255,即白點
		                 //自己繪制的圖像中可能存在一些點既不是0也不是255,另外為了避免由于前期處理不當導致hough失敗
		for(j=0;j<w;j++)
		{if(image_in[i][j]>0)image_in[i][j]=255;}

	for(i=0;i<h;i++)     //對原圖中的白點做hough變換
	for(j=0;j<w;j++)
	{
		if(image_in[i][j]==255)
		{
			for(k=0;k<180;k++)
			{
			r=(int)(j*cos(k*t)+i*sin(k*t));
			if(r<0)r+=w+h+1;
			hough[k][r]++;
			}
		}
	}
	BYTE *image_out[2000];
	InitImage(image_out,w,h);
	for(k=0;k<180;k++)         //尋找數組hough[][]的各個峰值,采用5x5模板算法
		for(r=0;r<rmax;r++)	
		{
			if(hough[k][r]>houghthresh)
			{
				int tag=1;
				int dk,dr,dkt,drt;
				for(dk=k-2;dk<=k+2;dk++)
				{
					for(dr=r-2;dr<=r+2;dr++)
					{
						if(dk<0)dkt=dk+180;
						else if(dk>=180)dkt=dk-180;
						else dkt=dk;
						if(dr<0)drt=dr+w+h+1;
						else drt=dr;
						if(drt<rmax&&hough[dkt][drt]>hough[k][r])
						{tag=0;break;}
					}
					if(tag==0)break;
				}
				if(tag==1)
				{
				//	makeline1(image_in,w,h,t,k,r,image_out);   //尋找到一條直線立即繪制
					makeline2(image_in,w,h,t,k,r,image_out);
				}
			}
		}
	SaveRawFile(image_out,w,h,"E:\\peacock_hough.raw");
}

void houghtrans2(BYTE *image_in[2000],int w,int h)  //hough變換第二種算法
{
	BYTE *image_out[2000];
	InitImage(image_out,w,h);
	double t=3.1415926;
	t=t/180;
	int rmax=w+h+1;
	int *hough[180];
	int k,r;
	for(k=0;k<180;k++)
		hough[k]=(int *)new int[rmax];
	int i,j;
	for(i=0;i<h;i++)
	for(j=0;j<w;j++)
		if(image_in[i][j]>0)image_in[i][j]=255;//此處以上與算法一相同
		
	while(1)                     //對hough變換的全部過程做循環
	{
	for(k=0;k<180;k++)
		for(r=0;r<rmax;r++)
			hough[k][r]=0;
	for(i=0;i<h;i++)                  //對原圖作hough變換,同算法一
	for(j=0;j<w;j++)
	{
		if(image_in[i][j]==255)
		{
			for(k=0;k<180;k++)
			{
			r=(int)(j*cos(k*t)+i*sin(k*t));
			if(r<0)r+=w+h+1;
			hough[k][r]++;
			}
		}
	} 

	int max=0,max_k,max_r;                //尋找最長的一條直線
	for(k=0;k<180;k++)
	for(r=0;r<rmax;r++)
	{
		if(hough[k][r]>max)
		{
			max=hough[k][r];
			max_k=k;
			max_r=r;
		}
	}
	if(max<houghthresh)break;                //當最大值小于設定的臨界值時,循環結束
//	makeline1(image_in,w,h,t,max_k,max_r,image_out);
	makeline2(image_in,w,h,t,max_k,max_r,image_out);
	}
	SaveRawFile(image_out,w,h,"E:\\peacock_hough.raw");
}


//繪制直線算法一
void makeline1(BYTE *image_in[2000],int w,int h,double t,int k,int r,BYTE *image_out[2000])
{
	int i,j,temp;
	for(i=0;i<h;i++)   //重新對數組上的白點作hough變換,如果發現某點落在(k,r)的區域內,在原圖與新圖中均做標記。
		for(j=0;j<w;j++)
		{
			if(image_in[i][j]==255)
			{
				temp=(int)(j*cos(k*t)+i*sin(k*t));
				if(temp<0)temp+=w+h+1;
				if(temp==r)
				{image_in[i][j]=250;image_out[i][j]=255;}
			}
		}
}


//繪制圖像算法二
void makeline2(BYTE *image_in[2000],int w,int h,double t,int k,int r,BYTE *image_out[2000])
{
	int i,j,temp;
	for(i=0;i<h;i++)   //對原圖重新作hough變換,標記已經提取到的直線(k,r)上的白點
		for(j=0;j<w;j++)
		{
			if(image_in[i][j]==255)
			{
				temp=(int)(j*cos(k*t)+i*sin(k*t));
				if(temp<0)temp+=w+h+1;
				if(temp==r)
				{image_in[i][j]=250;}
			}
		}
	for(j=0;j<w;j++)   //在輸出數組image_out[][]中通過逆函數繪制直線
	{
		if(k!=0)
		{
		if(k>90&&k<180&&r>h)r-=w+h+1;
		i=(int)(r/sin(k*t)-j/tan(k*t));	
		if(i>=0&&i<h)image_out[i][j]=255;
		}
	}
}

//以下為二值化,梯度銳化,中值濾波等函數,不做注釋!
void diedaiyz(BYTE *image[2000],int w,int h)
{
	int i,j;
	int count[256];
	for(i=0;i<256;i++)
		count[i]=0;
	for(i=0;i<h;i++)
		for(j=0;j<w;j++)
			count[image[i][j]]++;
	int T=100;
	while(1)
	{
		int temp=T;
		int t1=0,t2=0,t3=0,t4=0;
		for(i=0;i<=temp;i++)
		{t1+=count[i];t3+=count[i]*i;}
		for(i=temp+1;i<256;i++)
		{t2+=count[i];t4+=count[i]*i;}
		T=(int)((t3/t1+t4/t2)/2);
		if(T==temp)break;
	}
	for(i=0;i<h;i++)
		for(j=0;j<w;j++)
			if(image[i][j]>=T)image[i][j]=255;
			else image[i][j]=0;
	SaveRawFile(image,w,h,"E:\\peacock_diedaiyz.raw");
}

void sanfenyz(BYTE *image[2000],int w,int h)
{
	int i,j;
	int fmax=0,fmin=255;
	for(i=0;i<h;i++)
		for(j=0;j<w;j++)
		{
			if(image[i][j]>fmax)fmax=image[i][j];
			if(image[i][j]<fmin)fmin=image[i][j];
		}
	int T=fmax-(fmax-fmin)/3;
	for(i=0;i<h;i++)
		for(j=0;j<w;j++)
			if(image[i][j]>=T)image[i][j]=255;
			else image[i][j]=0;
	SaveRawFile(image,w,h,"E:\\peacock_sanfenyz.raw");
}

void sobel(BYTE *image_in[2000],int w,int h,BYTE *image_out[2000])
{
	int buf,buf1,buf2;
	int i,j;
	for(i=0;i<h;i++)
	for(j=0;j<w;j++)
	{
		if(i-1>=0&&j-1>=0&&i+1<h&&j+1<w)
		{
			//x方向
			buf1=(int)image_in[i-1][j+1]+2*(int)image_in[i][j+1]+(int)image_in[i+1][j+1];
			buf1=buf1-(int)image_in[i-1][j-1]-2*(int)image_in[i][j-1]-(int)image_in[i+1][j-1];
			//y方向
			buf2=(int)image_in[i-1][j-1]+2*(int)image_in[i-1][j]+(int)image_in[i-1][j+1];
			buf2=buf2-(int)image_in[i+1][j-1]-2*(int)image_in[i+1][j]-(int)image_in[i+1][j+1];
			buf=abs(buf1)+abs(buf2);
			if(buf>255)buf=255;
			if(buf<0)buf=0;
			image_out[i][j]=(BYTE)buf;
		}
		else
		image_out[i][j]=(BYTE)0;
	}
	SaveRawFile(image_out,w,h,"E:\\peacock_sobel.raw");
}

void lapla1(BYTE *image_in[2000],int w,int h,BYTE *image_out[2000])
{
	int buf;
	int i,j;
	for(i=0;i<h;i++)
	for(j=0;j<w;j++)
	{
		if(i-1>=0&&j-1>=0&&i+1<h&&j+1<w)
		{
			//x方向
			buf=4*(int)image_in[i][j]-(int)image_in[i-1][j]-(int)image_in[i][j-1]
				-(int)image_in[i][j+1]-(int)image_in[i+1][j];
			if(buf>255)buf=255;
			if(buf<0)buf=0;
			image_out[i][j]=(BYTE)buf;
		}
		else
		image_out[i][j]=(BYTE)0;
	}
	SaveRawFile(image_out,w,h,"E:\\peacock_lapla1.raw");
}

void lapla2(BYTE *image_in[2000],int w,int h,BYTE *image_out[2000])
{
	int buf;
	int i,j;
	for(i=0;i<h;i++)
	for(j=0;j<w;j++)
	{
		if(i-1>=0&&j-1>=0&&i+1<h&&j+1<w)
		{
			//x方向
			buf=8*(int)image_in[i][j]-(int)image_in[i-1][j-1]-(int)image_in[i-1][j]-(int)image_in[i-1][j+1]
				-(int)image_in[i][j-1]-(int)image_in[i][j+1]-(int)image_in[i+1][j-1]
				-(int)image_in[i+1][j]-(int)image_in[i+1][j+1];
			if(buf>255)buf=255;
			if(buf<0)buf=0;
			image_out[i][j]=(BYTE)buf;
		}
		else
		image_out[i][j]=(BYTE)0;
	}
	SaveRawFile(image_out,w,h,"E:\\peacock_lapla2.raw");
}


void zzlb(BYTE *image_in[2000],int w,int h,BYTE *image_out[2000])
{
	int value[9];
	int i,j;
	for(i=1;i<h-1;i++)
	for(j=1;j<w-1;j++)
	{
		value[0]=image_in[i-1][j-1];
		value[1]=image_in[i-1][j];
		value[2]=image_in[i-1][j+1];
		value[3]=image_in[i][j-1];
		value[4]=image_in[i][j];
		value[5]=image_in[i][j+1];
		value[6]=image_in[i+1][j-1];
		value[7]=image_in[i+1][j];
		value[8]=image_in[i+1][j+1];
		image_out[i][j]=medianvalue(value);
	}
	SaveRawFile(image_out,w,h,"E:\\peacock_zzlb.raw");
}

int medianvalue(int *value)
{
	int i,j,temp;
	for(i=0;i<=7;i++)
		for(j=0;j<=7-i;j++)
		{
			if(value[j]>value[j+1])
			{
				temp=value[j+1];
				value[j+1]=value[j];
				value[j]=temp;
			}
		}
	return value[4];
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲成人自拍偷拍| 成人午夜私人影院| 成人国产亚洲欧美成人综合网| 91福利精品视频| 久久综合色婷婷| 亚洲成人久久影院| www.av亚洲| 久久综合久久综合久久综合| 亚洲成a天堂v人片| 成人avav影音| 久久综合久久综合久久综合| 性做久久久久久免费观看| 波多野结衣亚洲| 精品久久久影院| 视频一区中文字幕国产| 色综合天天综合给合国产| 国产欧美综合在线观看第十页| 婷婷久久综合九色综合伊人色| 国产suv精品一区二区883| 欧美一区二区三区在线观看视频| 一区av在线播放| 99热这里都是精品| 国产精品美女久久久久久久久久久| 蜜桃av一区二区| 欧美一区二区高清| 手机精品视频在线观看| 欧美午夜精品久久久久久孕妇| 最新国产精品久久精品| 国产成人av网站| 欧美激情在线免费观看| 国产美女精品人人做人人爽| 精品国精品国产| 国内成+人亚洲+欧美+综合在线| 欧美一区二区三区在线视频| 日韩和欧美的一区| 91精品国产高清一区二区三区蜜臀| 亚洲电影激情视频网站| 欧美日韩精品电影| 日韩中文欧美在线| 日韩亚洲国产中文字幕欧美| 麻豆精品在线看| 欧美精品一区二区久久久| 国产一区二区三区蝌蚪| 国产欧美一区二区三区鸳鸯浴| 国产成人丝袜美腿| 日韩一区在线播放| 色88888久久久久久影院野外| 一区二区三区免费看视频| 欧美亚洲综合久久| 男人的天堂亚洲一区| 欧美tickling挠脚心丨vk| 国内精品国产成人国产三级粉色| 久久精品人人爽人人爽| 99精品一区二区| 亚洲国产视频a| 日韩一区二区三区观看| 国产福利一区二区三区在线视频| 国产精品麻豆一区二区| 在线观看亚洲精品视频| 美女一区二区久久| 国产日本欧美一区二区| 在线精品观看国产| 久久国产尿小便嘘嘘| 国产精品五月天| 欧美日韩中文精品| 国产一区二区在线观看免费| 国产精品久久久久久户外露出 | 亚洲色图19p| 欧美一级视频精品观看| 高清不卡在线观看av| 亚洲一区在线观看免费观看电影高清| 91超碰这里只有精品国产| 国产精品99久久久| 亚洲一区二区三区国产| 久久综合色天天久久综合图片| 一本大道久久a久久综合| 麻豆91在线播放| 亚洲日本乱码在线观看| 精品久久久久av影院| 色综合久久综合中文综合网| 免费成人av资源网| 亚洲自拍偷拍综合| 中文欧美字幕免费| 日韩欧美视频在线| 色综合久久中文字幕综合网| 国产综合色精品一区二区三区| 亚洲午夜久久久久久久久电影院 | 亚洲人成伊人成综合网小说| 日韩欧美一卡二卡| 欧美在线不卡一区| 国产成人无遮挡在线视频| 热久久久久久久| 亚洲一区二区三区四区在线免费观看| 久久久久久久久久看片| 51精品视频一区二区三区| 91视频xxxx| 国产精品伊人色| 秋霞成人午夜伦在线观看| 一区二区三区中文在线| 中文乱码免费一区二区| 久久久欧美精品sm网站| 日韩一级片网站| 91精品国产综合久久久久久| 欧洲在线/亚洲| 欧亚洲嫩模精品一区三区| 99久久精品国产一区| 成人精品免费看| 成人激情综合网站| 成人av电影在线播放| 成av人片一区二区| 波多野结衣亚洲| 99久久99久久久精品齐齐| 成人av网址在线| 91视频你懂的| 日本欧美一区二区| 麻豆精品久久精品色综合| 奇米四色…亚洲| 韩日av一区二区| 91国产免费观看| 91在线小视频| av动漫一区二区| 99精品国产热久久91蜜凸| 国产精品一区免费在线观看| 国产宾馆实践打屁股91| 国产精品一区二区免费不卡 | 国产美女视频91| 日本欧美一区二区三区| 久久99精品久久久久久| 极品少妇xxxx精品少妇| 国产一区二区不卡在线| 精品亚洲国内自在自线福利| 天使萌一区二区三区免费观看| 亚洲精品久久久蜜桃| 一二三四区精品视频| 亚洲蜜臀av乱码久久精品蜜桃| 亚洲成人午夜影院| 亚洲图片一区二区| 日韩精品乱码免费| 日本欧美一区二区三区| 青青草原综合久久大伊人精品优势| 亚洲资源在线观看| 亚洲v日本v欧美v久久精品| 午夜成人免费视频| 久久精品国产77777蜜臀| 成人免费看的视频| 一本色道久久综合狠狠躁的推荐| 成人av在线一区二区三区| 95精品视频在线| 91美女片黄在线观看91美女| 这里只有精品免费| 久久亚洲免费视频| 国产日韩欧美a| 亚洲激情欧美激情| 精品在线免费观看| 成人的网站免费观看| 国产精品一区在线| 欧美日韩精品一区二区三区| 日韩欧美久久久| 中文字幕第一区| 国产精品乱码一区二区三区软件| 亚洲高清免费观看高清完整版在线观看| 日韩精品色哟哟| 国产成人夜色高潮福利影视| 91丨porny丨中文| 国产亚洲午夜高清国产拍精品| 亚洲日本在线a| 人人狠狠综合久久亚洲| 成人福利在线看| 欧美日韩精品欧美日韩精品| 久久先锋影音av| 一区二区视频在线| 国产在线视频不卡二| 日本高清成人免费播放| 欧美精品一区二区高清在线观看| 国产精品乱人伦中文| 美女视频黄a大片欧美| 成人免费av网站| 欧美亚洲图片小说| 国产精品不卡一区二区三区| 秋霞午夜鲁丝一区二区老狼| 91污片在线观看| 欧美日产国产精品| 亚洲自拍偷拍欧美| 粉嫩一区二区三区在线看| 7777精品伊人久久久大香线蕉完整版 | 欧美美女直播网站| 国产欧美一区二区三区鸳鸯浴| 婷婷激情综合网| 欧美视频一区二区三区| 中文字幕免费不卡在线| 亚洲精品国产精品乱码不99| 国产精品影音先锋| 国产精品传媒视频| 麻豆91精品视频| 日韩一区二区三区电影在线观看| 亚洲精品免费看| 白白色 亚洲乱淫| 久久精品视频网| 国产91富婆露脸刺激对白| 久久人人97超碰com|