Comments (5)
Then what's exactly kind of case where zstd dictionary compression can actually stand out? Can I say, it's the case of many small files but don't allow to be concatenated?
Yes. It's a case where random access is required, or there is no time or memory to allow concatenation.
These cases are more common in data centers than on personal computers.
from zstd.
lz4
already supports it.
zlib
should also support it, the interface may be less obvious though.
No idea about snappy
.
from zstd.
This is highly unlikely.
There might be ways to manufacture a case to explicitly advantage the dictionary compression method, but even in this case, such a difference would end up being unimpressive.
Sort of such cheating technique, I would expect the more natural "stream the whole file" method to win every time, and sometimes by very significant margins.
from zstd.
@Cyan4973 Thanks for the very clear conclusion.
Given many files to compress, it's usually understandable that to compress the concatenating file of all can get a better compression effectiveness than compress each file one by one.
Then what's exactly kind of case where zstd dictionary compression can actually stand out? Can I say, it's the case of many small files but don't allow to be concatenated?
from zstd.
@Cyan4973 BTW, from your view, how difficult it is to expand the dictionary mechanism into other compression algorithms like snappy, lz4, gzip, zlib?
from zstd.
Related Issues (20)
- MSVC CMake build failed on v1.5.6
- v1.5.6 Windows binary downloads are double zipped HOT 4
- Raise version's in win32 binaries header HOT 3
- Why was the new release 1.5.6 removed? HOT 15
- long file names are cut off in output HOT 3
- Should zstd check archive consistency before overwriting files? HOT 1
- Should zstd delete incomplete archives? HOT 5
- 32-bit x86 build failure with 1.5.6 HOT 3
- v1.5.6 breaks 32-bit Windows clang-cl build HOT 3
- Decompress multiple zstaa backups on FAT32 drives HOT 4
- Replication of bug #3517 HOT 16
- Separate dictionary references to enable dictionary usage for any combination of window size and content size HOT 1
- Decompression speed regression in zstd 1.5.6 (win)
- Embed hash of raw dictionary in compressed resource (optionally) HOT 4
- Decompression crash after upgrading from zstd 1.4.5 to 1.5.6 HOT 12
- Missing check on failed allocation leads to NULL-ptr dereference
- libzstd.lib missed in package, also VC sample seems include wrong mem.h or ambigious including!
- Environment variable for --memory HOT 2
- Improve misleading wording in the streaming decompression howto HOT 1
- erro
Recommend Projects
-
React
A declarative, efficient, and flexible JavaScript library for building user interfaces.
-
Vue.js
🖖 Vue.js is a progressive, incrementally-adoptable JavaScript framework for building UI on the web.
-
Typescript
TypeScript is a superset of JavaScript that compiles to clean JavaScript output.
-
TensorFlow
An Open Source Machine Learning Framework for Everyone
-
Django
The Web framework for perfectionists with deadlines.
-
Laravel
A PHP framework for web artisans
-
D3
Bring data to life with SVG, Canvas and HTML. 📊📈🎉
-
Recommend Topics
-
javascript
JavaScript (JS) is a lightweight interpreted programming language with first-class functions.
-
web
Some thing interesting about web. New door for the world.
-
server
A server is a program made to process requests and deliver data to clients.
-
Machine learning
Machine learning is a way of modeling and interpreting data that allows a piece of software to respond intelligently.
-
Visualization
Some thing interesting about visualization, use data art
-
Game
Some thing interesting about game, make everyone happy.
Recommend Org
-
Facebook
We are working to build community through open source technology. NB: members must have two-factor auth.
-
Microsoft
Open source projects and samples from Microsoft.
-
Google
Google ❤️ Open Source for everyone.
-
Alibaba
Alibaba Open Source for everyone
-
D3
Data-Driven Documents codes.
-
Tencent
China tencent open source team.
from zstd.