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

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

?? ezw.h

?? 單獨的ezw編解碼
?? H
字號:
/*--------------------------------------------------------------------------------------------*/
/* ezw.h */
#ifndef __EZW_H__
#define __EZW_H__

/* disable unused variabled warning 避免一種變量重定義的warning*/
#pragma warning (disable : 4101)

#include <math.h>
#include <conio.h>
#include <assert.h>
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <stdarg.h>
#include <sys/stat.h>

/*--------------------------------------------------------------------------------------------*/
/* encoded stream filename extension */
typedef float Real;
typedef float REAL;
typedef unsigned long  ULONG;
typedef unsigned long  uLong;
typedef unsigned char uchar;
typedef int	INT32;

#define MaxReal ((float)3.40282346638528860e+38)
#define MinReal ((float)1.17549435082228750e-38)

/*--------------------------------------------------------------------------------------------*/	
/*--------------------------------------------------------------------------------------------*/
/* Codec mode options */
#define ENCODE						0
#define DECODE						1
/*--------------------------------------------------------------------------------------------*/
#define SCAN_CTX_BIT				0x00000008
#define CSIG_CTX_BIT				0x00000004
#define SIGN_CTX_BIT				0x00000002
#define PARE_CTX_BIT				0x00000001

/************************************************************************/
/*量化時的參數(shù)                                                          */     
/************************************************************************/
/* Scalar quantization */
/* At certain bitrate, uniform quantizer is better than deadzone. 
 * Note that the dequantization equation is for deadzone only. This is mathematically 
 * incorrect.
 */
/* EZW default : 1 */
#define _BIAS_DEQUANTIZE_			0
#if _BIAS_DEQUANTIZE_
#define MSB_GAMMA					0.38
#define GAMMA						0.48
#else
#define MSB_GAMMA					0.5
#define GAMMA						0.5
#endif

#define _DEADZONE_   1

#if _DEADZONE_
   #define EZWQuantize(Value, StepSize) SIGN((Value))*((int)(fabs((Value))/(StepSize)));
#else
   #define EZWQuantize(Value, StepSize) SIGN((Value))*(ROUND(fabs((Value))/(StepSize)));
#endif

#define EZWDequantize(index, StepSize, Gamma) \
	((index)==0? 0 : SIGN((index))*(abs((index)) + (Gamma))*(StepSize));

/************************************************************************/
/*DlistElement、Dlist有關(guān)樹型結(jié)構(gòu)中用到,例如需要進行副掃描的位置       */
/************************************************************************/
/* double-linked list element */
typedef struct DListElementStruct{
	void   *data;
	struct DListElementStruct *prev;
	struct DListElementStruct *next;
} DListElement;
/*--------------------------------------------------------------------------------------------*/
/* double-linked list struct */
typedef struct DListStruct{
	int  size;
	int  (*match)(const void *key1, const void *key2);
	void (*destroy)(void *data);
	void (*print)(int i, const void *data);
	DListElement *head;
	DListElement *tail;
} DList;

/************************************************************************/
/*主要的編解碼部分                                                                      */
/************************************************************************/	
typedef struct NodeStruct{
	int i;				/* coeff linear location in the subband */
	int x;				/* coeff horizontal location in the subband */
	int y;				/* coeff vertical location in the subband */
	char n;				/* subband index */
} ListData;

typedef struct CoderStruct {
	
	int Mode;//ENCODE or DECODE
	int FXSize;
	int FYSize;
	int ImageXSize;
	int ImageYSize;
	int NScale;//分辨率級數(shù)
	int nSubbands;//子帶數(shù)
	int CurrentThreshold;
	int MaxThreshold;
	int CurrentBitPlane;
	int MaxBitPlane;

	
	int *Coeff;
	int **SubbandPtr;
	int *SubbandXSize;
	int *SubbandYSize;
	int *SubbandSize;

	int **Magnitude;
	int **MaxMagnitude;
	unsigned int **State;
	
	DListElement *RefinementMark[32];

   /* List based */
 	DList LSP;
	
	char EncodeImageFileName[_MAX_PATH];
	double TargetBitRate;
	int TargetBits;
	
	int nPS;
	int nNG;
	int nIZ;
	int nZS;
	int nRF;

	int CodedSymbols;
	FILE *file;

} Coder;

/*--------------------------------------------------------------------------------------------*/	
/* General interface */
int EZWEncodeInterface(int xsize,int ysize,int level,double rate,int &maxbitplane);
int EZWDecodeInterface(int xsize,int ysize,int level,double rate,int maxbitplane);
int EZWEncode(Coder *coder,int *ezwcomp);
int EZWDecode(Coder *coder);

/*--------------------------------------------------------------------------------------------*/
/* Structures setup */ 
void EZWBuildCodingArrays(Coder *coder,int *ezwcomp);
void EZWDeBuildCodingArrays(Coder *coder);
void EZWDestroyCodingArrays(Coder *coder);
void EZWComputeMaxMagnitudeTree(Coder *coder);

/*--------------------------------------------------------------------------------------------*/
/* I/O */
//void EZWWriteHeader(Coder *coder);
//void EZWReadHeader(Coder *coder);
int EZWWSymbol(Coder *coder,int symbol);
int EZWRSymbol(Coder *coder,int *symbol);

/*--------------------------------------------------------------------------------------------*/
/* Main algorithms */
void EZWMainCodingPass(Coder *coder);
int EZWRefinementPass(Coder *coder);
int EZWSortingPass(Coder *coder);

/*--------------------------------------------------------------------------------------------*/
/* List manupulations */
void EZWDeleteData(void *data);
ListData *EZWCreateData(int i, int x, int y, char n);

/*--------------------------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------------------------*/
#define TEST_MALLOC(p) \
	if (p==NULL){ \
		Error("Memory allocation fail.\n"); \
	}

//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
//一些常用的數(shù)學(xué)函數(shù)
//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
#ifdef __cplusplus
extern "C" {
#endif
/*---------------------------------------------------------------------------*/
/*
 * Mow-Song, Ng 2/9/2002
 * msng@mmu.edu.my
 * http://www.pesona.mmu.edu.my/~msng
 *
 */
/*---------------------------------------------------------------------------*/
// note : (int)(-2.3) gives -2
// floor of -2.3 is -3
// so we do have to minus -0.5 for negative numbers to get their floor
#ifndef MIN
#define MIN(x,y)	(((x)<(y))?(x):(y))
#endif
#ifndef MAX
#define MAX(x,y)	(((x)>(y))?(x):(y))
#endif

#define ROUND(a)	(((a)<0)?(int)((a)-0.5):(int)((a)+0.5))
#define SIGN(x)		(x>0? 1: (x<0? -1: 0))

int sign(Real x);
int Log2(int x);

void Error(char *fmt, ...);
/* code from A. Said and W. Pearlman (SPIHT) */
#ifdef __cplusplus
}
#endif

/*--------------------------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------------------------*/
//////////////////////////////////////////////////////////////////////////
//關(guān)于樹型結(jié)構(gòu)
//////////////////////////////////////////////////////////////////////////
#ifdef __cplusplus
extern "C" {
#endif
/*--------------------------------------------------------------------------------------------*/	
/*--------------------------------------------------------------------------------------------*/
/* Copyright notice:
* Code comes from the book "Mastering Algorithms with C"
* by Kyle Loudon,  
* published by O'Reilly & Associates
*
/*	
/*--------------------------------------------------------------------------------------------*/
/* 
* Adapted/reformated to suit my own coding style 
* Mow-Song, Ng
* 18-02-2003
/*
/*--------------------------------------------------------------------------------------------*/
	
/*--------------------------------------------------------------------------------------------*/
/* Note
* Never pass free() as the function pointer for destroy. This has to be  
* followed strictly, especialy when the memchk module is used.
/*
/*--------------------------------------------------------------------------------------------*/
/*--------------------------------------------------------------------------------------------*/
/* Public Interface */
void EZWDListInit(DList *dlist, void (*destroy)(void *data),
				int  (*match)(const void *key1, const void *key2),
				void (*print)(int i, const void *data));
void EZWDListDestroy(DList *dlist);
int  EZWDListInsertAsHead(DList *dlist, const void *data);
int  EZWDListAppend(DList *dlist, const void *data);
int  EZWDListInsertNext(DList *dlist, DListElement *element, const void *data);
int  EZWDListInsertPrev(DList *dlist, DListElement *element, const void *data);
int  EZWDListRemove(DList *dlist, DListElement *element, void **data);

int  EZWDListInsertListPrev(DList *mainlist, DList *sublist, DListElement *element);
int  EZWDListInsertListNext(DList *mainlist, DList *sublist, DListElement *element);

/* Macros */
#define DListSize(dlist) ((dlist)->size)
#define DListHead(dlist) ((dlist)->head)
#define DListTail(dlist) ((dlist)->tail)
#define DListIsHead(element) ((element)->prev == NULL ? 1 : 0)
#define DListIsTail(element) ((element)->next == NULL ? 1 : 0)
#define DListData(element) ((element)->data)
#define DListNext(element) ((element)->next)
#define DListPrev(element) ((element)->prev)

#ifdef __cplusplus
}
#endif

/*--------------------------------------------------------------------------------------------*/
//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////
//關(guān)于內(nèi)存分配的函數(shù)
//////////////////////////////////////////////////////////////////////////
//////////////////////////////////////////////////////////////////////////

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
/* Adapted/reformated to suit my own coding style. Some changes to the 
* printing. Also the defintion that enable/disable the memory checker.
* Added a few functions and definitions.
*
* Mow-Song, Ng 2/9/2002
* msng@mmu.edu.my
* http://www.pesona.mmu.edu.my/~msng
*
*
*/
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/

/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
/* Original code from LiftPack */
/*
*  -*- Mode: ANSI C -*-
*  $Id: memchk.h,v 1.4 1996/11/06 20:52:23 fernande Exp $
*  $Header: /sgi.acct/sweldens/cvs/liftpack/include/memchk.h,v 1.4 
*           1996/11/06 20:52:23 fernande Exp $
*  Author: Sridhar, M. A.
*  Modified: Gabriel Fernandez
*
*  Contains declarations of memory management functions to control
*  memory leaks in a C source code.
*/
/*----------------------------------------------------------------------------*/
/*----------------------------------------------------------------------------*/
#ifdef __cplusplus
extern "C" {
#endif
	
//#define __MEMCHK_ENABLE_
	
/* allocate memory and initialize it with zeros */
extern void *
	Calloc (size_t __number, size_t __size, int __line_no, char* __file_name);
	
/* allocate a new memory block for a given pointer */
extern void *
	Realloc (void* __ptr, size_t __size, int __line_no, char* __file_name);
	
/* allocate memory and keep track of important information */
extern void *
	Malloc (size_t __size, int __line_no, char* __file_name);
	
/* free memory and delete entry in Malloc list */
extern void
	Free (void* __p);
	
	
/* print content of Malloc list of allocations */
extern int
	PrintLeaks (void);
	
/* free memory pointed out by the Malloc list */
extern void
	FreeLeaks (void);
	
/* return the maximum memory used */
extern long 
	MaxMemory(void);
	
/* return the current memory allocated */
extern long 
	CurrentMemoryAllocated(void);
	
#ifdef __MEMCHK_ENABLE_
/* definitions for all programs to use Realloc, Calloc, Malloc, and Free */
#define calloc(n, s)  Calloc(n, s, __LINE__, __FILE__)
#define realloc(p, s) Realloc(p, s, __LINE__, __FILE__)
#define malloc(s)     Malloc(s, __LINE__, __FILE__)
#define free(s)       Free(s)
#endif /* __MEMCHK_ENABLE_ */
	
#ifdef __cplusplus
}
#endif

#endif

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
av电影天堂一区二区在线观看| 国内精品久久久久影院薰衣草| 欧美一区二区成人| 国产高清不卡一区| 日韩精品亚洲一区| 亚洲国产精品精华液ab| 制服丝袜在线91| 色94色欧美sute亚洲线路一久| 免费黄网站欧美| 一区二区三区中文在线| 久久精品一区二区三区不卡牛牛| 欧美三级视频在线播放| 波波电影院一区二区三区| 国内一区二区在线| 亚洲成a人片综合在线| 国产精品传媒在线| 久久久精品人体av艺术| 日韩欧美自拍偷拍| 欧美亚洲高清一区二区三区不卡| 国产69精品久久久久毛片| 美女视频黄免费的久久| 亚洲国产另类av| 亚洲女人小视频在线观看| 日本一区二区免费在线| 精品国产一区二区三区四区四| 欧美午夜影院一区| 色网站国产精品| caoporen国产精品视频| 国产成人午夜视频| 国产精品一级片在线观看| 蜜桃免费网站一区二区三区| 香蕉久久夜色精品国产使用方法| 亚洲欧美一区二区久久 | 欧美va亚洲va| 欧美精品一二三区| 欧美日韩精品一区二区天天拍小说| 99riav久久精品riav| 成人伦理片在线| 成人美女视频在线观看18| 国产超碰在线一区| 高清av一区二区| 成人性生交大片免费看视频在线| 国产一区二区三区免费看 | 国产欧美一二三区| 久久久高清一区二区三区| 久久日韩精品一区二区五区| 久久亚洲二区三区| 国产欧美视频一区二区三区| 久久精品视频一区二区三区| 久久精品一区蜜桃臀影院| 国产午夜精品福利| 国产精品成人免费| 亚洲免费观看高清完整版在线观看熊| 最新久久zyz资源站| 亚洲黄色免费电影| 亚洲h动漫在线| 天堂蜜桃一区二区三区| 狂野欧美性猛交blacked| 国产精品中文有码| 成人综合婷婷国产精品久久| 99视频在线精品| 欧美亚洲一区三区| 日韩女优av电影在线观看| 久久久久久久久久久黄色| 亚洲欧洲精品一区二区三区 | 精品黑人一区二区三区久久| 久久久久久久久久看片| 亚洲乱码国产乱码精品精的特点 | 99精品桃花视频在线观看| 在线免费一区三区| 日韩一级片网址| 国产精品无人区| 亚洲一区在线电影| 美女诱惑一区二区| 不卡欧美aaaaa| 欧美日韩情趣电影| 久久先锋影音av鲁色资源| 亚洲日本在线观看| 奇米影视一区二区三区| 国产jizzjizz一区二区| 欧美体内she精高潮| 久久亚区不卡日本| 一卡二卡欧美日韩| 国模娜娜一区二区三区| 欧洲另类一二三四区| 欧美tk—视频vk| 一区二区免费在线| 国产露脸91国语对白| 欧美亚洲综合在线| 国产欧美精品一区二区色综合朱莉| 一区二区三区蜜桃| 国产精品一区免费视频| 欧美亚一区二区| 国产日韩av一区二区| 夜夜精品视频一区二区| 国产一区二区三区日韩| 欧美日本乱大交xxxxx| 中文字幕乱码一区二区免费| 丝袜美腿成人在线| 91亚洲资源网| 久久久蜜桃精品| 婷婷久久综合九色综合伊人色| 成人午夜电影小说| 日韩三级视频中文字幕| 一区二区三区在线免费| 国产a久久麻豆| 精品国内二区三区| 亚洲h精品动漫在线观看| 91视频免费观看| 久久久久久久久久久久久夜| 奇米影视一区二区三区| 欧美午夜电影一区| 亚洲欧美日韩国产综合在线| 国产精品888| 日韩欧美精品在线| 视频一区二区中文字幕| 色系网站成人免费| 亚洲视频一二区| 成人av集中营| 国产视频一区在线播放| 久久se这里有精品| 91精品国产色综合久久| 亚洲h在线观看| 欧美系列在线观看| 亚洲国产精品自拍| 日本韩国一区二区三区| 日韩美女视频一区| 99精品在线观看视频| 成人免费一区二区三区在线观看| 福利电影一区二区| 国产欧美一区二区在线观看| 国产曰批免费观看久久久| 欧美mv和日韩mv的网站| 蜜臀久久99精品久久久画质超高清 | 精品国产污污免费网站入口| 美国三级日本三级久久99| 777亚洲妇女| 日韩经典一区二区| 欧美一级黄色录像| 久久国产欧美日韩精品| 日韩欧美综合一区| 国产麻豆精品视频| 欧美国产激情二区三区| fc2成人免费人成在线观看播放 | 欧美va亚洲va在线观看蝴蝶网| 免费在线观看日韩欧美| 日韩免费视频一区| 国产一区二区中文字幕| 国产日产亚洲精品系列| 91同城在线观看| 亚洲国产aⅴ天堂久久| 欧美日韩精品系列| 爽爽淫人综合网网站| 91精品国产乱码久久蜜臀| 久国产精品韩国三级视频| 久久久精品天堂| 91蜜桃在线免费视频| 亚洲福利一区二区三区| 日韩一级大片在线| 国产精品乡下勾搭老头1| 中文字幕在线不卡一区二区三区| 色综合久久88色综合天天免费| 亚洲国产一区在线观看| 欧美v国产在线一区二区三区| 粉嫩一区二区三区性色av| 亚洲精品国产一区二区三区四区在线 | 日韩在线a电影| 久久久久久久久久久黄色| 91免费观看视频| 乱中年女人伦av一区二区| 国产日韩欧美一区二区三区乱码 | 日韩久久久久久| 成人短视频下载| 亚洲一区二区三区四区五区中文| 3d动漫精品啪啪| 成人av网站在线| 日韩 欧美一区二区三区| 国产欧美一区在线| 欧美情侣在线播放| 国产成人精品免费网站| 亚洲精品一二三| 精品国产一区二区三区不卡| 91蝌蚪porny| 久久爱另类一区二区小说| 亚洲激情中文1区| 久久日一线二线三线suv| 欧美在线一区二区| 国产丶欧美丶日本不卡视频| 亚洲一区二区欧美激情| 亚洲国产经典视频| 日韩一级成人av| 色国产综合视频| 国产福利一区在线| 日产欧产美韩系列久久99| 亚洲图片激情小说| 国产欧美一区二区精品性| 宅男噜噜噜66一区二区66| 99re热视频精品| 国产精品1区2区3区在线观看| 亚洲国产一区视频|