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

? 歡迎來(lái)到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? fourier.h

?? 實(shí)現(xiàn)jpeg的壓縮編碼功能 在demo2的工程文件中即可查看
?? H
字號(hào):
/*************************************************************
Filename:	Fourier.h.
Writer:		Dai Zhiheng.
Time:		2005-3-27.
**************************************************************/
#include <math.h>
#include "myComplex.h"
#define PI	3.141593
/*************************************************************
函數(shù)功能:	產(chǎn)生倒序序列
			case inout r = 3; this function will format *a as
			{0、4、2、6、1、5、3、7}
**************************************************************/
void reverseOrder(int *a, int r)
{
	int count = 1 << r ;
	for(int j = 0; j < count; j++)
	{
		int p=0;
		for(int i = 0; i < r; i++)
		{
			if (j & (1<<i))
			{
					p += 1 << (r-i-1);
			}
		}
		*(a+j) = p;
	}
}
/*************************************************************
函數(shù)功能:	求矩陣的轉(zhuǎn)置
parameter:
			*f		數(shù)據(jù)指針
			m,n		矩陣維數(shù)
**************************************************************/
void complexArrayT( double *f, long m, long n)
{
	double *X = new  double [m*n*2];
	for(int i=0; i<m; i++)
		for(int j=0; j<n; j++)
		{
			*(X + i*2 + m*j*2) = *(f + i*n*2 +j*2);
			*(X + i*2 + m*j*2 +1) = *(f + i*n*2 +j*2 +1);
		}
	for(long t=0; t<m*n*2; t++)
		*(f+t) = *(X+t);
	delete [] X;
}
/*************************************************************
函數(shù)功能:	1-D,count行,r階Fourier變換
parameter:
			*f		時(shí)域數(shù)據(jù)的指針
			*F		頻域數(shù)據(jù)的指針
			 r		Fourier變換的階數(shù)基數(shù)
**************************************************************/
void DLineFourier(double *f, double *F, long r)
{
	int count = 1 << r ;
	int bfSize;
	int p;
	int *order = new int [count];
	double *W  = new double [count];
	double *X  = new double [count*count*2];
	double *X1 = new double [count*count*2];
	double *X2 = new double [count*count*2];
	//計(jì)算變換基W
	for(int i=0; i<count/2; i++)
	{
		double angle =-i*2*PI/count;
		*(W + i*2) = cos( angle ) ;
		*(W + i*2 + 1) = sin( angle ) ;
	}

	//產(chǎn)生倒序序列
	reverseOrder(order, r);
	//數(shù)據(jù)從 f (按每行)倒序到 X1
	for(int m=0; m< count; m++)
		for(int n=0; n< count; n++)
		{
			*(X1 + count*m*2 + n*2) = *(f + count*m*2 + (*(order+n))*2 );
			*(X1 + count*m*2 + n*2 + 1) = *(f + count*m*2 + (*(order+n))*2 +1 );
		}
		
	//Butterfly algorithm
	for(int l=0; l< count; l++)
	{
		for(int k=0; k<r; k++ )
		{	
			for(int j=0; j< 1<<(r-k-1); j++)
			{
				bfSize = 1<<k;
				for(int i=0; i<bfSize; i++)
				{
					p = j*bfSize*2;
					double *A  = new double[2];
					complexMUL(A, X1 + count*l*2 + i*2 + p*2 + bfSize*2, W + i*(1<<(r-k)) );
					complexADD(X2 + count*l*2 + i*2 + p*2 , X1 + count*l*2 + i*2 + p*2 , A);
					
					complexDEC(X2 + count*l*2 + i*2 + p*2 + bfSize*2, X1 + count*l*2 + i*2 + p*2, A);
					delete [] A;
				}
			}
			//交換數(shù)據(jù)
			for( int m=0; m< count*2; m++)
			{
				*(X + count*l*2 + m)	= *(X1 + count*l*2 + m);
			}
			for( m=0; m< count*2; m++)
			{
				*(X1 + count*l*2 + m)	= *(X2 + count*l*2 + m);
			}
			for( m=0; m< count*2; m++)
			{
				*(X2 + count*l*2 + m)	= *(X  + count*l*2 + m);
			}
		}
	}

	for(long t=0; t<count*count*2; t++)
	{
		*(F+t) = *(X1 + t);
	}
	delete [] W;
	delete [] order;
	delete [] X;
	delete [] X1;
	delete [] X2;
}
/*************************************************************
函數(shù)功能:	2-D,count行,count列,r階Fourier變換
parameter:
			*f		時(shí)域數(shù)據(jù)的指針
			*F		頻域數(shù)據(jù)的指針
			 r		Fourier變換的階數(shù)基數(shù)
**************************************************************/
void D2Fourier( double *f,  double *F, long r)
{
	int count = 1 << r ;
	double *X1 = new  double [count*count*2];
	double *X2 = new  double [count*count*2];
	//行的Fourier變換
	DLineFourier(f, X1, r);
	//轉(zhuǎn)置
	complexArrayT(X1, count, count);
	//列的Fourier變換
	DLineFourier(X1, X2, r);
	//轉(zhuǎn)置
	complexArrayT(X2, count, count);
	for(long m=0; m< count*count*2; m++)
		{
			*(F + m) = *(X2 + m);
		}
	delete [] X1;
	delete [] X2;
}
/*************************************************************
函數(shù)功能:	2-D圖象的r階Fourier變換
parameter:
			*f		時(shí)域數(shù)據(jù)的指針
			*F		頻域數(shù)據(jù)的指針
			 height	圖片的長(zhǎng)度
			 width	圖片的寬度
			 r		Fourier變換的階數(shù)基數(shù)
**************************************************************/
void D2BMPFourier( double *f,  double *F, long height, long width, long r)
{
	int count = 1 << r ;
	double *X1 = new  double [count*count*2];
	double *X2 = new  double [count*count*2];
	for(int i=0; i<(height/count); i++)
		for(int j=0; j<(width/count); j++)
		{
			//對(duì)于每個(gè)count * count 塊
			for(int m=0; m< count; m++)
				for(int n=0; n< count*2; n++)
				{
					*(X1 + m*count*2 +n) = *(f + width*i*count*2 + width*m*2 + count*j*2 + n);
				}
			//塊的Fourier變換
			D2Fourier(X1, X2, r);
			//將數(shù)據(jù)輸出到頻域
			for(m=0; m< count; m++)
				for(int n=0; n< count*2; n++)
				{
					*(F + width*i*count*2 + width*m*2 + count*j*2 + n) = *(X2 + m*count*2 +n);
				}
		}
	delete [] X1;
	delete [] X2;
}
/*************************************************************
函數(shù)功能:	2-D,count行,count列,r階Fourier變換
parameter:
			*f		時(shí)域數(shù)據(jù)的指針
			*F		頻域數(shù)據(jù)的指針
			 r		Fourier變換的階數(shù)基數(shù)
**************************************************************/
void ID2Fourier( double *f,  double *F, long r)
{
	int count = 1 << r ;
	double *X1 = new  double [count*count*2];
	double *X2 = new  double [count*count*2];

	//行的Fourier變換
	//求復(fù)共軛
	for(int m=0; m< count; m++)
		for(int n=0; n< count; n++)
			{
				*(X1 + m*count*2 + n*2 ) = *(f + m*count*2 + n*2 );
				*(X1 + m*count*2 + n*2 +1) = -*(f + m*count*2 + n*2 +1);
			}
	DLineFourier(X1, X2, r);
	//求復(fù)共軛
	for(m=0; m< count; m++)
		for(int n=0; n< count; n++)
			{
				*(X1 + m*count*2 + n*2 ) = *(X2 + m*count*2 + n*2 )/count;
				*(X1 + m*count*2 + n*2 +1) = -*(X2 + m*count*2 + n*2 +1)/count;
			}

	//轉(zhuǎn)置
	complexArrayT(X1, count, count);

	//列的Fourier變換
	//求復(fù)共軛
	for(m=0; m< count; m++)
		for(int n=0; n< count; n++)
			{
				*(X2 + m*count*2 + n*2 ) = *(X1 + m*count*2 + n*2 );
				*(X2 + m*count*2 + n*2 +1) = -*(X1 + m*count*2 + n*2 +1);
			}
	DLineFourier(X2, X1, r);
	//求復(fù)共軛
	for(m=0; m< count; m++)
		for(int n=0; n< count; n++)
			{
				*(X2 + m*count*2 + n*2 ) = *(X1 + m*count*2 + n*2 )/count;
				*(X2 + m*count*2 + n*2 +1) = -*(X1 + m*count*2 + n*2 +1)/count;
			}	
	//轉(zhuǎn)置
	complexArrayT(X2, count, count);
	for(long t=0; t< count*count*2; t++)
		{
			*(F + t) = *(X2 + t);
		}
	delete [] X1;
	delete [] X2;
}
/*************************************************************
函數(shù)功能:	2-D圖象的r階Fourier逆變換
parameter:
			*F		頻域數(shù)據(jù)的指針
			*f		時(shí)域數(shù)據(jù)的指針
			 height	圖片的長(zhǎng)度
			 width	圖片的寬度
			 r		Fourier變換的階數(shù)基數(shù)
**************************************************************/
void ID2BMPFourier( double *F,  double *f, long height, long width, long r)
{
	int count = 1 << r ;
	double *X1 = new double [count*count*2];
	double *X2 = new double [count*count*2];
	for(int i=0; i<(height/count); i++)
		for(int j=0; j<(width/count); j++)
		{
			//對(duì)于每個(gè)count * count 塊
			for(int m=0; m< count; m++)
				for(int n=0; n< count*2; n++)
				{
					*(X1 + m*count*2 + n)
						= *(F + width*i*count*2 + width*m*2 + count*j*2 + n);
				}

			//塊的Fourier變換
			ID2Fourier(X1, X2, r);

			//將數(shù)據(jù)輸出至?xí)r域
			for(m=0; m< count; m++)
				for(int n=0; n< count*2; n++)
				{
					*(f + width*i*count*2 + width*m*2 + count*j*2 + n)
						= (*(X2 + m*count*2 + n));
				}
		}
	delete [] X1;
	delete [] X2;
}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久久久久久久久久久久久久99| 欧美国产在线观看| 国产91丝袜在线播放0| 亚洲大片免费看| 欧美国产激情一区二区三区蜜月| 精品视频在线看| 福利一区二区在线观看| 免费高清在线一区| 一区二区三区国产精华| 国产精品网曝门| 2020国产精品| 制服视频三区第一页精品| 色婷婷精品久久二区二区蜜臀av| 激情小说欧美图片| 日本欧美在线看| 亚洲线精品一区二区三区| 国产精品蜜臀在线观看| 精品国产乱码久久久久久牛牛| 在线免费不卡电影| 成人av影院在线| 国产一区二区影院| 精品一区二区在线看| 亚洲自拍偷拍九九九| 综合自拍亚洲综合图不卡区| 久久一区二区三区四区| 欧美一区二区女人| 91超碰这里只有精品国产| 欧美视频精品在线| 在线观看欧美精品| 在线观看亚洲专区| 91福利在线看| 在线观看www91| 色综合久久88色综合天天| 成人久久久精品乱码一区二区三区| 久久99久久99精品免视看婷婷| 日日夜夜免费精品| 日韩高清在线观看| 丝袜亚洲另类欧美| 天堂在线亚洲视频| 三级精品在线观看| 免费在线一区观看| 欧美在线免费视屏| 欧美在线播放高清精品| 欧美丝袜第三区| 欧美精品色一区二区三区| 欧美日韩aaa| 欧美日本国产视频| 欧美大片一区二区| 久久久亚洲综合| 国产精品美女久久福利网站| 国产精品美女一区二区| 中文字幕在线不卡视频| 中文字幕欧美一| 亚洲一区二区三区视频在线播放| 亚洲一卡二卡三卡四卡无卡久久 | 亚欧色一区w666天堂| 五月天久久比比资源色| 蜜桃视频一区二区| 国产美女精品人人做人人爽 | 精品一区二区三区日韩| 国产精品自拍三区| 99久久国产免费看| 欧美午夜寂寞影院| 精品国内二区三区| 中文字幕一区日韩精品欧美| 一区二区三区国产精华| 日本视频免费一区| 成人综合婷婷国产精品久久蜜臀| 成人性生交大片免费看中文 | 欧美国产日产图区| 亚洲图片你懂的| 亚洲chinese男男1069| 久久97超碰国产精品超碰| 成人aa视频在线观看| 欧美日韩性生活| 2020国产精品久久精品美国| 亚洲天堂中文字幕| 青青草国产成人99久久| 成人免费观看视频| 欧美日韩不卡在线| 中文字幕免费不卡在线| 香蕉乱码成人久久天堂爱免费| 精品亚洲免费视频| 色av一区二区| 精品福利一二区| 亚洲综合色区另类av| 国模少妇一区二区三区| 色www精品视频在线观看| 日韩女优视频免费观看| 亚洲视频在线观看三级| 美女网站一区二区| 色综合网色综合| 精品国产乱码久久久久久闺蜜| 自拍偷在线精品自拍偷无码专区| 青青草国产精品亚洲专区无| 99精品一区二区三区| 欧美不卡一二三| 91一区一区三区| 精品国产乱码久久久久久闺蜜 | 国产亚洲精品资源在线26u| 亚洲一级二级在线| 成人av小说网| 日韩欧美另类在线| 亚洲第一精品在线| 91丨九色丨黑人外教| 精品日产卡一卡二卡麻豆| 亚洲图片欧美一区| 99精品视频一区二区| 久久久久久久久岛国免费| 亚洲福利视频三区| 一本高清dvd不卡在线观看| 国产色婷婷亚洲99精品小说| 美女网站一区二区| 欧美日本在线观看| 一区二区三区在线视频观看58| 国产成人免费av在线| 日韩免费福利电影在线观看| 五月天视频一区| 欧美三级在线视频| 亚洲欧美日韩国产手机在线| 成人av影视在线观看| 中文一区二区在线观看| 国产在线一区观看| 精品不卡在线视频| 蜜臀av性久久久久av蜜臀妖精| 欧美日本一道本在线视频| 一区二区三区中文字幕精品精品| 成人h动漫精品一区二区| 欧美国产综合色视频| 国产成人综合亚洲91猫咪| 久久久一区二区三区捆绑**| 韩国精品久久久| 久久中文字幕电影| 国产老女人精品毛片久久| 久久久亚洲欧洲日产国码αv| 激情五月播播久久久精品| 精品国产凹凸成av人网站| 国产一区二区三区国产| 国产欧美一区二区在线| 成人性生交大片免费| 中文字幕一区二区视频| 91玉足脚交白嫩脚丫在线播放| 亚洲视频免费在线观看| 欧美综合亚洲图片综合区| 亚洲福利一二三区| 91精品国产欧美日韩| 国内精品国产三级国产a久久| 欧美不卡一区二区三区四区| 国产乱码精品一品二品| 综合久久一区二区三区| 91国内精品野花午夜精品| 性做久久久久久免费观看欧美| 91精品国产综合久久久久久久| 久久国产成人午夜av影院| 久久精品人人做人人爽97 | 欧美老肥妇做.爰bbww| 日韩成人免费在线| 久久久噜噜噜久久人人看 | 亚洲午夜久久久久久久久电影网 | 日韩手机在线导航| 国产伦精一区二区三区| 亚洲人成人一区二区在线观看| 欧美性xxxxx极品少妇| 久久国内精品视频| 国产精品免费看片| 欧美视频三区在线播放| 极品少妇一区二区三区精品视频| 久久精品人人做人人爽人人 | 亚洲一区精品在线| 欧美一级夜夜爽| 国产99久久精品| 一区二区三区久久| 精品国产一区二区在线观看| 成人午夜视频在线观看| 亚洲一区二区三区在线看| 日韩一区二区三区视频| 波多野洁衣一区| 日韩福利视频网| 国产精品激情偷乱一区二区∴| 色噜噜狠狠一区二区三区果冻| 日本aⅴ免费视频一区二区三区| 国产日本一区二区| 欧美狂野另类xxxxoooo| 成人手机电影网| 日韩极品在线观看| 亚洲天堂a在线| 日韩欧美中文字幕精品| 91蜜桃在线观看| 韩国欧美国产1区| 亚洲综合色自拍一区| 国产午夜精品久久久久久免费视| 91国产成人在线| 大美女一区二区三区| 美女性感视频久久| 亚洲永久精品大片| 国产精品毛片无遮挡高清| 日韩一区二区三区在线视频| 99精品黄色片免费大全| 国产精选一区二区三区| 秋霞午夜鲁丝一区二区老狼|