28 releases
0.11.2 | Oct 10, 2024 |
---|---|
0.11.0 | Sep 6, 2024 |
0.10.1 | May 14, 2024 |
0.10.0 | Mar 15, 2024 |
0.8.3 | Jul 31, 2023 |
#105 in Images
445 downloads per month
Used in oculante
4MB
1K
SLoC
lutgen-rs
A blazingly fast interpolated LUT utility for arbitrary and popular color palettes. Theme any image to your desktop colorscheme!
Example Output
Hald Cluts
Catppuccin Mocha
data:image/s3,"s3://crabby-images/4a761/4a761f122fe7ad0c96c0ade6c43c581cd241e0b7" alt=""
Gruvbox Dark
data:image/s3,"s3://crabby-images/3e08f/3e08fa739459327109e442dd7399a9c9830a5829" alt=""
Nord
data:image/s3,"s3://crabby-images/4f8b1/4f8b19fb195f2665adff2012fd141a118efe1590" alt=""
Color Corrections
Original Image
data:image/s3,"s3://crabby-images/b1ebc/b1ebc6d9ae34438b1d53c7af443288356578d00f" alt=""
Catppuccin Mocha
data:image/s3,"s3://crabby-images/d5d55/d5d5558481da3f2013d616c6b4a1646d93062921" alt=""
Gruvbox Dark
data:image/s3,"s3://crabby-images/3e13c/3e13c0b42c751918a7113a555d5e7be7c4800ca9" alt=""
Nord
data:image/s3,"s3://crabby-images/a0940/a09409154cd2229f6223476e47a7e1ba9c9e95a3" alt=""
CLI
Installation
Source
git clone https://github.com/ozwaldorf/lutgen-rs
cd lutgen-rs
cargo install --path .
Nix flake
A nix flake is available and can be run easily with:
nix run github:ozwaldorf/lutgen-rs
Cache is provided via https://garnix.io
Documentation
Detailed cli documentation is available at docs/README.md.
Examples
Correcting an image
# Builtin palette
lutgen apply -p catppuccin-mocha docs/example-image.jpg -o mocha_version.jpg
# Custom colors
lutgen apply docs/example-image.jpg -- "#ABCDEF" ffffff 000000
# Custom palette file with whitespace separated hex colors (linux example shown)
echo "fff 555 000 abcdef deadbe" > ~/.config/lutgen/my-palette-name
lutgen apply docs/example-image.jpg -p my-palette-name
# Multiple images
lutgen apply image1.png image2.png *.jpg -p catppuccin-mocha
# Using an external LUT
lutgen apply --hald-clut mocha_lut.png docs/example-image.jpg
Generating a standalone LUT for external or manual usage
# Builtin palette
lutgen generate -p catppuccin-mocha -o mocha_lut.png
# Custom colors
lutgen generate -o custom.png -- "#ABCDEF" ffffff 000000
# Custom palette file with whitespace separated hex colors (linux example shown)
echo "fff 555 000 abcdef deadbe" > ~/.config/lutgen/my-palette-name
lutgen generate -p my-palette-name
Preview palletes
# Preview all palettes
lutgen palette all
# Copy a palette to the custom palette dir for modifying and overriding
lutgen palette carburetor > ~/.config/lutgen/carburetor
# Finding a palette name with grep
lutgen palette names | grep 'gruvbox'
Correcting videos (using ffmpeg):
ffmpeg -i input.mkv -i hald_clut.png -filter_complex '[0][1] haldclut' output.mp4
Zsh Completions:
lutgen --bpaf-complete-style-zsh > _lutgen
sudo mv _lutgen /usr/local/share/zsh/site-functions/
Library
See the latest documentation on docs.rs
Planned features
- Interpolation for more accuracy when correcting with low level luts (<16)
- Hardware acceleration for applying luts to images
Sources
- Hald Cluts: https://www.quelsolaar.com/technology/clut.html
- Editing with Hald Cluts: https://im.snibgo.com/edithald.htm
- Sparse Hald Cluts: https://im.snibgo.com/sphaldcl.htm
- RBF Interpolation: https://en.wikipedia.org/wiki/Radial_basis_function_interpolation
- Shepard's method: https://en.wikipedia.org/wiki/Inverse_distance_weighting
- Oklab Colorspace: https://bottosson.github.io/posts/oklab/
Special Thanks
- Stonks3141 for maintaining the Alpine Linux package
- All the nixpkgs maintainers
Dependencies
~7–37MB
~492K SLoC