logoalt Hacker News

Show HN: SplatHash – A lightweight alternative to BlurHash and ThumbHash

49 pointsby unsorted2270today at 11:24 AM20 commentsview on HN

Hi HN,

I built SplatHash. It's a lightweight image placeholder generator I wrote to be a simpler, faster alternative to BlurHash and ThumbHash.

Repo: https://github.com/junevm/splathash


Comments

Dwedittoday at 4:05 PM

One other thing to compare it against is actual tiny JPEGs.

When you save a series of images as 16x16 JPEGs at the same JPEG quality level without optimization, you notice that there is a whole lot of common data between those files. Common data includes things like the file header (FF D8, FF E0 blocks), the Quantization tables, and the Huffman tables. If you cut away all the common data, the actual size of the image data is extremely tiny, usually under 64 bytes, though not a fixed size.

Here are the sizes of the four example images (just the unique image data) when resized to 16x16, then saved at quality 20:

First image: 48 bytes

Second image: 42 bytes

Third image: 31 bytes

Fourth image: 35 bytes

After appending back the 625 bytes of common data, you end up with a regular JPEG that can be decoded and displayed using fast native code from the browser.

ThumbHash page includes a comparison against "Potato WebP" which is probably a similar idea.

show 1 reply
geooff_today at 7:36 PM

This is super cool! I'm wondering what applications typically look like? Send a little hash like this along with a big image to show while decompressing?

twocommitstoday at 8:52 PM

Next: HashBrown.

lifthrasiirtoday at 12:37 PM

Interesting, but my testing suggests that SplatHash is very weak at preserving global features, at least for synthetic images [1]. Both BlurHash and ThumbHash were able to preserve most of them, at the expense of worse (but still non-zero) local feature reproduction, but SplatHash simply discarded all global features! I guess you need to store both local features (Gaussian splats) and global features (cosine bases) for the best result. The currently unused padding bit might be useful for that...

[1] I used my own avatars and icons as a test set. For example, https://avatars.githubusercontent.com/u/323836?s=400&v=4

show 1 reply
joshutoday at 4:26 PM

this is cool. i built something similar a while back using wavelets and matching pursuit in a similar manner but with a different goal; i wanted to make an image compressor that had different visual effects when the file format was glitched. here are some examples of it moving variance from the original above to the compressed image below: https://youtube.com/shorts/f2pZyZNXY0Q?si=HXf14pOs9DaAk7MZ https://youtube.com/shorts/-LIALRpU63o?si=p_MiFnT8MMX0C0b4

swaminarayantoday at 5:56 PM

How does SplatHash compare to BlurHash and ThumbHash in terms of visual fidelity vs byte size at the same target length?

montrosertoday at 12:49 PM

Very cool. To my eye, the splats are sometimes having too much contrast -- implying more "stark" visual features that don't actually manifest in the real image. Presumably the radius and the opacity curve of the gradients can be tuned to taste at the decoding phase, to make the splats softer?

show 1 reply
GaggiXtoday at 12:51 PM

The 6 blobs of colors look very weird after testing a few images, I feel like ThumbHash is much more natural and the downsides are minimal compare to SplatHash.

k2xltoday at 12:33 PM

Thanks for sharing. I didn’t even know this type of thing had multiple algorithms.

Can you share what are the reasons someone may want to compress and image to 16 bytes?

show 2 replies
therealdeal2020today at 12:42 PM

so you turn images into colored bubbles? Why do people use this?

show 4 replies