- Floyd-Steinberg dithering
- Bill Atkinson dithering
- Jarvis-Judice-Ninke dithering
- Sierra 2-4a dithering
- Stucki dithering
- Burkes dithering
- Sierra2 dithering
- Sierra3 dithering
For each algorithm, I wrote a 2-dimensional convolution function (a matrix passing over a matrix); it is slow because I didn't implemented any fasting tricks. It can be easily implemented in C, then used in R for a faster solution.
Then, a function to transform a grey image in a grey-dithered image is provided, with an example. The library rimage was used for loading and displaying images (see the other post R is a cool image editor).
These function can be easily re-coded for a RGB image.
Only the first code is commented, 'cause they're all very similar.
library(rimage)
y <- read.jpeg("valve.jpg")
plot(y)
data:image/s3,"s3://crabby-images/0b15b/0b15bfb52af3c3bd8188081f8d91488d29fb405c" alt=""
plot(normalize(grey2FSdith(rgb2grey(y))))
data:image/s3,"s3://crabby-images/85440/85440d203dc0ce9cec929ce4e8ceca83b9684f66" alt=""
plot(normalize(grey2ATKdith(rgb2grey(y))))
data:image/s3,"s3://crabby-images/935f3/935f375f66db4dc84df62e8470a80ab14ef7d655" alt=""
plot(normalize(grey2JJNdith(rgb2grey(y))))
data:image/s3,"s3://crabby-images/bdf34/bdf34e4c5f61e9d3b740dfbf07504066fc411a5f" alt=""
plot(normalize(grey2S24adith(rgb2grey(y))))
data:image/s3,"s3://crabby-images/40728/40728709d800d255c4d24727f5f0458c7fcafba8" alt=""
plot(normalize(grey2Stucki(rgb2grey(y))))
data:image/s3,"s3://crabby-images/801b6/801b6544ff598ce3172c8df23804bad7c2285f7c" alt=""
plot(normalize(grey2Burkes(rgb2grey(y))))
data:image/s3,"s3://crabby-images/ff481/ff4813f91dc320e119ad6a39356a204866503b84" alt=""
plot(normalize(grey2Sierra2(rgb2grey(y))))
data:image/s3,"s3://crabby-images/d4080/d4080eabac3651fead9e826a82f33cf94dcbdc85" alt=""
plot(normalize(grey2Sierra3(rgb2grey(y))))
data:image/s3,"s3://crabby-images/89465/89465db0f3ce51900b9d2be77501867a0c950e5d" alt=""
No comments:
Post a Comment