2002-02-03 16:30:31 +00:00
|
|
|
#ifndef __WAVELET_H
|
|
|
|
#define __WAVELET_H
|
|
|
|
|
|
|
|
#include <stdint.h>
|
|
|
|
|
|
|
|
|
2004-03-14 22:34:33 +00:00
|
|
|
typedef struct
|
|
|
|
{
|
|
|
|
TYPE *data;
|
|
|
|
uint32_t width;
|
|
|
|
uint32_t height;
|
|
|
|
uint32_t frames;
|
|
|
|
uint32_t scales;
|
|
|
|
uint32_t *w;
|
|
|
|
uint32_t *h;
|
|
|
|
uint32_t *f;
|
|
|
|
uint32_t (*offset)[8];
|
|
|
|
TYPE *scratchbuf;
|
2002-02-03 16:30:31 +00:00
|
|
|
} Wavelet3DBuf;
|
|
|
|
|
|
|
|
|
2004-03-14 22:34:33 +00:00
|
|
|
extern Wavelet3DBuf *wavelet_3d_buf_new (uint32_t width, uint32_t height,
|
|
|
|
uint32_t frames);
|
2002-02-03 16:30:31 +00:00
|
|
|
|
2004-03-14 22:34:33 +00:00
|
|
|
extern void wavelet_3d_buf_destroy (Wavelet3DBuf * buf);
|
2002-02-03 16:30:31 +00:00
|
|
|
|
|
|
|
/**
|
|
|
|
* transform buf->data
|
|
|
|
* a_moments is the number of vanishing moments of the analyzing
|
|
|
|
* highpass filter,
|
|
|
|
* s_moments the one of the synthesizing lowpass filter.
|
|
|
|
*/
|
2004-03-14 22:34:33 +00:00
|
|
|
extern void wavelet_3d_buf_fwd_xform (Wavelet3DBuf * buf,
|
|
|
|
int a_moments, int s_moments);
|
|
|
|
extern void wavelet_3d_buf_inv_xform (Wavelet3DBuf * buf,
|
|
|
|
int a_moments, int s_moments);
|
2002-02-03 16:30:31 +00:00
|
|
|
|
2004-03-14 22:34:33 +00:00
|
|
|
extern int wavelet_3d_buf_encode_coeff (const Wavelet3DBuf * buf,
|
|
|
|
uint8_t * bitstream, uint32_t limit);
|
2002-02-03 16:30:31 +00:00
|
|
|
|
2004-03-14 22:34:33 +00:00
|
|
|
extern void wavelet_3d_buf_decode_coeff (Wavelet3DBuf * buf,
|
|
|
|
uint8_t * bitstream, uint32_t limit);
|
2002-02-03 16:30:31 +00:00
|
|
|
|
|
|
|
#if defined(DBG_XFORM)
|
|
|
|
extern void wavelet_3d_buf_dump (char *fmt,
|
2004-03-14 22:34:33 +00:00
|
|
|
uint32_t first_frame_in_buf,
|
|
|
|
uint32_t id, Wavelet3DBuf * buf, int16_t offset);
|
2002-02-03 16:30:31 +00:00
|
|
|
#else
|
|
|
|
#define wavelet_3d_buf_dump(x...)
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#endif
|