Lines Matching full:compression
27 zstd, short for Zstandard, is a fast lossless compression algorithm, targeting
28 real-time compression scenarios at zlib-level and better compression ratios.
29 The zstd compression library provides in-memory compression and decompression
32 The library supports regular compression levels from 1 up to ZSTD_maxCLevel(),
35 compression levels, which extend the range of speed vs. ratio preferences.
36 The lower the level, the faster the speed (at the cost of compression).
38 Compression can be done in:
41 - unbounded multiple steps (described as Streaming compression)
43 The compression ratio achievable on small data can be highly improved using
44 a dictionary. Dictionary compression can be performed in:
103 * Hint : compression runs faster if `dstCapacity` >= `ZSTD_compressBound(srcSize)`.
133 …* note 3 : decompressed size is always present when compression is completed using single-pass f…
168 ZSTDLIB_API int ZSTD_minCLevel(void); /*!< minimum negative compression level…
169 ZSTDLIB_API int ZSTD_maxCLevel(void); /*!< maximum compression level availabl…
175 /*= Compression context
178 * and re-use it for each successive compression operation.
181 * It doesn't change the compression ratio, which remains identical.
192 * this function compresses at requested compression level,
205 * and re-use it for each successive compression operation.
223 * Advanced compression API
240 /* Compression strategies, listed from fastest to strongest */
257 /* compression parameters
261 … ZSTD_c_compressionLevel=100, /* Set compression parameters according to pre-defined cLevel table.
262 * Note that exact compression parameters are dynamically determined,
263 * depending on both compression level and srcSize (when known).
266 * Note 1 : it's possible to pass a negative compression level.
267 … * Note 2 : setting a level does not automatically set all other compression parameters
268 … * to default. Setting this will however eventually dynamically impact the compression
271 /* Advanced compression parameters :
272 * It's possible to pin down compression parameters to some specific values.
285 * Larger tables improve compression ratio of strategies <= dFast,
291 * Larger tables result in better and slower compression.
297 * More attempts result in better and slower compression.
303 … * Larger values increase compression and decompression speed, but decrease ratio.
311 * Larger values make compression stronger, and slower.
314 * Larger values make compression faster, and weaker.
318 * resulting in stronger and slower compression.
323 * This parameter is designed to improve compression ratio
329 … * compression strategy >= ZSTD_btopt (== compression level 16+) */
331 * Larger values increase memory usage and compression ratio,
332 * but decrease compression speed.
337 * Larger/too small values usually decrease compression ratio.
341 … * Larger values improve collision resolution but decrease compression speed.
347 * Larger values improve compression speed.
348 … * Deviating far from default value will likely result in a compression ratio decrease.
353 * Content size must be known at the beginning of compression.
368 * while compression is performed in parallel, within worker thread(s).
373 … * compression is performed inside Caller's thread, and all invocations are blocking */
374 …ZSTD_c_jobSize=401, /* Size of a compression job. This value is enforced only when nbWorkers …
375 …* Each compression job is completed in parallel, so this value can indirectly impact the nb of act…
376 … * 0 means default, which is dynamically determined based on compression parameters.
381 … * It helps preserve compression ratio, while each job is compressed in parallel.
383 * Larger values increase compression ratio, but decrease speed.
441 * Set one compression parameter, selected by enum ZSTD_cParameter.
444 …g a parameter is generally only possible during frame initialization (before starting compression).
446 * the following parameters can be updated _during_ compression (within same frame):
479 * Useful after an error, or to interrupt any ongoing compression.
481 * Compression parameters and dictionary remain unchanged.
486 …* Parameters can only be changed between 2 sessions (i.e. no compression is curre…
493 …* Behave the same as ZSTD_compressCCtx(), but compression parameters are set using the advanced A…
496 …* - Compression parameters are pushed into CCtx before starting compression, using ZSTD_CCtx_set*…
497 * - The function is always blocking, returns when compression is completed.
498 * Hint : compression runs faster if `dstCapacity` >= `ZSTD_compressBound(srcSize)`.
555 * Set one compression parameter, selected by enum ZSTD_dParameter.
591 * Streaming compression - HowTo
595 * ZSTD_CStream objects can be reused multiple times on consecutive compression operations.
602 * Parameters are sticky : when starting a new compression on the same context,
603 * it will re-use the same sticky parameters as previous compression session.
657 /*===== Streaming compression functions =====*/
659 …llect more data, encoder decides when to output compressed result, for optimal compression ratio */
662 …ll continue: any future data can still reference previously compressed data, improving compression.
663 … * note : multithreaded compression will block to flush as much output as possible. */
668 … : note : multithreaded compression will block to flush as much output as possible. */
673 …* - Compression parameters are pushed into CCtx before starting compression, using ZSTD_CCtx_set*…
674 …* - Compression parameters cannot be changed once compression is started (save a list of exceptio…
690 * Before starting a new compression job, or changing compression parameters,
708 …* It's not rare that performance ends being spent more into the interface, rather than compression…
720 * Advanced parameters and dictionary compression can only be used through the
797 * Compression at an explicit compression level using a Dictionary.
811 * Dictionary must be identical to the one used during compression.
830 …* The resulting state can be used for future compression operations with very limited startup cos…
847 * Compression using a digested Dictionary.
849 * Note : compression level is _decided at dictionary creation time_,
927 * Tables are dependent on compression parameters, and for this reason,
928 * compression parameters can no longer be changed after loading a dictionary.
938 * Note that compression parameters are enforced from within CDict,
939 * and supersede any compression parameter previously set within CCtx.
955 …erforms much faster, especially during decompression (compression speed is tunable with compressio…
958 * Note 1 : Prefix buffer is referenced. It **must** outlive compression.
959 * Its content must remain unmodified during compression.
963 …* Note 3 : Referencing a prefix involves building tables, which are dependent on compression para…
1009 * and must use the same prefix as the one used during compression.
1067 /* compression parameter bounds */
1160 …unsigned windowLog; /*< largest match distance : larger == more compression, more memory nee…
1161 …unsigned chainLog; /*< fully searched segment : larger == more compression, slower, more me…
1163 unsigned searchLog; /*< nb of searches : larger == more compression, slower */
1164 …h; /*< match length searched : larger == faster decompression, sometimes less compression */
1165 …gth; /*< acceptable match size for optimal parser (only) : larger == more compression, slower */
1172 … 1: no dictID will be saved into frame header (dictID is only useful for dictionary compression) */
1219 * means that the compression can search both the dictionary and input
1221 * the compression faster per-byte of input. However, the initial copy of
1223 * compression. For small compressions (< 8 KB), that copy can dominate
1224 * the cost of the compression.
1226 * - The CDict's tables can be used in-place. In this model, compression is
1239 * at the beginning of a compression. However, if experimentation shows that
1250 …_lcm_auto = 0, /*< Automatically determine the compression mode based on the compression …
1251 … * Negative compression levels will be uncompressed, and positive compression
1253 …ZSTD_lcm_huffman = 1, /*< Always attempt Huffman compression. Uncompressed literals will sti…
1254 * emitted if Huffman compression is not profitable. */
1274 * note 2 : decompressed size is always present when compression is done with ZSTD_compress()
1320 * zc can be used to insert custom compression params.
1349 * The compression behavior changes based on cctx params. In particular:
1363 …ionLevel accordingly adjusts the strength of the entropy coder, as it would in typical compression.
1403 * for any compression level up to selected one.
1412 * because the CCtx compression context will need less memory.
1416 …* Both can be used to estimate memory using custom compression parameters and arbitrary srcSize l…
1418 * Note 2 : only single-threaded compression is supported.
1427 …* ZSTD_estimateCStreamSize() will provide a budget large enough for any compression level up to s…
1431 …ed in tandem with ZSTD_CCtxParams_setParameter(). Only single-threaded compression is supported. T…
1432 * Note : CStream size estimation is only correct for single-threaded compression.
1447 …* ZSTD_estimateCDictSize_advanced() makes it possible to control compression parameters precisely…
1468 * Note 3 : cParams : use ZSTD_getCParams() to convert a compression level
1519 * These prototypes make it possible to share a thread pool among multiple compression contexts.
1521 * a threaded compression mode (via ZSTD_c_nbWorkers parameter).
1552 * Advanced compression functions
1556 * Create a digested dictionary for compression
1570 …* @return ZSTD_compressionParameters structure for a selected compression level and estimated srcS…
1640 * it will result in compression ratio degradation.
1645 * NOTE 3: Rsyncable mode limits maximum compression speed to ~400 MB/s.
1646 * If the selected compression level is already running significantly slower,
1651 /* Select a compression format.
1680 * but compression ratio may regress significantly if guess considerably underestimates */
1691 * construction (via ZSTD_createCDict_advanced2()). A compression will then
1703 * To an approximation, a compression using a dictionary can then use those
1705 * compression where the simulated compression of the dictionary left off.
1712 * written as the compression goes along. This means we can choose a search
1719 * highly recommended that you simply set a compression level in the CCtxParams
1733 * In general, you should expect compression to be faster--sometimes very much
1746 * compression will fail if it ever changes. This means the only flush
1749 * MUST not be modified during compression or you will get data corruption.
1762 * memory. However, compression WILL fail if you violate the preconditions.
1765 * not be modified during compression or you will get data corruption. This
1795 * For use with sequence compression API: ZSTD_compressSequences().
1806 * For use with sequence compression API: ZSTD_compressSequences().
1821 * Get the requested compression parameter value, selected by enum ZSTD_cParameter,
1839 * - ZSTD_compressStream2() : Do compression using the CCtx.
1843 * for static allocation of CCtx for single-threaded compression.
1854 * Initializes the compression parameters of cctxParams according to
1855 * compression level. All other parameters are reset to their default values.
1860 * Initializes the compression and frame parameters of cctxParams according to
1867 * Set one compression parameter, selected by enum ZSTD_cParameter.
1877 * Get the requested value of one compression parameter, selected by enum ZSTD_cParameter.
1883 * Apply a set of ZSTD_CCtx_params to the compression context.
1884 * This can be done even after compression is started,
1885 * if nbWorkers==0, this will have no impact until a new compression is started.
1960 * allowing selection between ZSTD_format_e input compression formats
2000 * of whether checksumming was specified during compression. This offers some
2056 /*===== Advanced Streaming compression functions =====*/
2118 * note : cdict will just be referenced, and must outlive compression session
2239 Buffer-less streaming compression (synchronous mode)
2243 ZSTD_CCtx object can be re-used multiple times within successive compression operations.
2246 Use ZSTD_compressBegin(), or ZSTD_compressBegin_usingDict() for dictionary compression,
2256 ZSTD_compressContinue() doesn't guarantee recover after a failed compression.
2269 /*===== Buffer-less streaming compression functions =====*/
2274 …rameters const fParams, unsigned long long const pledgedSrcSize); /* compression parameters are …
2321 Finally, if you control the compression process, you can also ignore all buffer size rules,
2406 + compression : any ZSTD_compressBegin*() variant, including with dictionary