package decompress
Install
dune-project
Dependency
Authors
Maintainers
Sources
sha256=a8c9a6ba132514d56ad3626fbd5e79124844836010350ee161d43bb29bf5762e
sha512=1a5a935ff55ebad83682cffb9792b1b5e3a189d2df483f77856ea683706219f7c50ff14b7ab1de0c5ce90e0d779bd06ab86afb29d39461192fbbf4b3fbaf600c
doc/decompress.de/De/Lz77/index.html
Module De.Lz77Source
The type for input sources. With a `Manual source the client must provide input with src. With `String or `Channel source the client can safely discard `Await case (with assert false).
The type for states.
literals s is frequencies of lengths and literals emitted by s since it was created.
distances s is frequencies of distances emitted by s since it was created.
src s i j l provides s with l bytes to read, starting at j in i. This byte range is read by calls to compress with s until `Await is returned. To signal the end of input call the function with l = 0.
compress s is:
`Awaitifshas a`Manualinput source and awits for more input. The client must usesrcto provide it.`Flushifsfilled completely the shared-queueq(given instate).Queue.junk_exnorQueue.pop_exncan be used to give some free cells tocompress.`Endifscompressed all input. Given shared-queueqis possibly not empty.
state src ~w ~q is an state that inputs from src and that outputs to q.
Window.
The client can constrain lookup operation by a window. Small window enforces compress to emit small distances. However, large window allows compress to go furthermore to recognize a pattern which can be expensive.
Level.
Lz77 has mainly 2 levels:
0where we only copy inputs to outpus, we don't do a lookupn(to9) with a certain configuration of the lookup. The higher the level, the longer it may take to find a pattern.
The 0 can be useful to only pack an input into a format such as DEFLATE - as an already compressed document such as a video or an image. Otherwise, 4 as the level is pretty common.