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

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

?? b97.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);
}

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
石原莉奈在线亚洲三区| 91视频观看免费| 成人免费看黄yyy456| 欧美日本不卡视频| 国产婷婷一区二区| 午夜免费久久看| 成人a区在线观看| 欧美不卡在线视频| 亚洲成a人片在线不卡一二三区| 国产乱码精品1区2区3区| 欧美午夜精品久久久久久超碰| 精品福利一区二区三区免费视频| 亚洲六月丁香色婷婷综合久久 | 最新成人av在线| 老司机精品视频线观看86| 色噜噜狠狠色综合中国| 久久精品一区四区| 美女视频黄a大片欧美| 91福利区一区二区三区| 国产精品久久99| 国产精品资源在线观看| 日韩视频在线你懂得| 亚洲图片欧美一区| 91国偷自产一区二区使用方法| 中文字幕乱码亚洲精品一区| 韩国av一区二区三区在线观看| 在线观看日韩一区| 亚洲女性喷水在线观看一区| 粉嫩绯色av一区二区在线观看| 2024国产精品| 国产美女在线观看一区| 精品理论电影在线| 国产在线精品视频| 久久久久国产精品厨房| 狠狠v欧美v日韩v亚洲ⅴ| 日韩精品一区国产麻豆| 狠狠色丁香婷综合久久| 精品国产乱码久久久久久夜甘婷婷 | 99国产欧美另类久久久精品| 久久久久97国产精华液好用吗| 久久99精品久久久久久| 久久综合一区二区| 国产成人综合网| 亚洲欧洲国产专区| 欧美无人高清视频在线观看| 亚洲大尺度视频在线观看| 欧美三日本三级三级在线播放| 亚洲成人福利片| 欧美一级在线视频| 国产一区二区在线看| 国产欧美精品一区| 一本一道久久a久久精品综合蜜臀| 伊人婷婷欧美激情| 欧美日韩精品一区二区三区四区| 日韩电影网1区2区| 久久蜜臀精品av| 99视频一区二区| 亚洲国产另类精品专区| 日韩女优电影在线观看| 国产精品亚洲人在线观看| 国产精品二三区| 欧美揉bbbbb揉bbbbb| 极品销魂美女一区二区三区| 国产日韩欧美综合在线| 色悠悠久久综合| 免费在线观看视频一区| 国产精品福利影院| 欧美一级高清片| 岛国精品在线播放| 亚洲一区二区三区不卡国产欧美| 宅男噜噜噜66一区二区66| 豆国产96在线|亚洲| 亚洲一区二区高清| 国产欧美精品在线观看| 欧美日韩黄色影视| 成人少妇影院yyyy| 欧美aaa在线| 亚洲欧美综合网| 欧美成人三级电影在线| 色欧美片视频在线观看在线视频| 欧美a级理论片| 亚洲精品一二三区| 久久久久久久久久久久久久久99 | 精一区二区三区| 亚洲另类在线制服丝袜| 国产亚洲一区二区三区| 欧美日本一区二区三区四区| 成人黄色在线看| 蜜桃久久精品一区二区| 亚洲乱码中文字幕| 中文在线资源观看网站视频免费不卡 | 欧美日韩电影在线| 99精品欧美一区二区三区综合在线| 美女任你摸久久| 一区二区三区日韩| 中文字幕欧美区| 精品国产一区二区三区久久影院 | 欧美亚洲丝袜传媒另类| 国产91精品一区二区麻豆网站| 亚洲国产综合色| 亚洲美女视频在线| 国产精品污www在线观看| 精品国产乱码久久久久久图片| 欧美日韩一二区| 欧洲av一区二区嗯嗯嗯啊| 91在线观看高清| 91在线无精精品入口| 成人免费看的视频| 成人av在线资源网| 成人激情黄色小说| 成人综合婷婷国产精品久久免费| 久久精品国产久精国产爱| 青青草一区二区三区| 欧美aaaaa成人免费观看视频| 午夜视频在线观看一区二区三区| 一区二区三区在线影院| 亚洲日本va午夜在线影院| 亚洲欧洲日韩av| 亚洲精品免费电影| 亚洲一区二区三区爽爽爽爽爽| 一区二区三区在线观看网站| 一区二区成人在线视频| 亚洲一区二区三区中文字幕在线| 洋洋av久久久久久久一区| 亚洲黄色录像片| 亚洲444eee在线观看| 日韩极品在线观看| 精品无码三级在线观看视频| 黄页网站大全一区二区| 国产成人啪免费观看软件| 成人h精品动漫一区二区三区| 99视频精品在线| 欧美日韩亚洲高清一区二区| 欧美精品在线观看播放| 日韩精品一区在线| 国产精品久久久久久亚洲毛片| 中文字幕在线一区| 亚洲电影在线播放| 韩国一区二区三区| 成人精品视频一区| 欧美日韩在线亚洲一区蜜芽| 91精品国产福利| 久久精品一区八戒影视| 国产精品日韩成人| 亚洲图片欧美视频| 国产在线播放一区三区四| 成人激情校园春色| 欧美日韩不卡视频| 亚洲精品一区二区精华| 亚洲人妖av一区二区| 日韩精品91亚洲二区在线观看| 国产精品一区二区无线| 91麻豆精品一区二区三区| 91麻豆精品国产91久久久使用方法| 久久只精品国产| 亚洲一区二区在线免费看| 久久精品噜噜噜成人88aⅴ| 成人免费av网站| 在线播放/欧美激情| 国产精品电影院| 蜜臀av亚洲一区中文字幕| av亚洲精华国产精华精华| 欧美高清精品3d| 日韩一区欧美小说| 国内一区二区在线| 欧美性生活大片视频| 日本一区二区三区视频视频| 午夜精品一区二区三区电影天堂 | 久久不见久久见免费视频1| 99久久久免费精品国产一区二区| 欧美性生活大片视频| 欧美激情一区二区三区不卡| 日本色综合中文字幕| 色老综合老女人久久久| 国产午夜一区二区三区| 五月婷婷激情综合| 日韩欧美国产一区在线观看| 亚洲美女免费在线| 成人黄色一级视频| 久久午夜电影网| 日韩电影在线观看网站| 欧美中文一区二区三区| 中文字幕中文字幕一区| 国产精品99久久久久久久vr| 欧美日韩久久久久久| 亚洲欧美激情小说另类| 成人美女在线视频| 精品国产1区二区| 老司机免费视频一区二区| 欧美乱妇15p| 亚洲尤物在线视频观看| 91欧美一区二区| 中文字幕一区二区在线观看| 国产一区亚洲一区| 精品国产制服丝袜高跟| 久久66热偷产精品| 欧美大胆一级视频| 精品亚洲成a人在线观看 | 日韩激情一二三区| 欧美在线观看一区二区|