Go Quantise
Overview
Library to quantise images using algorithms from Virmajoki, O., & Franti, P. (2003). Multilevel thresholding by fast PNN-based algorithm. Image Processing: Algorithms and Systems II. doi:10.1117/12.477741
Install
go get github.com/fiwippi/go-quantise/pkg/quantisers
go mod tidy
Usage
Errors ignored for brevity
// Read in an image
reader, _ := os.Open("fish.jpg")
img, _, _ := image.Decode(reader)
// Quantise the image with PNN
colours := pnn.QuantiseColour(img, 10)
quantisedImg, _ := quantisers.ImageFromPalette(img, colours, quantisers.NoDither)
paletteImg := quantisers.ColourPaletteImage(colours, 200)
// Save the recreated image
savedImg, _ := os.Create("fish-quantised.jpg")
png.Encode(savedImg, quantisedImg)
// Save the colour palette image
savedImg, _ = os.Create("fish-palette.jpg")
png.Encode(savedImg, paletteImg)
Result
data:image/s3,"s3://crabby-images/cc4fe/cc4febd23e23119eee34d9aefa57004c9d1cff8c" alt="input"
Output
Raw
data:image/s3,"s3://crabby-images/f5142/f51429cc115f74426fa0f74e27cc18993f402b94" alt="output"
Dithered (Floyd-Steinberg)
data:image/s3,"s3://crabby-images/be717/be717bae2b8f8c560b16a71bbcb4c2973810fe7b" alt="output-dithered"
Palette
data:image/s3,"s3://crabby-images/1bff5/1bff5ccbc5f0496c35dd29df261015fc74500eb8" alt="output palette"
Notes
The quantisation algorithms implemented from the paper are:
- FastOtsu
- Lloyd Max Quantiser (LMQ)
- PNN (In RGB and LAB space)
Available dithering algorithms are:
- Floyd-Steinberg
- Floyd-Steinberg Serpentine
- Bayer 2x2 Matrix
- Bayer 4x4 Matrix
- Bayer 8x8 Matrix
Due to limitations of each algorithm:
- Otsu only supports greyscale quantisation with
m = 1
- LMQ only supports greyscale quantisation
- Images with
m = 1
do not dither.
Sections of this code are adapted from Miller Chan's code found here.
A big thank you to him for his help in explaining sections of it.
License
MIT