diff options
Diffstat (limited to 'src/compression/dict.c')
-rw-r--r-- | src/compression/dict.c | 45 |
1 files changed, 45 insertions, 0 deletions
diff --git a/src/compression/dict.c b/src/compression/dict.c new file mode 100644 index 0000000..59c1994 --- /dev/null +++ b/src/compression/dict.c @@ -0,0 +1,45 @@ +/* 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. + */ + + +#include <string.h> +#include "dict.h" + +void Ptngc_comp_canonical_dict(unsigned int *dict, int *ndict) +{ + int i; + for (i=0; i<0x20004; i++) + dict[i]=i; + *ndict=0x20004; +} + +void Ptngc_comp_make_dict_hist(unsigned int *vals, int nvals, + unsigned int *dict, int *ndict, + unsigned int *hist) +{ + int i; + int j=0; + for (i=0; i<0x20004; i++) + hist[i]=0; + for (i=0; i<0x20004; i++) + dict[i]=i; + for (i=0; i<nvals; i++) + hist[vals[i]]++; + for (i=0; i<0x20004; i++) + if (hist[i]!=0) + { + hist[j]=hist[i]; + dict[j]=dict[i]; + j++; + } + *ndict=j; +} |