📄 wavelet.h
字号:
#ifndef WAVELET_H#include <stdio.h>extern char dbgstr[1000];/* this are internal functions - don't use 'em! */extern void out_dbg_str(const char *str);extern void start_trace(void);extern void stop_trace(void);extern void flush_trace_file(void);/* public functions / macros */#define StartTrace#define StopTrace#define Trace(str)#define TraceVar(str,var)#define Entering#define Leaving#define LeavingErr#define FlushTrace#define Warning(str)#define PreCondition(exp,str)#define PostCondition(exp,str)/* Note that if an error is added, an errormessage for this specific error must also be added. Otherwise no appropriate message can be displayed in an error window. ( Then "Unknown error ocurred" will be displayed.) The errormessage must be added to the case-construct in the procedure err_GetErrorMessage*/ typedef enum{ Error_NoError, /* No Error has happened. */ Error_NotImplemented, /* A needed part has not (yet) been implemented */ Error_AssertionFailed, /* An assertion, pre- or postcondition failed. Occurs only in buggy programs. */ Error_NotEnoughMemory, /* We can't allocate the memory we need. */ Error_Limitation, /* Some limitation exceeded, e.g. a string variable is too short */ Error_CantOpenFile, /* The file cannot be opened */ Error_CantCreateFile, Error_CantWriteIntoFile, Error_CantCloseFile, Error_WrongFileFormat, Error_WidthOrHeightZero, Error_CompressedZeroContent, Error_OriginalZeroContent, Error_InternalError}Error; /************************************************************************//* Functionname: err_simple_message *//* -------------------------------------------------------------------- *//* Parameter: *//* char *: string that contains information about an *//* error the user should know. *//* -------------------------------------------------------------------- *//* Description: *//* Prints error messages for the user. *//************************************************************************/void err_SimpleMessage(char *message);/************************************************************************//* Functionname: err_get_message *//* -------------------------------------------------------------------- *//* Return value: Errormessage for this specific error. *//* Parameter: *//* Error err: Error whose errormessage should be returned *//* -------------------------------------------------------------------- *//* Description: *//************************************************************************/char * err_GetErrorMessage(Error err);#include <stddef.h>typedef double Pixel;typedef struct Image_struct { Pixel *data; int width,height; /* redundant, for our fun only :-) */ Pixel min_val,max_val; /* range of pixel-values in data */ /* [min_val..max_val] */ int size; /* = width * height */ int bpp; /* bits per pixel of original image */ } *Image;typedef unsigned int IntPixel;typedef struct IntImage_struct { IntPixel *data; int width, height; /* redundant, for our fun only :-) */ IntPixel min_val,max_val; /* range of values in data */ /* [min_val..max_val] */ int size; /* = width * height */ int bpp; /* bits per pixel of original image */ } *IntImage;typedef struct Image_tree_struct { double entropy; struct Image_tree_struct *coarse,*horizontal,*vertical,*diagonal,*doubletree; Image image; int level; int flag; void *codec_data; IntImage significance_map; } *Image_tree;typedef struct Image_info_struct { Pixel min,max,mean,var,rms; } *Image_info;enum zigzag_direction {zigzag_up,zigzag_down,zigzag_right,zigzag_left};typedef struct Zigzag_data_struct { int x,y,w,h; enum zigzag_direction dir; } *Zigzag_data;#define get_intpixel(image,x,y) ( ((image)==NULL || \ (x)<0 || (x)>=(image)->width || (y)<0 || (y)>=(image)->height) \ ? (IntPixel) 0 : (image)->data[(x)+(y)*(image)->width])#define set_intpixel(image,x,y,val) if (!((image)==NULL || \ (x)<0 || (x)>=(image)->width || (y)<0 || (y)>=(image)->height)) \ (image)->data[(x)+(y)*(image)->width]=(IntPixel) (val)#define get_pixel(image,x,y) ( ((image)==NULL || \ (x)<0 || (x)>=(image)->width || (y)<0 || (y)>=(image)->height) \ ? (Pixel) 0 : (image)->data[(x)+(y)*(image)->width])#define set_pixel(image,x,y,val) if (!((image)==NULL || \ (x)<0 || (x)>=(image)->width || (y)<0 || (y)>=(image)->height)) \ (image)->data[(x)+(y)*(image)->width]=(Pixel) (val)#define get_pixel_adr(image,x,y) ( ((image)==NULL || \ (x)<0 || (x)>=(image)->width || (y)<0 || (y)>=(image)->height) \ ? (Pixel*) NULL : (image)->data+((x)+(y)*(image)->width))/* functions: */extern IntImage new_intimage(int width, int height);extern IntImage load_intimage(char *file, int max_val);extern void free_intimage(IntImage img);extern void clear_intimage(IntImage img);extern void copy_into_intimage(IntImage img1,IntImage img2,int x,int y);extern void copy_part_of_intimage(IntImage img1,IntImage img2,int x,int y);extern Image new_image(int width, int height);extern void free_image(Image img);extern void clear_image(Image img);extern void copy_into_image(Image img1,Image img2,int x,int y);extern void scale_image(Image img,int maximum);extern void copy_part_of_image(Image img1,Image img2,int x,int y);extern void copy_part_of_image_into_image( Image dest_img, int dest_x, int dest_y, Image src_img, int src_x, int src_y, int width, int height);extern int string_to_pixel(char *str, Pixel *p);extern Image load_image(char *file, int max_val);extern int save_image_P5(char *file, Image img);extern Image intimage_to_image(IntImage i);extern IntImage image_to_intimage(Image i);extern Image_tree new_image_tree();extern void free_image_tree(Image_tree t);extern Image get_difference_image(Image image1, Image image2);extern void get_image_infos(Image image, Image_info info);extern void get_intimage_infos(IntImage image, IntPixel *min, IntPixel *max, Pixel *avg, Pixel *var);extern void init_zigzag(Zigzag_data zz, int width, int height);extern void next_zigzag(Zigzag_data zz);extern Image get_absolute_image_scaled(Image img);/* common macros */#ifndef MIN#define MIN(a,b) ((a)<(b)?(a):(b))#endif#ifndef MAX#define MAX(a,b) ((a)>(b)?(a):(b))#endifenum FilterType { FTNoSymm, FTSymm, FTAntiSymm};typedef struct FilterStruct { enum FilterType type; int hipass; Pixel * data; int start,end; int len; } *Filter;extern Filter new_filter(int size);extern int filter_cutoff(Image in, int in_start, int in_len, int in_step, Image out, int out_start, int out_len, int out_step, Filter f);extern int filter_inv_cutoff(Image in, int in_start, int in_len, int in_step, Image out, int out_start, int out_len, int out_step, Filter f);extern int filter_periodical(Image in, int in_start, int in_len, int in_step, Image out, int out_start, int out_len, int out_step, Filter f);extern int filter_inv_periodical(Image in, int in_start, int in_len, int in_step, Image out, int out_start, int out_len, int out_step, Filter f);extern int filter_mirror(Image in, int in_start, int in_len, int in_step, Image out, int out_start, int out_len, int out_step, Filter f);extern int filter_inv_mirror(Image in, int in_start, int in_len, int in_step, Image out, int out_start, int out_len, int out_step, Filter f);extern Pixel get_filter_center(Filter f);enum FilterGHType { FTOrtho, FTBiOrtho, FTOther};typedef struct FilterGHStruct { enum FilterGHType type; Filter g, h, gi, hi; char *name; } *FilterGH;typedef struct AllFilterStruct { FilterGH *filter; int count; } *AllFilters;extern AllFilters load_filters(char *name);typedef struct SegmentsStruct { int width,height; /* segment width & height*/ int *data; } *Segments; enum FilterMethod{cutoff,inv_cutoff,periodical,inv_periodical,mirror,inv_mirror};enum Information_Cost{threshold,log_energy,entropy,norml,norml2,gauss_markov, shanon,weak_l,weak_lq,compression_number,compression_numberq, compression_area,compression_areaq,sdiscrepancy,discrepancy,concentration};extern Image_tree wavelettransform(Image original,int level,FilterGH *flt,enum FilterMethod method);extern Image_tree wavelettransform_wp(Image original,int level,FilterGH *flt,enum FilterMethod method); extern Image_tree best_basis(Image original,int level,FilterGH *flt, enum FilterMethod method,enum Information_Cost cost,double epsilon); extern Image_tree best_level(Image original,int maxlevel,int *bestlevel,FilterGH *flt,enum FilterMethod method, enum Information_Cost cost,double epsilon);extern Image build_image(Image_tree quadtree,int width,int height);extern Image inv_transform(Image_tree quadtree,FilterGH *flt, enum FilterMethod method);extern Image inv_transform_wp(Image_tree quadtree,FilterGH *flt, enum FilterMethod method);extern int rec_double(Image_tree dtree,int level,FilterGH *flt,enum FilterMethod method,enum Information_Cost cost,double epsilon);extern Image_tree decompose_to_level(Image original,int level,FilterGH *flt,enum FilterMethod method);extern decompose_all(Image_tree tree,int maxlevel,FilterGH *flt,enum FilterMethod method, enum Information_Cost cost,double epsilon);extern int find_deepest_level(int width,int height); /*Selective methods*/extern int selectiv_tiling1(Image img,Segments seg,int filternumber,char *file, enum Information_Cost cost,double epsilon);extern Image inv_selectiv_tiling1(char *file);extern int selectiv_tiling2(Image img,Segments seg,int filternumber,char *file, enum Information_Cost cost,double epsilon);extern Image inv_selectiv_tiling2(char *file); extern int selectiv_quant1(Image img,IntImage area,int filternumber,char *file, enum Information_Cost cost,double epsilon);extern Image inv_selectiv_quant1(char *file);extern int selectiv_quant2(Image img,IntImage area,int filternumber,char *file, enum Information_Cost cost,double epsilon);extern Image inv_selectiv_quant2(char *file);extern int selectiv_quant3(Image img,IntImage area,int filternumber,char *file, enum Information_Cost cost,double epsilon);extern Image inv_selectiv_quant3(char *file);extern smooth_block(Image img,int x,int y, int width,int height);extern compute_map(Image_tree tree,IntImage map);extern int *pixelarray_to_intarray(Pixel *pdata,int size);extern Pixel *intarray_to_pixelarray(int *idata,int size);#define WAVELET_H#endif
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -