Incremental update
[platform/upstream/libvorbis.git] / vq / vqgen.h
1 /********************************************************************
2  *                                                                  *
3  * THIS FILE IS PART OF THE Ogg Vorbis SOFTWARE CODEC SOURCE CODE.  *
4  * USE, DISTRIBUTION AND REPRODUCTION OF THIS SOURCE IS GOVERNED BY *
5  * THE GNU PUBLIC LICENSE 2, WHICH IS INCLUDED WITH THIS SOURCE.    *
6  * PLEASE READ THESE TERMS DISTRIBUTING.                            *
7  *                                                                  *
8  * THE OggSQUISH SOURCE CODE IS (C) COPYRIGHT 1994-1999             *
9  * by 1999 Monty <monty@xiph.org> and The XIPHOPHORUS Company       *
10  * http://www.xiph.org/                                             *
11  *                                                                  *
12  ********************************************************************/
13
14 #ifndef _VQGEN_H_
15 #define _VQGEN_H_
16
17 typedef struct vqgen{
18   int it;
19
20   int    elements;
21
22   /* point cache */
23   double *pointlist; 
24   long   points;
25   long   allocated;
26
27   /* entries */
28   double *entrylist;
29   long   *assigned;
30   double *bias;
31   long   entries;
32
33   double (*metric_func)   (struct vqgen *v,double *a,double *b);
34 } vqgen;
35
36 typedef struct vqbook{
37   long elements;
38   long entries;
39   double *valuelist;
40   long   *codelist;
41   long   *lengthlist;
42
43   /* auxiliary encoding/decoding information */
44   long   *ptr0;
45   long   *ptr1;
46
47   /* auxiliary encoding information */
48   double *n;
49   double *c;
50   long   aux;
51   long   alloc;
52
53 } vqbook;
54
55 extern void vqgen_init(vqgen *v,int elements,int entries,
56                        double (*metric)(vqgen *,double *, double *));
57 extern void vqgen_addpoint(vqgen *v, double *p);
58 extern double *vqgen_midpoint(vqgen *v);
59 extern double vqgen_iterate(vqgen *v);
60 extern int vqenc_entry(vqbook *b,double *val);
61 extern void vqgen_book(vqgen *v,vqbook *b);
62 extern double *_now(vqgen *v,long ptr);
63
64 #endif
65
66
67
68
69