Package me.lemire.longcompression
Class LongComposition
java.lang.Object
me.lemire.longcompression.LongComposition
-
Constructor Summary
ConstructorsConstructorDescriptionLongComposition
(LongCODEC f1, LongCODEC f2) Compose a scheme from a first one (f1) and a second one (f2). -
Method Summary
Modifier and TypeMethodDescriptionvoid
compress
(long[] in, IntWrapper inpos, int inlength, long[] out, IntWrapper outpos) Compress data from an array to another array.toString()
void
uncompress
(long[] in, IntWrapper inpos, int inlength, long[] out, IntWrapper outpos) Uncompress data from an array to another array.
-
Constructor Details
-
LongComposition
Compose a scheme from a first one (f1) and a second one (f2). The first one is called first and then the second one tries to compress whatever remains from the first run. By convention, the first scheme should be such that if, during decoding, a 32-bit zero is first encountered, then there is no output.- Parameters:
f1
- first codecf2
- second codec
-
-
Method Details
-
compress
Description copied from interface:LongCODEC
Compress data from an array to another array. Both inpos and outpos are modified to represent how much data was read and written to. If 12 longs (inlength = 12) are compressed to 3 longs, then inpos will be incremented by 12 while outpos will be incremented by 3. We use IntWrapper to pass the values by reference. -
uncompress
Description copied from interface:LongCODEC
Uncompress data from an array to another array. Both inpos and outpos parameters are modified to indicate new positions after read/write.- Specified by:
uncompress
in interfaceLongCODEC
- Parameters:
in
- array containing data in compressed forminpos
- where to start reading in the arrayinlength
- length of the compressed data (ignored by some schemes)out
- array where to write the uncompressed outputoutpos
- where to start writing the uncompressed output in out
-
toString
-