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

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

?? hilbert.c

?? 圖像置亂代碼
?? C
字號:
/*---------------------------------------------------------------------------*    hilbert transformation* ---------------------------------------------------------------------------*/#include <tina/all_tina.h>#include "bmp.h"
#define MAXPATHLEN 64static char directory_name[MAXPATHLEN];static char file_name[MAXPATHLEN];static char pathname[MAXPATHLEN];
static void *pdir=0, *pfile=0;static int SCRAM_n = 1;static Tv *tv = NULL;static Tv *tv1=NULL;
static int x = -1, y = 0;
static int i = 0, j = 0;
static int width;

static void step(int dir, int **r, int **c)
{
	/*int x0 = x, y0 = y;*/

	switch(dir & 3)
	{
		case 0: x = x + 1; break;
		case 1: y = y + 1; break;
		case 2: x = x - 1; break;
		case 3: y = y - 1; break;
	}
	/*if(x0 >= 0) tv_linexy(tv, x0*10, y0*10, x*10, y*10);*/
	if(j == width)
	{
		j = 0;
		++i;
	}
	r[y][x] = i;
	c[y][x] = j++;
}

static void hilbert(int dir, int rot, int order, int **r, int **c)
{
	if(order == 0) return;

	dir += rot;
	hilbert(dir, -rot, order-1, r, c);
	step(dir, r, c);
	dir = dir - rot;
	hilbert(dir, rot, order-1, r, c);
	step(dir, r, c);
	hilbert(dir, rot, order-1, r, c);
	dir = dir - rot;
	step(dir, r, c);
	hilbert(dir, -rot, order-1, r, c);
}

static void hilbert_curve(int order, int **r, int **c)
{
	x = -1, y = 0;
	i = 0, j = 0;
	width = 1;
	int k;
	for(k = 0; k < order; k++) width *= 2;
	step(0, r, c);
	hilbert(0, 1, order, r, c);
}/*---------------------------------------------------------------------------     To generate the scrambling mapping-matrix of hilbert transformation. ---------------------------------------------------------------------------*/void hilbert_matrix(int** r, int** c, int height, int width)
{
	int i, lev = 1;
    while((int)pow(2,lev) < height) lev++;
	printf("\nHilbert transform\n");
	hilbert_curve(lev, r, c);
} /*---------------------------------------------------------------------------  To generate the inverse scrambling mapping-matrix of hilbert transformation. ---------------------------------------------------------------------------*/void r_hilbert_matrix(int** src_r,int** src_c, int height, int width){	int i,j,r,c;	int **trans_r, **trans_c;
	trans_r = int_matrix(height, width);
	trans_c = int_matrix(height, width);	hilbert_matrix(trans_r, trans_c, height, width);	printf("\nR_Hilbert transform\n");	for(i = 0; i < height; i++)
	{
		for(j = 0; j < width; j++)
		{
			r = trans_r[i][j];
			c = trans_c[i][j];
			src_r[r][c] = i;
			src_c[r][c] = j;
		}
	}	free_int_matrix(trans_r, height);
	free_int_matrix(trans_c, height);}static 	Imrect *read_image(void){	Imrect *srcIm;/*----------------Read the image---------------------------*/  	(void) strip_spaces(file_name);  	(void) strip_spaces(directory_name);  	(void) string_append(pathname, directory_name, "/", file_name, NULL);	srcIm = ReadGIF(pathname, 1);/*------------------------------------------------*/	return(srcIm);} /*---------------------------------------------------------------------------     hilbert transformation ---------------------------------------------------------------------------*/void Hilbert_Trans(int nTrans)
{
	Imrect *srcIm,*destIm,*tmpIm;
	int width, height;
	Imregion *roi;	int i,j,k;	int type;
	BYTE pix;/*	if (stack_check_types(IMRECT, NULL) == false)
	{
		error("Hilbert : wrong types on stack", warning);
		return;
	}	srcIm = (Imrect *) stack_pop(&type);*/	srcIm = read_image();	//srcIm = DrawRGB_proc();
	width = srcIm->width;
    	height = srcIm->height;
	if (width != height)
	{
		error("Hilbert:width != height", warning);
		return;
	}

	roi = srcIm->region;
	if (roi == NULL) return ;/*------------------------------------------------*/	int **trans_r, **trans_c;
	trans_r = int_matrix(height, width);
	trans_c = int_matrix(height, width);	hilbert_matrix(trans_r, trans_c, height, width);/*------------------------------------------------*/
	printf("\n\n=== Hilbert Transform begin: ===\n");	destIm = im_alloc( height, width, roi, int_v );	int r,c;
	for( k = 0; k < SCRAM_n; k++)
	{			for (i = 0; i < height  ; i++)
		{
			for (j = 0; j< width ; j++)
			{								IM_PIX_GET(srcIm, i, j, pix);
				IM_PIX_SET(destIm, trans_r[i][j], trans_c[i][j], pix);
			}
		}
 		tmpIm = srcIm;
		srcIm = destIm;
		destIm = tmpIm;	}/*----------------------Save the image as .gif--------------------------*/	char filename[64];	char string[25];	gcvt(k,5,string);	printf("string=%s\n",string);	char *filename0 ="result/Hilbert/";	strcpy(filename,filename0);	//strcat(filename,file_name);	strcat(filename,"Hilbert_");	strcat(filename, string);	strcat(filename,".gif");	//gif_write_file(srcIm,filename);	gif_write_file_color(srcIm,filename);	//strcat(filename,".bmp");	//ImrectToBMP8(srcIm,filename);//}/*------------------------------------------------*/	tv_imrect2(tv1, srcIm);	im_free(destIm);	free_int_matrix(trans_r, height);
	free_int_matrix(trans_c, height);	printf("=== Hilbert transform complete! ===\n");
}
/*---------------------------------------------------------------------------    inverse hilbert transformation ---------------------------------------------------------------------------*/void R_Hilbert_Trans(int nTrans)
{
	Imrect *srcIm,*destIm,*tmpIm;
	int width, height;
	Imregion *roi;	int i,j,k;	int type;
	BYTE pix;/*	if (stack_check_types(IMRECT, NULL) == false)
	{
		error("Hilbert : wrong types on stack", warning);
		return;
	}	srcIm = (Imrect *) stack_pop(&type);*/	srcIm = read_image();
	width = srcIm->width;
    	height = srcIm->height;
	if (width != height)
	{
		error("R_Hilbert:width != height", warning);
		return;
	}

	roi = srcIm->region;
	if (roi == NULL) return ;
/*------------------------------------------------*/	int **trans_r, **trans_c;
	trans_r = int_matrix(height, width);
	trans_c = int_matrix(height, width);	r_hilbert_matrix(trans_r, trans_c, height, width);/*------------------------------------------------*/
	printf("\n\n=== R_Hilbert Transform begin: ===\n");	destIm = im_alloc( height, width, roi, int_v );	int r,c;
	for( k = 0; k < SCRAM_n; k++)
	{			for (i = 0; i < height  ; i++)
		{
			for (j = 0; j< width ; j++)
			{								IM_PIX_GET(srcIm, i, j, pix);
				IM_PIX_SET(destIm, trans_r[i][j], trans_c[i][j], pix);
			}
		}
 		tmpIm = srcIm;
		srcIm = destIm;
		destIm = tmpIm;	}/*----------------------Save the image as .gif--------------------------*/	char filename[64];	char string[25];	gcvt(k,5,string);	printf("string=%s\n",string);	char *filename0 ="result/Hilbert/";	strcpy(filename,filename0);	strcat(filename,file_name);	strcat(filename,"+R_Hilbert_");	strcat(filename, string);	strcat(filename,".gif");	gif_write_file(srcIm,filename);/*------------------------------------------------*/	tv_imrect2(tv1, srcIm);	im_free(destIm);	free_int_matrix(trans_r, height);
	free_int_matrix(trans_c, height);	printf("=== R_Hilbert transform complete! ===\n");
}static void tv_choice_proc(choice)
int     choice;
{
    switch (choice)
    	{
    	case 0: tv_set_next(tv);
		break;
    	case 1: tv_set_next(tv1);
		break;
    	default:error("tv_choice_proc: unknown choice\n", warning);
		break;
    	}}static void scan_proc(void){    scan_files(directory_name,file_name);    tw_sglobal_reset(pdir);    tw_sglobal_reset(pfile);}void            Hilbert_tool(int x, int y)
{
	static void *tool = NULL;
	static void tv_choice_proc();	if (tool)
	{
		tw_show_tool(tool);
		return;
	}
	tool = (void *)tw_tool("Hilbert Scrambling tool", x, y);    	/* Initialise pathname from environment variable (or #define) */    	(void) environ_pathname_get(directory_name, file_name,				"TINA_IMAGE_DEFAULT",				"/home/wzz/newimscramdegree/result/Hilbert/gRGB.gif");	tv = tv_create("Hilbert original");
     	tv1 = tv_create("Hilbert scrambled");
        tw_choice("Tv choice", tv_choice_proc, 0, "original","scrambled", NULL);	tw_newrow();
	tw_newrow();	/*---------------------------*/  	pdir = (void *) tw_sglobal("Directory:", directory_name, 32);    	tw_button("scan", scan_proc, NULL);  	tw_newrow();  	pfile = (void*) tw_sglobal("File:", file_name, 32);  	tw_newrow();	/*---------------------------*/	tw_iglobal("Scrambling times = ", &SCRAM_n, 5);
	tw_newrow();
	tw_button("Hilbert", Hilbert_Trans,NULL);	tw_button("R_Hilbert", R_Hilbert_Trans,NULL);	tw_newrow();	tw_newrow();
	tw_end_tool();
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲视频图片小说| 欧美中文字幕一区二区三区亚洲| 中文字幕亚洲一区二区av在线| 欧美tk丨vk视频| 日韩欧美国产电影| 欧美成人女星排名| 欧美一卡二卡在线| 欧美一级在线免费| 欧美成va人片在线观看| 91精品国产91久久久久久一区二区| 欧美日韩一区视频| 91精品欧美福利在线观看| 69堂国产成人免费视频| 日韩免费福利电影在线观看| 欧美精品一区在线观看| 国产三级精品在线| 亚洲视频在线观看一区| 亚洲一区二区3| 日韩极品在线观看| 国产麻豆日韩欧美久久| 成人亚洲一区二区一| 91在线视频观看| 欧美日韩国产三级| 精品剧情在线观看| 1区2区3区国产精品| 亚洲第一电影网| 国产精品夜夜嗨| 色婷婷av一区二区三区软件| 欧美日韩精品一区二区三区四区| 日韩一区二区三区免费看| 久久精品一级爱片| 一区二区三区精品视频在线| 日韩av电影免费观看高清完整版在线观看| 免费精品视频在线| av色综合久久天堂av综合| 69堂成人精品免费视频| 国产色91在线| 婷婷激情综合网| 成人黄色a**站在线观看| 欧美放荡的少妇| 国产情人综合久久777777| 亚洲电影一区二区三区| 国产福利91精品| 欧美精品18+| 日韩一区有码在线| 黄色日韩三级电影| 欧美丝袜自拍制服另类| 国产网站一区二区| 日本亚洲三级在线| 欧美性受xxxx黑人xyx性爽| 国产亚洲欧美中文| 久久精品99国产精品日本| 欧美亚洲综合色| 国产精品国产三级国产a| 免费的成人av| 欧美精品久久天天躁| 成人欧美一区二区三区白人| 国产成人亚洲综合a∨猫咪| 日韩一区二区在线观看| 亚洲第一搞黄网站| 色哟哟亚洲精品| 国产精品美女久久久久久久久 | 97久久久精品综合88久久| 欧美v日韩v国产v| 日韩精品免费专区| 欧美色成人综合| 亚洲国产精品久久人人爱蜜臀| av一区二区不卡| 国产欧美日韩综合精品一区二区| 蜜桃视频在线观看一区| 欧美一区二区三区视频在线观看| 亚洲综合男人的天堂| 色综合一区二区三区| 亚洲欧美自拍偷拍色图| av在线不卡电影| 国产精品久久久久久亚洲伦| 国产成人精品网址| 国产亚洲精品中文字幕| 国产一区二区在线观看视频| 精品久久久久久亚洲综合网| 久久国内精品视频| 精品国产乱码久久久久久闺蜜| 美女视频网站黄色亚洲| www激情久久| 国产91综合网| 亚洲婷婷综合久久一本伊一区| 不卡电影一区二区三区| 亚洲精品欧美激情| 欧美三级一区二区| 亚洲成人动漫av| 精品三级在线观看| 国产高清不卡一区| 亚洲人亚洲人成电影网站色| 91福利国产成人精品照片| 性久久久久久久久| 精品国产乱码久久久久久牛牛 | 欧美伊人久久久久久久久影院| 亚洲精品日产精品乱码不卡| 欧美日韩国产片| 国产一区二区福利视频| 亚洲天堂免费看| 欧美日韩你懂的| 国产一区视频导航| 亚洲人妖av一区二区| 91精品国产综合久久精品app| 麻豆精品蜜桃视频网站| 亚洲国产精品av| 欧美日韩性生活| 国产精品夜夜嗨| 五月婷婷综合在线| 久久久久久久网| 精品视频在线免费观看| 国产一区二区精品久久99| 亚洲图片欧美视频| 国产亚洲精品bt天堂精选| 欧美日韩一区二区欧美激情| 国产一区二区精品久久| 亚洲一区二区三区四区在线免费观看 | 精品一区二区三区在线观看 | 狠狠v欧美v日韩v亚洲ⅴ| 久久久亚洲精华液精华液精华液| 97se亚洲国产综合自在线| 免费高清不卡av| 伊人夜夜躁av伊人久久| 国产欧美综合在线观看第十页| 日本久久精品电影| 国产精品一区二区三区网站| 亚洲gay无套男同| 中文字幕亚洲精品在线观看| 日韩欧美电影一区| 在线免费精品视频| zzijzzij亚洲日本少妇熟睡| 麻豆成人久久精品二区三区小说| 亚洲日本中文字幕区| 国产欧美综合在线观看第十页| 日韩丝袜美女视频| 在线综合视频播放| 欧美亚洲动漫另类| 99精品欧美一区二区三区小说| 国产一区二区三区香蕉| 奇米精品一区二区三区四区| 亚洲精品乱码久久久久久| 亚洲国产成人一区二区三区| 2022国产精品视频| 日韩欧美亚洲国产另类 | 精品综合免费视频观看| 亚洲国产一区在线观看| 伊人开心综合网| 一区二区在线观看av| 亚洲欧美aⅴ...| 国产精品国产三级国产| 《视频一区视频二区| 国产精品第一页第二页第三页| 久久久99精品久久| 久久九九久久九九| 中文一区二区在线观看| 亚洲国产精品高清| 亚洲色图欧洲色图| 亚洲人成7777| 一区二区三区国产精华| 亚洲精品国产a| 亚洲成va人在线观看| 日韩国产欧美在线观看| 日韩av一区二区三区四区| 精品一区二区综合| 国产精品一区二区91| 成人短视频下载| 一本大道av伊人久久综合| 欧美亚洲综合另类| 欧美一级xxx| 国产日产欧美一区| 中文字幕亚洲区| 无吗不卡中文字幕| 国产一区视频在线看| 91在线一区二区| 欧美人与性动xxxx| 精品国内二区三区| 综合久久综合久久| 午夜伊人狠狠久久| 国产精品系列在线观看| 色一情一乱一乱一91av| 日韩一二三区视频| 中文天堂在线一区| 午夜在线成人av| 国产999精品久久久久久绿帽| 色嗨嗨av一区二区三区| 日韩欧美不卡在线观看视频| 国产精品欧美一区二区三区| 亚洲成a人片在线不卡一二三区 | 99这里都是精品| 欧美精品成人一区二区三区四区| 精品久久久久久亚洲综合网| 亚洲精品国产无天堂网2021| 极品美女销魂一区二区三区| 91在线观看污| 久久综合国产精品| 亚洲国产一区二区在线播放| 国产iv一区二区三区| 777久久久精品| 亚洲日本在线视频观看|