Skip to content

Two 32-bit bloom-filter implementations written in bash

Notifications You must be signed in to change notification settings

timbirms/bash-bloom

Repository files navigation

BASH-BLOOM

Between the two abberations contained in this repo, you get about 1100 lines of inpenetrable bash supported by my otherwise unrelated 1100 line shared.bash lib.

bloom-files

The slightly sane example, bloom-files is something for you distributed file-system ops people to figure out since you it manages at least the A in ACID :) by filling file-system 'slack space' with symlinks and subdirectories that can encode huge numbers.

bloom-files is also fun to read since it uses four concurrent bash pipes to pump data.

bloom-images

This slightly crazy example lets you watch a bloom filter fill up using an image viewer instead of file-system tools. It can do monochrome and color compressed into png's so that you could give an image like this someone so that your system would remember what they know when they upload the image again. Neato! :)

bloom-filter-viz bloom-filter-viz

Inside

Created in Emacs using Outshine, then exported from a literate org-mode file. Uses openssl hmac mode for hashes, imagemagic for the pngs, Optionally feh, ristretto and jumpapp for visualization.

Note

Please scan the code ahead of time and fill-in the path near the top of these scripts. You want output to go to ram or another temp-storage or things could get crowded.

Good Luck!

Send feedback if you survive your encounter with this code!

Releases

No releases published

Packages

No packages published

Languages