summaryrefslogtreecommitdiff
path: root/include/compression/coder.h
blob: 5cef38a04470459be82a3286bccc94325c7e4bc9 (plain)
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
/* This code is part of the tng compression routines.
 *
 * Written by Daniel Spangberg
 * Copyright (c) 2010, 2013, The GROMACS development team.
 *
 *
 * This program is free software; you can redistribute it and/or
 * modify it under the terms of the GNU Lesser General Public License
 * as published by the Free Software Foundation; either version 2.1
 * of the License, or (at your option) any later version.
 */

#ifndef CODER_H
#define CODER_H

struct coder
{
    unsigned int pack_temporary;
    int pack_temporary_bits;
    int stat_overflow;
    int stat_numval;
};

struct coder *Ptngc_coder_init(void);
void Ptngc_coder_deinit(struct coder *coder);
unsigned char *Ptngc_pack_array(struct coder *coder,int *input, int *length, int coding, int coding_parameter, int natoms, int speed);
int Ptngc_unpack_array(struct coder *coder,unsigned char *packed,int *output, int length, int coding, int coding_parameter, int natoms);
unsigned char *Ptngc_pack_array_xtc2(struct coder *coder,int *input, int *length);
int Ptngc_unpack_array_xtc2(struct coder *coder,unsigned char *packed,int *output, int length);
unsigned char *Ptngc_pack_array_xtc3(int *input, int *length, int natoms, int speed);
int Ptngc_unpack_array_xtc3(unsigned char *packed,int *output, int length, int natoms);

void Ptngc_out8bits(struct coder *coder, unsigned char **output);
void Ptngc_pack_flush(struct coder *coder,unsigned char **output);
void Ptngc_write_pattern(struct coder *coder,unsigned int pattern, int nbits, unsigned char **output);

void Ptngc_writebits(struct coder *coder,unsigned int value,int nbits, unsigned char **output_ptr);
void Ptngc_write32bits(struct coder *coder,unsigned int value,int nbits, unsigned char **output_ptr);
void Ptngc_writemanybits(struct coder *coder,unsigned char *value,int nbits, unsigned char **output_ptr);


#endif
contact: Jan Huwald // Impressum