kuuhana
  • Communities
  • Multi-communities
  • Support Lemmy
  • Search
  • Login
  • Sign Up
Programming@programming.devbyruffsl@programming.dev
8 months

OpenZL Explained - Changing Data Compression Forever

youtube.com English
  • https://openzl.org/
  • https://engineering.fb.com/2025/10/06/developer-tools/openzl-open-source-format-aware-compression-framework/
20
    - YouTube
    youtube.com
    Auf YouTube findest du die angesagtesten Videos und Tracks. Außerdem kannst du eigene Inhalte hochladen und mit Freunden oder gleich der ganzen Welt teilen.
    You must log in or register to comment.

    • hoshikarakitaridia@lemmy.world
      8 months

      The guy in the videos sounds really convinced. Is this a big thing or more of a “cautious optimism” thing as is with most scientific innovation?

        • Eager Eagle@lemmy.worldEnglish
          8 months

          It’ll have its uses, I’m sure, but is not like this training specialized compressors is free, or even always advantageous

          The goal of OpenZL is to generate specialized compressors, optimized for user’s input. To this end, you are going to train a new profile and use it to compress the data. The approach makes more sense when compressing a large flow of similar data, because the cost of training is then amortized across all future compressions.

          • PhilipTheBucket@piefed.socialEnglish
            8 months

            I strongly suspect that it’s a bunch of “machine learning” hooey. If your compression is capable at all, it should be able to spend a few bits on categorizing what the “format” type stuff he’s talking about is, and then do pretty much equally well as whatever specialized compressor. I won’t say it will never be useful for some kind of data that has patterns and regularity that are not immediately obvious unless you spell it out for the compressor (2d images where there are similarities between the same positions on consecutive lines widely separated in the bytestream for example), but my guess is that this is a bunch of hype and garbage.

            Just out of curiosity, I downloaded it and did the quickstart to test my assumption. Results I got:

            $ ls -lh reads*
            -rw-r--r-- 1 billy users  27M Oct 19 15:14 reads.csv
            -rw-r--r-- 1 billy users 4.2M Oct 19 15:15 reads.csv.bz2
            -rw-r--r-- 1 billy users 6.7M Oct 19 15:16 reads.csv.zl
            

            So yeah I think at least at first look, for general-purpose compression it’s trash. IDK. I also tried exactly what it sounds like their use case is, compressing PyTorch models, and it’s kinda cool maybe (and certainly faster than bzip2 for those models) but at best it seems like a one-trick pony.

            $ ls -lh optimizer*
            -rw-r--r-- 1 billy users  76M Oct 19 15:26 optimizer.bin
            -rw-r--r-- 1 billy users  56M Oct 19 15:27 optimizer.bin.bz2
            -rw-r--r-- 1 billy users  53M Oct 19 15:26 optimizer.bin.zl
            

            I feel like maybe building Huffman trees based on general-purpose prediction of what comes next, and teaching that how to grasp what the next bits might turn out to be based on what has come before including traversing different formats or even just skipping backwards in the data by specified amounts, might be a better way than whatever this is doing. But doing way worse than bzip2 for simple textual data even when we give it the “format hint” that it’s looking for is a sign of problems to me.

              • phiresky@lemmy.world
                8 months

                This is from the same people that made zstd, the current state of the art for generic compression by almost any metric. They know what they are doing. Of course this is not better at generic compression because that’s not what it’s for.

                Edit: I would assume the video is not great and can recommend the official article: https://engineering.fb.com/2025/10/06/developer-tools/openzl-open-source-format-aware-compression-framework/

                  • PhilipTheBucket@piefed.socialEnglish
                    8 months

                    the current state of the art for generic compression by almost any metric

                    $ ls -lh optimizer*
                    -rw-r--r-- 1 billy users 76M Oct 19 15:51 optimizer.bin
                    -rw-r--r-- 1 billy users 56M Oct 19 15:51 optimizer.bin.bz2
                    -rw-r--r-- 1 billy users 60M Oct 19 15:51 optimizer.bin.zstd
                    

                    I mean apparently not.

                    (Lempel-Ziv is not the best compression that’s currently known by a wide margin. It’s very fast and it’s nicely elegant but I would expect almost any modern “next gen compression” to be based on Huffman trees at the very core, or else specialized lossy compression. Maybe I am wrong, I’m not super up to speed on this stuff, but zstd is not state of the art, that much I definitely know.)

                    Of course this is not better at generic compression because that’s not what it’s for.

                    They specifically offered csv as an example of a thing it can handle, that’s why I chose that as one of the tests.

                      • phiresky@lemmy.world
                        8 months

                        Zstd by default uses a level that’s like 10x faster than the default of bz2. Also Bz2 is unusably slow in decompression if you have files >100MB.

                          • PhilipTheBucket@piefed.socialEnglish
                            8 months

                            Yes, Lempel-Ziv is incredibly fast in compression. That’s because it’s a sort of elegant hack from the 1970s that more or less gets lucky in terms of how it can be made to work to compress files. It’s very nice. You said “by almost any metric,” though, not “by compression speed and literally nothing else.” There is a reason web pages default to using gzip instead of zstd for example.

                            Absolutely no idea what you’re on about with >100 MB. I’ve used bzip2 for all my hard disk backups for about 20 years now, and I think I broke the 100 MB barrier for local storage at some point during that time.

                              • phiresky@lemmy.world
                                8 months

                                My point is you are comparing the wrong thing, if you make zstd as slow as bz2 by increasing the level, you will get same or better compression ratio on most content. You’re just comparing who has defaults you like more. Zstd is on the Pareto front almost everywhere, you can tune it to be (almost) the fastest and you can tune it to be almost the highest compression ratio with a single number, all while having decompression speeds topping alternatives.

                                Additionally it has features nothing else has, like --adapt mode and dictionary compression.

                                  • PhilipTheBucket@piefed.socialEnglish
                                    8 months

                                    What are you basing this all on?

                                    $ time (cat optimizer.bin | bzip2 > optimizer.bin.bz2)
                                    
                                    real	0m4.352s
                                    user	0m4.244s
                                    sys	0m0.135s
                                    
                                    $ time (cat optimizer.bin | zstd -19 > optimizer.bin.zst)
                                    
                                    real	0m12.786s
                                    user	0m28.457s
                                    sys	0m0.237s
                                    
                                    $ ls -lh optimizer.bin*
                                    -rw-r--r-- 1 billy users 76M Oct 20 17:54 optimizer.bin
                                    -rw-r--r-- 1 billy users 56M Oct 20 17:55 optimizer.bin.bz2
                                    -rw-r--r-- 1 billy users 59M Oct 20 17:56 optimizer.bin.zst
                                    
                                    $ time (cat stocks-part-2022-08.tar | bzip2 > stocks-part-2022-08.tar.bz2)
                                    
                                    real	0m3.845s
                                    user	0m3.788s
                                    sys	0m0.103s
                                    
                                    $ time (cat stocks-part-2022-08.tar | zstd -19 > stocks-part-2022-08.zst)
                                    
                                    real	0m34.917s
                                    user	1m12.811s
                                    sys	0m0.211s
                                    
                                    $ ls -lh stocks-part-2022-08.*
                                    -rw-r--r-- 1 billy users 73M Oct 20 17:57 stocks-part-2022-08.tar
                                    -rw-r--r-- 1 billy users 26M Oct 20 17:58 stocks-part-2022-08.tar.bz2
                                    -rw-r--r-- 1 billy users 27M Oct 20 17:59 stocks-part-2022-08.zst
                                    

                                    Are you looking at https://jdlm.info/articles/2017/05/01/compression-pareto-docker-gnuplot.html or something? I would expect Lempel-Ziv to perform phenomenally on genomic data because of how many widely separated repeated sequences the data will have… for that specific domain I could see zstd being a clear winner (super fast obviously and also happens to have the best compression, although check the not-starting-at-0 Y axis to put that in context).

                                    I have literally never heard of someone claiming zstd was the best overall general purpose compression. Where are you getting this?

                      • pulsewidth@lemmy.world
                        8 months

                        1000125806

                        • KiwiTB@lemmy.world
                          8 months

                          Or you just use the same concept from the early 90s where you have a dedicated routine for data as a library which is used instead and offers more benefits.

                          Might as well code it properly than recode it in a more generic way in another language.

                            • MalReynolds@piefed.socialEnglish
                              8 months

                              Sure, I was doing genome compression for tree comparison in the late 90s for in memory analysis and the speed up was very significant. The idea of a universal specification format and a universal decoder is IMO bloody brilliant, hell with a bit of training I’d be unsurprised if you could point a LLM at a format and get 90+% of the way there with the specification for most simple-ish formats, and probably have a manual crack at simple relational databases. Potentially you could also switch out huffman for encryption for efficient zero-knowledge proofs as well.

                                • KiwiTB@lemmy.world
                                  8 months

                                  It could work out well. Be interesting to see if it’s widely adopted.

                              Programming@programming.dev

                              programming@programming.dev

                              Subscribe from remote instance

                              Create post

                              Report community

                              Modlog
                              You are not logged in. However you can subscribe from another Fediverse account, for example Lemmy or Mastodon. To do this, paste the following into the search field of your instance: !programming@programming.dev

                              Welcome to the main community in programming.dev! Feel free to post anything relating to programming here!

                              Cross posting is strongly encouraged in the instance. If you feel your post or another person’s post makes sense in another community cross post into it.

                              Hope you enjoy the instance!

                              Rules

                              Rules

                              • Follow the programming.dev instance rules
                              • Keep content related to programming in some way
                              • If you’re posting long videos try to add in some form of tldr for those who don’t want to watch videos

                              Wormhole

                              Follow the wormhole through a path of communities !webdev@programming.dev



                              Visibility: Public

                              This community is visible to everyone.

                              • 3 users / Day
                              • 189 users / Week
                              • 192 users / Month
                              • 7.06K users / 6 months
                              • 3.16K posts
                              • 46.1K comments
                              • 1 local subscriber
                              • 27.4K subscribers
                              • UI: 1.0.0-beta.0
                              • BE: 1.0.0-alpha.20
                              • Modlog
                              • Instances
                              • Docs
                              • Code
                              • join-lemmy.org