This repository has been archived by the owner on Mar 8, 2023. It is now read-only.
-
Notifications
You must be signed in to change notification settings - Fork 119
/
Copy pathjbig_ar.h
55 lines (48 loc) · 2.26 KB
/
jbig_ar.h
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
/*
* Header file for the arithmetic encoder and decoder of
* the portable JBIG compression library
*
* Markus Kuhn -- http://www.cl.cam.ac.uk/~mgk25/jbigkit/
*
* $Id: jbig_ar.h,v 1.1 2008/09/05 15:05:54 rick Exp $
*/
#ifndef JBG_AR_H
#define JBG_AR_H
/*
* Status of arithmetic encoder
*/
struct jbg_arenc_state {
unsigned char st[4096]; /* probability status for contexts, MSB = MPS */
unsigned long c; /* register C: base of coding intervall, *
* layout as in Table 23 */
unsigned long a; /* register A: normalized size of coding interval */
long sc; /* number of buffered 0xff values that might still overflow */
int ct; /* bit shift counter, determines when next byte will be written */
int buffer; /* buffer for most recent output byte != 0xff */
void (*byte_out)(int, void *); /* function that receives all PSCD bytes */
void *file; /* parameter passed to byte_out */
};
/*
* Status of arithmetic decoder
*/
struct jbg_ardec_state {
unsigned char st[4096]; /* probability status for contexts, MSB = MPS */
unsigned long c; /* register C: base of coding intervall, *
* layout as in Table 25 */
unsigned long a; /* register A: normalized size of coding interval */
unsigned char *pscd_ptr; /* pointer to next PSCD data byte */
unsigned char *pscd_end; /* pointer to byte after PSCD */
int ct; /* bit-shift counter, determines when next byte will be read;
* special value -1 signals that zero-padding has started */
int startup; /* boolean flag that controls initial fill of s->c */
int nopadding; /* boolean flag that triggers return -2 between
* reaching PSCD end and decoding the first symbol
* that might never have been encoded in the first
* place */
};
void arith_encode_init(struct jbg_arenc_state *s, int reuse_st);
void arith_encode_flush(struct jbg_arenc_state *s);
void arith_encode(struct jbg_arenc_state *s, int cx, int pix);
void arith_decode_init(struct jbg_ardec_state *s, int reuse_st);
int arith_decode(struct jbg_ardec_state *s, int cx);
#endif /* JBG_AR_H */