diff m-toolbox/classes/+utils/@helper/dzip.m @ 0:f0afece42f48

Import.
author Daniele Nicolodi <nicolodi@science.unitn.it>
date Wed, 23 Nov 2011 19:22:13 +0100 (2011-11-23)
parents
children
line wrap: on
line diff
--- /dev/null	Thu Jan 01 00:00:00 1970 +0000
+++ b/m-toolbox/classes/+utils/@helper/dzip.m	Wed Nov 23 19:22:13 2011 +0100
@@ -0,0 +1,53 @@
+function Z = dzip(M)
+% DZIP - losslessly compress data into smaller memory space
+%
+% USAGE:
+% Z = dzip(M)
+%
+% VARIABLES:
+% M = variable to compress
+% Z = compressed output
+%
+% NOTES: (1) The input variable M can be a scalar, vector, matrix, or
+%            n-dimensional matrix
+%        (2) The input variable must be a non-complex and full (meaning
+%            matrices declared as type "sparse" are not allowed)
+%        (3) Permitted input types include: double, single, logical,
+%            char, int8, uint8, int16, uint16, int32, uint32, int64,
+%            and uint64.
+%        (4) In testing, DZIP compresses several megabytes of data per
+%            second.
+%        (5) In testing, random matrices of type double compress to about
+%            75% of their original size. Sparsely populated matrices or
+%            matrices with regular structure can compress to less than
+%            1% of their original size. The realized compression ratio
+%            is heavily dependent on the data.
+%        (6) Variables originally occupying very little memory (less than
+%            about half of one kilobyte) are handled correctly, but
+%            the compression requires some overhead and may actually
+%            increase the storage size of such small data sets.
+%            One exception to this rule is noted below.
+%        (7) LOGICAL variables are compressed to a small fraction of
+%            their original sizes.
+%        (8) The DUNZIP function decompresses the output of this function
+%            and restores the original data, including size and class type.
+%        (9) This function uses the public domain ZLIB Deflater algorithm.
+%       (10) Carefully tested, but no warranty; use at your own risk.
+%       (11) Michael Kleder, Nov 2005
+
+s = size(M);
+c = class(M);
+cn = strmatch(c,{'double','single','logical','char','int8','uint8',...
+    'int16','uint16','int32','uint32','int64','uint64'});
+if cn == 3 | cn == 4
+    M=uint8(M);
+end
+M=typecast(M(:),'uint8');
+M=[uint8(cn);uint8(length(s));typecast(s(:),'uint8');M(:)];
+f=java.io.ByteArrayOutputStream();
+g=java.util.zip.DeflaterOutputStream(f);
+g.write(M);
+g.close;
+Z=typecast(f.toByteArray,'uint8');
+f.close;
+return