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

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

?? liftdwt97.cpp

?? 二維小波變換算法實現壓縮解壓的程序
?? CPP
字號:
// LiftDwt.cpp: implementation of the CLiftDwt class.

//  此程序為完全提升格式的小波變換,所謂完全是指,最后的拉伸變換也進行了提升分解,即分解成了三個提升結構
//  程序中了使用的小波濾波器為帶參數的9-7小波濾波器
//
//  程序包括以下部分: 
//
//  Dwt2D(double buffer[], int height, int width, int lv) 二維提升小波變換,buffer進行變換的數據,height,width數據的尺寸,lv小波分解的層數
//  IDwt2D(double buffer[], int height, int width, int lv) 二維提升小波反變換
//  
//  Dwt1D(double *buffer, int buflen)  一維提升小波分解 buflen 數據的長度
//  IDwt1D(double *buffer, int buflen) 
//   
//  filterset(double t)  設置小波濾波器,小波和對偶小波濾波器之和必須為sqrt(2),否則編碼效果不好
//
//  數據延拓方式有兩種: 周期延拓和對稱延拓
//////////////////////////////////////////////////////////////////////

#include "stdafx.h"
//#include "ImgPro.h"
#include "LiftDwt97.h"
#include "math.h"

#ifdef _DEBUG
#undef THIS_FILE
static char THIS_FILE[]=__FILE__;
#define new DEBUG_NEW
#endif

//#define MAX(x,y) (x>y?x:y)
//////////////////////////////////////////////////////////////////////
// Construction/Destruction
//////////////////////////////////////////////////////////////////////

CLiftDwt97::CLiftDwt97()
{
	p_t = 0.730174;
	shift = 4;
	filterset(p_t);  // 設置濾波器的系數
}

CLiftDwt97::~CLiftDwt97()
{
	delete []h;
	delete []h1;

}

void CLiftDwt97::Dwt2D(double buffer[], int height, int width, int lv)
{
	int i,j,k;
 	int nheight,nwidth;
    double *pbuffer1,*pbuffer2;
 
	for ( k=0; k<lv; k++)
	{
       nheight=height>>k;
	   nwidth=width>>k;

	   pbuffer1 = new double [nheight];	 
	   pbuffer2 = new double [nwidth];
       //行變換
	   for (i=0; i<nheight; i++)
		{
			for(j=0; j<nwidth; j++)
				*(pbuffer1+j) = *(buffer+i*width+j);
			
			Dwt1D(pbuffer1,nwidth);
			
			for(j=0; j<nwidth; j++)
				 *(buffer+i*width+j) = *(pbuffer1+j);
		}
		delete []pbuffer1;
       
		//列變換
		for(j=0; j<nwidth; j++)
		{
			for (i=0; i<nheight; i++)
				*(pbuffer2+i)= *(buffer+i*width+j);

			Dwt1D(pbuffer2,nheight);
			
			for(i=0; i<nwidth; i++)
				 *(buffer+i*width+j) = *(pbuffer2+i);
		}
		delete []pbuffer2;
	}
}

void CLiftDwt97::IDwt2D(double buffer[], int height, int width, int lv)
{

    int i,j,k;
 	int nheight,nwidth;
	double *pbuffer1,*pbuffer2;
	  
	for (k=0; k<lv; k++)
	{
		nheight=height>>(lv-k-1);
 		nwidth=width>>(lv-k-1);
	    
		pbuffer1 = new double [nheight];	 
	    pbuffer2 = new double [nwidth];
        
		//列反變換
		for(j=0; j<nwidth; j++)
		{
 			for (i=0; i<nheight; i++)
 				*(pbuffer1+i) =  *(buffer+i*width+j);
 		
			IDwt1D(pbuffer1,nheight);
 			
			for(i=0; i<nwidth; i++)
 				 *(buffer+i*width+j) = *(pbuffer1+i);
 		}
 		delete []pbuffer1;
 
        //行反變換
	
 		for (i=0; i<nheight; i++)
		{
 			for(j=0; j<nwidth; j++)
 				*(pbuffer2+j)=*(buffer+i*width+j);
 			IDwt1D(pbuffer2,nwidth);
 			for(j=0; j<nwidth; j++)
 				 *(buffer+i*width+j) = *(pbuffer2+j);
 		}
		delete []pbuffer2;
 	}

}

void CLiftDwt97::Dwt1D(double *buffer, int buflen)
{
	int i;
	int itemp;

/*    使用周期延拓方式	*/
	double *d, *s, *p;
	p = new double [buflen+2*shift];
	d = new double [(buflen>>1)+shift];
	s = new double [(buflen>>1)+shift];

/*	for (i=0; i<shift; i++){
		*(p+i) = *(buffer+buflen-shift+i);
		*(p+buflen+shift+i) = *(buffer+i);
	}
	for (i=0; i<buflen; i++) *(p+i+shift) = *(buffer+i);
	/* 數據周期延拓結束  計算p1 = d1          p2 = s1 */

	/*  對稱延拓 */
	for (i=0; i<shift; i++)
	{
		*(p+i) = *(buffer+shift-i);
		*(p+buflen+shift+i) = *(buffer+buflen-i-2);
	}
	for (i=0; i<buflen; i++) 
		*(p+i+shift) = *(buffer+i);
    /*  結束  */
	for (i=0; i<(buflen>>1)+shift; i++)
	{
		itemp = i-(shift>>1);
		*(d+i) = *(p+shift+2*itemp+1) + p_alfa*( *(p+shift+2*itemp)+*(p+shift+2*itemp+2) );
	}

	for (i=0; i<(buflen>>1)+shift-1; i++)
	{
		itemp = i+1-(shift>>1);
		*(s+i+1) = *(p+shift+2*itemp) + p_beta*( *(d+i+1)+*(d+i+1-1) );
	}
   /*  d1 s1 計算結束 下計算 d2  */
	for (i=0; i<(buflen>>1)+shift-1; i++)
	{
		//itemp = i-(shift>>1);
		*(p+shift+(buflen>>1)+i) =  *(d+i) + p_gama*( *(s+i)+*(s+i+1)); 
	}
	/*  s2 */
    for (i=0; i<(buflen>>1)+shift-1; i++)
	{
	//	itemp = i-(shift>>1);
		*(p+i+1) = *(s+i+1) + p_delta*(*(p+(buflen>>1)+shift+i+1) + *(p+(buflen>>1)+shift+i+1-1) );
	}

	/* d3 */
	for (i=0; i<(buflen>>1); i++)
		*(d+i) = *(p+i+(buflen>>1)+shift+(shift>>1)) +p_kesa*(1-p_kesa)*(*(p+i+(shift>>1)));
	/* s3 */
	for (i=0; i<(buflen>>1); i++)
		*(s+i) = *(p+i+(shift>>1)) -1/p_kesa*(*(d+i));
    /* d4 */
	for (i=0; i<(buflen>>1); i++)
		*(buffer+i+(buflen>>1)) = *(d+i) +(p_kesa-1)*(*(s+i));

	/* s4 */
	for (i=0; i<(buflen>>1); i++)
		*(buffer+i) = *(s+i) + *(buffer+i+(buflen>>1));

/*	for (i=0; i<(buflen>>1); i++){
   *(buffer+i) = p_kesa*(*(p+i+(shift>>1)));  
 	 *(buffer+i+(buflen>>1)) = 1/p_kesa*(*(p+i+(buflen>>1)+shift+(shift>>1)));	
	}
*/
    delete []p;
	delete []d;
	delete []s;
    
}

void CLiftDwt97::IDwt1D(double *buffer, int buflen)
{
	int i;
    double *p1, *p2, *s, *d;
	p1 = new double [(buflen>>1)+shift];
	p2 = new double [(buflen>>1)+shift];
	s  = new double [(buflen>>1)+shift];
	d  = new double [(buflen>>1)+shift];

   /* s3 */
   for (i=0; i<(buflen>>1); i++)
	   *(s+i) = *(buffer+i) - *(buffer+i+(buflen>>1));
   /* d3 */
   for (i=0; i<(buflen>>1); i++)
	   *(d+i) =*(buffer+i+(buflen>>1))- (p_kesa-1)*(*(s+i));
   /*  s2 */
   for (i=0; i<(buflen>>1); i++)
	   *(buffer+i) = *(s+i) + (1/p_kesa)*(*(d+i));
   /*  d2 */
   for (i=0; i<(buflen>>1); i++)
	   *(buffer+i+(buflen>>1)) = *(d+i) - p_kesa*(1-p_kesa)*(*(buffer+i));

/*    延拓方式為周期延拓     /*
	for (i=0; i<(shift>>1); i++){
		p1[i] = buffer[i+(buflen>>1)-(shift>>1)];
		p1[i+(shift>>1)+(buflen>>1)] = buffer[i];
		p2[i] = buffer[i+buflen-(shift>>1)];
		p2[i+(shift>>1)+(buflen>>1)] = buffer[i+(buflen>>1)];
	}
	for (i=0; i<(buflen>>1); i++){
		p1[i+(shift>>1)] = buffer[i];
		p2[i+(shift>>1)] = buffer[i+(buflen>>1)];
	}

/*  延拓結束 */	

	/*  對稱延拓	*/
   	for (i=0; i<(shift>>1); i++){
		p1[i] = buffer[(shift>>1)-i];
		p1[i+(shift>>1)+(buflen>>1)] = buffer[(buflen>>1)-i-1];
		p2[i] = buffer[(buflen>>1)+(shift>>1)-i-1];
		p2[i+(shift>>1)+(buflen>>1)] = buffer[buflen-i-2];
	}
	for (i=0; i<(buflen>>1); i++){
		p1[i+(shift>>1)] = buffer[i];
		p2[i+(shift>>1)] = buffer[i+(buflen>>1)];
	}
/*   對稱延拓結束  */

   /*  s1  */
   for (i=0; i<(buflen>>1)+shift-1; i++)
	   *(s+i+1) = *(p1+i+1) - p_delta*( *(p2+i+1) + *(p2+i+1-1));
   /*  d1 */
   for (i=0; i<(buflen>>1)+shift-1; i++)
	   *(d+i) = *(p2+i) - p_gama*(*(s+i) + *(s+i+1));
    /* p1 = s0 */
   for (i=0; i<(buflen>>1)+shift-1; i++)
	   *(p1+i+1) = *(s+i+1) - p_beta*( *(d+i+1)+*(d+i+1-1));
   /*  p2 = d0 */
   for (i=0; i<(buflen>>1)+shift-1; i++)
	   *(p2+i) = *(d+i) - p_alfa*(*(p1+i) + *(p1+i+1));

   for (i=0; i<(buflen>>1); i++){
	   *(buffer+2*i) = *(p1+i+(shift>>1)) ;
	   *(buffer+2*i+1) = *(p2+i+(shift>>1));
   }


	delete []p1;
	delete []p2;
	delete []s;
	delete []d;
}

void CLiftDwt97::filterset(double t)
{
	h = new double [9];
	h1 = new double [7];
	*h = (8*t*t*t-6*t*t+3*t)/(1+2*t)*(1/32.)*sqrt(2);
	*(h+1) = (-16*t*t*t+20*t*t-12*t+3)/(1+2*t)*(1/32.)*sqrt(2);
	*(h+2) = (2*t-3)/(1+2*t)*(1/8.)*sqrt(2);
	*(h+3) = (16*t*t*t-20*t*t+28*t+5)/(1+2*t)*(1/32.)*sqrt(2);
	*(h+4) = (-8*t*t*t+6*t*t+5*t+20)/(1+2*t)*(1/16.)*sqrt(2);
	*(h+5) = *(h+3);
	*(h+6) = *(h+2);
	*(h+7) = *(h+1);
	*(h+8) = *(h+0);

	double r0, r1, s0, t0;
	r0 = (*(h+4))-2*(*h)*(*(h+3))/(*(h+1));
	r1 = (*(h+2))-(*h)-(*h)*(*(h+3))/(*(h+1));
	s0 = (*(h+3))-(*(h+1))-(*(h+1))*r0/r1;
	t0 = r0-2*r1;

	p_alfa = (*h)/(*(h+1));
	p_beta = (*(h+1))/r1;
	p_gama = r1/s0;
	p_delta = s0/t0;
	p_kesa = t0;


}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
3d动漫精品啪啪一区二区竹菊 | 色综合久久88色综合天天6| 香蕉av福利精品导航| 亚洲男女毛片无遮挡| 国产精品国产三级国产aⅴ中文| 久久久久久综合| www亚洲一区| 欧美韩日一区二区三区四区| 国产精品网曝门| 亚洲欧美另类图片小说| 亚洲视频 欧洲视频| 五月天激情小说综合| 午夜精品视频一区| 蜜臀av一级做a爰片久久| 青草国产精品久久久久久| 日本va欧美va精品| 精品中文字幕一区二区小辣椒| 老司机精品视频一区二区三区| 久久国产精品72免费观看| 久久99精品国产麻豆婷婷洗澡| 国产在线看一区| 99综合影院在线| 91理论电影在线观看| 在线播放欧美女士性生活| 日韩欧美专区在线| 国产精品免费av| 亚洲成av人综合在线观看| 精品在线播放午夜| 99国产精品国产精品毛片| 欧美日韩专区在线| 精品国产乱码久久久久久1区2区| 国产精品污www在线观看| 亚洲电影你懂得| 精品视频1区2区| 精品国精品国产| 亚洲蜜臀av乱码久久精品蜜桃| 日本系列欧美系列| 成人黄色大片在线观看| 欧美午夜在线一二页| 久久综合色婷婷| 一区二区日韩电影| 国产美女主播视频一区| 99精品在线免费| 久久午夜羞羞影院免费观看| 中文字幕亚洲综合久久菠萝蜜| 日韩激情一二三区| 91丝袜国产在线播放| 精品国产乱码久久| 首页国产丝袜综合| 91女神在线视频| 久久久久久久久久美女| 亚洲成av人片一区二区梦乃| 国产精品一二三区在线| 7777女厕盗摄久久久| 成人欧美一区二区三区黑人麻豆| 欧美aaaaaa午夜精品| 在线观看国产91| ...xxx性欧美| 欧美高清激情brazzers| 亚洲免费三区一区二区| 成人黄页在线观看| 久久久久国产精品人| 精品在线你懂的| 日韩精品影音先锋| 蜜桃在线一区二区三区| 欧美在线视频日韩| 一区二区三区欧美久久| 91色.com| 综合久久综合久久| 成人精品视频一区| 国产日韩欧美精品一区| 国内国产精品久久| 久久综合丝袜日本网| 国产在线精品视频| 亚洲精品一区二区三区影院| 免费在线看一区| 91麻豆精品国产91久久久资源速度 | 亚洲国产精品久久人人爱蜜臀| 99久久精品国产导航| 亚洲人快播电影网| 色综合久久久久综合| 亚洲婷婷国产精品电影人久久| 99精品视频一区二区三区| 国产精品视频一二三| 不卡av在线网| 亚洲制服丝袜在线| 欧美三级在线看| 日韩 欧美一区二区三区| 91精品久久久久久久久99蜜臂| 天天操天天干天天综合网| 7777精品伊人久久久大香线蕉超级流畅 | www久久精品| 国产大陆a不卡| √…a在线天堂一区| 欧美在线999| 久久成人免费电影| 中文字幕精品一区二区三区精品| av一本久道久久综合久久鬼色| 最新国产の精品合集bt伙计| 欧美影院一区二区| 美女一区二区视频| 日本一区二区三区四区在线视频 | 日韩亚洲欧美一区| 麻豆久久一区二区| 日本一区二区三区免费乱视频| 99久久99久久精品国产片果冻| 亚洲成av人片一区二区| 日韩免费性生活视频播放| 国产精品一区在线观看乱码| 亚洲欧美日韩中文字幕一区二区三区 | 日韩一区二区视频在线观看| 国产一区二区不卡在线 | 日韩专区在线视频| 久久―日本道色综合久久| 成a人片亚洲日本久久| 日韩精品成人一区二区三区| 中文字幕不卡三区| 欧美成va人片在线观看| 91丝袜国产在线播放| 狠狠色丁香婷婷综合| 亚洲最大成人综合| 国产网红主播福利一区二区| 欧美日韩的一区二区| aaa欧美日韩| 国产麻豆一精品一av一免费| 一二三区精品视频| 国产精品视频第一区| 91精品国产91久久久久久一区二区| 丰满放荡岳乱妇91ww| 美女视频免费一区| 亚洲一区二区三区四区在线免费观看 | 国产欧美一区二区三区在线老狼| 欧美视频一二三区| 99热这里都是精品| 国产一区二区三区免费| 视频一区二区不卡| 亚洲乱码国产乱码精品精小说| xfplay精品久久| 日韩精品一区二区三区在线| 欧美日韩国产另类不卡| 色综合天天综合网天天狠天天| 国产91丝袜在线18| 激情文学综合丁香| 捆绑紧缚一区二区三区视频| 青青草国产精品97视觉盛宴| 亚洲主播在线播放| 亚洲欧美一区二区三区孕妇| 最近日韩中文字幕| 国产精品久久久久久久午夜片 | 欧美美女直播网站| 91精品办公室少妇高潮对白| 99在线精品视频| 91免费在线视频观看| 99国产精品99久久久久久| 成人激情小说乱人伦| 成人午夜视频福利| 大尺度一区二区| 高清av一区二区| 99精品久久久久久| 91麻豆免费看| 欧美色网站导航| 欧美另类z0zxhd电影| 91精品国产色综合久久不卡蜜臀 | 久久蜜臀精品av| 国产女同性恋一区二区| 欧美激情一区二区三区不卡 | 在线观看av一区| 91精品国产综合久久久蜜臀图片 | 亚洲一区二区三区在线看| 亚洲自拍偷拍欧美| 免费av成人在线| 国产精品一区二区三区99| 福利一区二区在线观看| 粉嫩13p一区二区三区| 99视频精品全部免费在线| 在线观看91视频| 欧美sm美女调教| 日韩一区欧美小说| 天堂一区二区在线免费观看| 国产做a爰片久久毛片| 97se亚洲国产综合自在线不卡| 色女孩综合影院| 久久综合一区二区| 亚洲激情第一区| 国产一区二区三区四区五区入口| 99久久夜色精品国产网站| 91精品国产一区二区三区| 中文字幕av一区二区三区免费看| 一区二区三区在线视频免费| 免费在线视频一区| 97se亚洲国产综合自在线不卡| 欧美日韩一区二区三区视频| 欧美精品一区二区三| 一区二区三区在线不卡| 国产一区在线观看麻豆| 欧美亚州韩日在线看免费版国语版| 26uuu久久天堂性欧美| 国产精品 日产精品 欧美精品| 一本色道久久加勒比精品| 日韩精品一区二区三区视频在线观看 |