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

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

?? b97.c

?? 用C++語言實現的基于小波分析的源代碼,實現了小波分析的諸多算法
?? C
字號:
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <crblib/inc.h>
#include "coder.h"

#define SHIFT_BASE			tune_param
#define SHIFT_ROUNDER		(1<<(SHIFT_BASE-1))
#define	ONE					(1<<(SHIFT_BASE))

#define SHIFT(x)	(((x)+SHIFT_ROUNDER)>>SHIFT_BASE)

#define	C_A	((int)(ONE* 1.586134342  + 0.5))
#define C_B	((int)(ONE* 0.05298011854+ 0.5))
#define C_C ((int)(ONE* 0.8829110762 + 0.5))
#define C_D	((int)(ONE* 0.4435068522 + 0.5))

static void do_tdec_line(int * to,int *from,int len)
{
int x,*ptr,*low,*high,half;

	half = len>>1;

	assert(len & 1 == 0);
	assert(half >= 2);

	low  = to; high = to + half; ptr = from;
	for(x=0;x<half;x++) {
		*low  = ptr[0];
		*high = ptr[1];
		if ( x == half-1 )	*high -= SHIFT(C_A*( ptr[0] + ptr[0] ));
		else				*high -= SHIFT(C_A*( ptr[0] + ptr[2] ));
		if ( x == 0 )		*low  -= SHIFT(C_B*( high[0] + high[0]));
		else				*low  -= SHIFT(C_B*( high[0] + high[-1]));
		low++; high++; ptr += 2;
	}

	low  = to; high = to + half;
	for(x=0;x<half;x++) {
		if ( x == half-1 )	*high += SHIFT(C_C*( low[0] + low[0] ));
		else				*high += SHIFT(C_C*( low[0] + low[1] ));
		if ( x == 0 )		*low  += SHIFT(C_D*( high[0] + high[0]));
		else				*low  += SHIFT(C_D*( high[0] + high[-1]));
		low++; high++; 
	}
}

static void un_tdec_line(int *to,int *from,int len)
{
int x,*ptr,*low,*high,half;

	half = len>>1;

	low  = from; high = from + half;
	for(x=0;x<half;x++) {
		if ( x == 0 )		*low  -= SHIFT(C_D*( high[0] + high[0]));
		else				*low  -= SHIFT(C_D*( high[0] + high[-1]));
		low++; high++;
	}

	low  = from; high = from + half;
	for(x=0;x<half;x++) {
		if ( x == half-1 )	*high -= SHIFT(C_C*( low[0] + low[0] ));
		else				*high -= SHIFT(C_C*( low[0] + low[1] ));
		low++; high++;
	}

	low  = from; high = from + half; ptr = to;
	for(x=0;x<half;x++) {
		if ( x == 0 )		ptr[0] = *low  + SHIFT(C_B*( high[0] + high[0]));
		else				ptr[0] = *low  + SHIFT(C_B*( high[0] + high[-1]));
		low++; high++; ptr += 2;
	}

	low  = from; high = from + half; ptr = to;
	for(x=0;x<half;x++) {
		if ( x == half-1 )	ptr[1] = *high + SHIFT(C_A*( ptr[0] + ptr[0] ));
		else				ptr[1] = *high + SHIFT(C_A*( ptr[0] + ptr[2] ));
		low++; high++; ptr += 2;
	}
}

void b97_2D(int **rows, int width, int height, int levels,bool inverse)
{
int x, y, w, h, l;
int *buffer,*tempbuf,*temprow;

    if (width%(1 << (levels+1)) || height%(1 << (levels+1)))
		errexit("width and height must be divisible by 2^(levels+1)");
  
    /* Allocate a work array (for transposing columns) */
    
   	if ( (buffer = newarray(int,height+max(width,height)+height)) == NULL )
		errexit("malloc failed");
	temprow = buffer+height;
	tempbuf = buffer+height+height;

	if ( !inverse ) {

		for (l = 0; l < levels; l++) {
			w = width >> l;
			h = height >> l;
      
			/* Rows */
	
			do_tdec_line(temprow,rows[h-1],w);
			for (y = h-2; y >=0; y--) {
				do_tdec_line(rows[y+1],rows[y],w);
			}
	
			/* Columns */
	
			for (x = 0; x < w; x++) {
					for (y = 1; y < h; y++) buffer[y-1] = rows[y][x];
					buffer[h-1] = temprow[x];
				do_tdec_line(tempbuf,buffer,h);
					for (y = 0; y < h; y++) rows[y][x] = tempbuf[y];
			}
		}

    } else {

		for (l = levels-1; l >= 0; l--) { /** backwards in scale **/
			w = width >> l;
			h = height >> l;

			/* Columns */
	
			for (x = 0; x < w; x++) {
					for (y = 0; y < h; y++) buffer[y] = rows[y][x];
				un_tdec_line(tempbuf,buffer,h);
					for (y = 0; y < h-1; y++) rows[y+1][x] = tempbuf[y];
					temprow[x] = tempbuf[h-1];
			}

			/* Rows */
			for (y = 0; y < h-1; y++) {
				un_tdec_line(rows[y],rows[y+1],w);
			} 
			un_tdec_line(rows[h-1],temprow,w);
		}
	}

	free(buffer);
}


void b97Quad(int *band,int w,int h,int fullw,bool inverse)
{
int x, y;
int *buffer,*tempbuf,*bptr,*temprow;

   	if ( (buffer = newarray(int,h+h+max(w,h))) == NULL ) {
		errputs("malloc failed"); exit(10);
	}
	temprow = buffer+h;
	tempbuf = buffer+h+h;
  
	if ( !inverse ) { /* forward transform. */
	
		bptr = band + (h-1)*fullw;
		do_tdec_line(temprow,bptr,w);
		for (y = (h-1); y--;) {
			bptr -= fullw;
			do_tdec_line(bptr+fullw,bptr,w);
		}
    
		for (x = 0; x < w; x++) {
			bptr = band + x + fullw;
			for (y = 0; y < (h-1); y++) { buffer[y] = *bptr; bptr += fullw; }
			buffer[h-1] = temprow[x];
			do_tdec_line(tempbuf,buffer,h);
			bptr = band + x;
			for (y = 0; y < h; y++) { *bptr = tempbuf[y]; bptr += fullw; }
		}

    } else {

		for (x = 0; x < w; x++) {
			bptr = band + x;
			for (y = 0; y < h; y++) { buffer[y] = *bptr; bptr += fullw; }
			un_tdec_line(tempbuf,buffer,h);
			bptr = band + x + fullw;
			for (y = 0; y < h-1; y++) { *bptr = tempbuf[y]; bptr += fullw; }
			temprow[x] = tempbuf[h-1];
		}

		bptr = band;
		for (y = (h-1); y--; ){
			un_tdec_line(bptr,bptr+fullw,w);
			bptr += fullw;
		}
		un_tdec_line(bptr,temprow,w);

	}

	free(buffer);
}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
午夜欧美2019年伦理| 国产精品一线二线三线精华| 久久精品国产色蜜蜜麻豆| 国产黄人亚洲片| 91麻豆精品国产91久久久使用方法| 久久精品日产第一区二区三区高清版| 亚洲免费观看高清在线观看| 国产成人精品www牛牛影视| 在线播放中文字幕一区| 亚洲欧美色一区| 国产精品影视网| 91精品国产美女浴室洗澡无遮挡| 亚洲欧洲韩国日本视频| 国产在线精品免费| 欧美人与禽zozo性伦| 亚洲男女一区二区三区| 国产91色综合久久免费分享| 日韩欧美综合在线| 亚洲成av人片在线观看| 99国产精品一区| 国产精品电影院| 处破女av一区二区| 久久久久国产精品麻豆ai换脸| 免费国产亚洲视频| 51精品久久久久久久蜜臀| 一区二区三区久久久| 色婷婷综合激情| 中文字幕人成不卡一区| 成人av在线播放网站| 欧美国产激情二区三区 | **欧美大码日韩| 成人免费视频网站在线观看| 国产午夜亚洲精品理论片色戒 | 欧美日韩一级二级三级| 一区二区三区小说| 在线观看一区二区视频| 日韩一区在线免费观看| 日本精品视频一区二区| 一区二区三区欧美久久| 欧美日韩亚洲综合| 日一区二区三区| 欧美一区二区三区喷汁尤物| 看片的网站亚洲| 久久久久国产成人精品亚洲午夜| 成人丝袜视频网| 亚洲免费观看高清完整版在线观看熊| 97久久精品人人爽人人爽蜜臀| 亚洲精品乱码久久久久久日本蜜臀| 色欧美日韩亚洲| 五月激情丁香一区二区三区| 日韩一级片在线播放| 黄色日韩网站视频| 中文字幕欧美激情一区| 97久久精品人人澡人人爽| 亚洲已满18点击进入久久| 91精品一区二区三区在线观看| 久久99国产乱子伦精品免费| 亚洲国产精品av| 欧美在线观看一区二区| 美国欧美日韩国产在线播放| 国产欧美一区二区在线观看| 色先锋久久av资源部| 丝袜美腿亚洲色图| 久久精品视频在线看| 欧美专区亚洲专区| 麻豆成人av在线| 中文字幕成人av| 欧美日韩一区不卡| 国产高清不卡一区二区| 一区二区三区高清| 精品国产乱码久久久久久浪潮 | 三级欧美在线一区| 久久综合国产精品| 91亚洲精品久久久蜜桃| 裸体一区二区三区| 国产精品黄色在线观看| 91精品国产综合久久香蕉麻豆| 成人美女在线视频| 日韩av午夜在线观看| 国产精品毛片久久久久久| 欧美一区二区三区影视| 9久草视频在线视频精品| 天天影视网天天综合色在线播放| 欧美激情资源网| 日韩一区二区三区在线视频| 日本精品免费观看高清观看| 国产精品一二三区| 三级精品在线观看| 亚洲同性同志一二三专区| 日韩免费一区二区三区在线播放| 日本高清不卡视频| 国产精品资源在线看| 日韩av中文在线观看| 亚洲精品久久久蜜桃| 国产精品青草久久| 久久影院午夜片一区| 日韩一区二区在线播放| 欧美伊人久久久久久午夜久久久久| 成人精品视频一区二区三区| 老司机免费视频一区二区三区| 亚洲国产婷婷综合在线精品| 国产精品福利一区二区三区| 国产视频一区二区三区在线观看| 日韩美一区二区三区| 欧美精品色综合| 欧美日韩久久久久久| 99久久久无码国产精品| 国产成a人亚洲| 国产一区二区三区四区五区入口| 青草国产精品久久久久久| 丝袜美腿高跟呻吟高潮一区| 亚洲成av人片在线观看无码| 亚洲一区二区av在线| 亚洲男人的天堂在线aⅴ视频| 国产精品久久久久久久久免费相片 | 风间由美一区二区av101 | 欧美成人r级一区二区三区| 91精品国产一区二区三区| 欧美高清视频一二三区| 欧美色男人天堂| 在线综合视频播放| 日韩一区二区在线观看视频 | 欧美日韩在线播放三区四区| 欧美天天综合网| 欧美日韩国产系列| 欧美理论在线播放| 日韩欧美你懂的| 久久综合久久久久88| 久久久国产精华| 国产精品三级视频| 日韩理论片在线| 亚洲午夜电影在线观看| 天天影视涩香欲综合网| 伦理电影国产精品| 国产一区福利在线| 成人性生交大合| 在线观看日韩毛片| 日韩一区二区三区免费看| 久久一二三国产| 亚洲视频电影在线| 视频一区视频二区在线观看| 久久精品999| 成人sese在线| 在线播放视频一区| 久久久久久综合| 亚洲乱码国产乱码精品精98午夜 | 欧美综合久久久| 日韩一区二区三区电影在线观看| 久久精品一区二区| 一区二区三区日韩欧美精品 | 26uuu国产一区二区三区| 国产色综合久久| 一区二区三区四区乱视频| 日本在线观看不卡视频| 国产一区二区中文字幕| 欧美色成人综合| 国产亚洲综合性久久久影院| 一区二区三区在线播放| 久久99深爱久久99精品| 91浏览器在线视频| 精品久久国产97色综合| 一区二区三区四区高清精品免费观看| 激情综合色播五月| 91免费在线看| 国产丝袜在线精品| 亚洲成av人片| 97精品超碰一区二区三区| 日韩一区二区三区视频| 一区二区三区日韩欧美精品| 国产精品亚洲人在线观看| 欧美疯狂做受xxxx富婆| **欧美大码日韩| 国产福利电影一区二区三区| 欧美日韩视频在线观看一区二区三区 | 国产女人18毛片水真多成人如厕| 亚洲va欧美va人人爽| www.欧美.com| 国产亚洲美州欧州综合国| 天堂在线亚洲视频| 91久久精品一区二区二区| 国产午夜精品久久| 久久9热精品视频| 欧美日韩国产高清一区二区| 综合精品久久久| 高清不卡一区二区| 2017欧美狠狠色| 日日摸夜夜添夜夜添国产精品| 91麻豆文化传媒在线观看| 国产精品色哟哟网站| 国产一区视频在线看| 日韩区在线观看| 蜜臀久久久久久久| 欧美日韩国产一区| 一区二区三区精品视频在线| 91最新地址在线播放| 中文一区二区在线观看| 国产精品99久久久久久宅男| 久久久国产午夜精品 | 欧美大尺度电影在线| 一区二区三区免费|