brew install joedrago/repo/colorist
Note: If it doesn’t find a pre-compiled bottle, building from source takes a while (10+ minutes). I’ll try to keep bottles available for the most recent macOS releases.
Grab the latest executable from Releases and put it somewhere in your PATH.
Build from source
Clone or download a zip of the repo, then run CMake on the root directory and run the generated build.
To use codecs other than libaom (used with AVIF), you must enable the
AVIF_CODEC_* CMake variable, and to build locally, you must run
the appropriate .cmd file in
ext/avif/ext and then additionally enable the
AVIF_LOCAL_* CMake variable.
For a near-automated Linux or macOS build, simply run
requires Rust, CMake, Ninja, NASM, Meson, and Git, but should build
libavif), link them into colorist. Read the contents of
build.sh and the .cmd files inside of
ext/avif/ext to see exactly what
commands will be run.
Overview & Explanation
Colorist is an image file and ICC profile converter, generator, and identifier. Why make such a tool when the venerable ImageMagick already exists and seems to offer every possible image processing tool you can imagine? The answer is absolute luminance.
(Also, making tools is great fun.)
Since the dawn of computer rendering, luminance (brightness) has always been relative.** Values of 0 in a pixel have always meant “emit no light / as little light as possible”, and max values in a pixel (255 in 8-bit, etc) meant “as bright as possible”. We’ve gotten by just fine for a while with this strategy, but times are changing. For example, the HDR10 standard (BT.2100) and Dolby Vision have defined a luminance range of 0-10,000 nits. We no longer can assume that the author of an image containing max-channel white pixels intended to burn your retinas out of your head. We need more information!
** Hasn’t it?
This means somewhere in the image file we must store our intended max luminance such that renderers know how much to scale it when rendering (depending on the output’s max luminance). But where to store it? It turns out there is already a place available in any image file format that can embed an ICC profile: an ICC profile’s lumi tag. The explanation in the ICC spec for the lumi tag is:
This tag contains the absolute luminance of emissive devices in candelas per square metre as described by the Y channel.
Sounds perfect, no? Unfortunately, while ICC profile viewers and editors will happily manipulate this tag and standard ICC profiles occasionally include the tag for completeness, no image manipulation tool to date actually honors the value during conversion or rendering. Until now!
The goal of this tool is to be a one-stop shop for manipulating/abusing ICC profiles and image file formats (with respect to absolute luminance). By leveraging the fantastic LittleCMS library, choosing interesting tone curves and max luminance, and injecting my own scaling and tonemapping steps into the pipeline, I hope to maintain as much of the original image’s fidelity when converting to other color profiles or file formats that can’t handle larger bit depth or are excessively lossy.
Any files created/generated via this tool will still be fully standards compliant, it will simply have a slightly more interesting color profile embedded that you can choose to parse in your own engines and scale that luminance down accordingly. If the output of this tool isn’t to your satisfaction, ImageMagick is better in pretty much every other way. I highly recommend it!
Released under the Boost Software License (Version 1.0).