data:image/s3,"s3://crabby-images/3ce59/3ce59e96e431e8b43b466c101ae69f808bee8007" alt="SciCloj logo"
This is part of the Scicloj Clojure Data Scrapbook. |
Clay & Noj demo: image processing
ns index
(:require [tech.v3.libs.buffered-image :as bufimg]
(:as dtype]
[tech.v3.datatype :as tensor]
[tech.v3.tensor :as fun]
[tech.v3.datatype.functional :as kind])) [scicloj.kindly.v4.kind
:style "img {max-width: 100%}"]) (kind/hiccup [
:youtube-id "fd4kjlws6Ts"}) (kind/video {
Arithmetic
+ 1 2) (
3
Loading data
defonce raw-image
(
(bufimg/load"https://upload.wikimedia.org/wikipedia/commons/1/1e/Gay_head_cliffs_MV.JPG"))
type raw-image) (
java.awt.image.BufferedImage
(bufimg/image-type raw-image)
:byte-bgr
Displaying images
raw-image
data:image/s3,"s3://crabby-images/002b3/002b3abbc318b2ea7ecead662ae54ef625ca7000" alt=""
Tensors
defonce raw-tensor
(-> raw-image
( bufimg/as-ubyte-tensor))
(dtype/shape raw-tensor)
1478 2006 3] [
Processing
(kind/fragment
[raw-image-> raw-tensor
(0.5)
(fun/* :byte-bgr))]) (bufimg/tensor->image
data:image/s3,"s3://crabby-images/002b3/002b3abbc318b2ea7ecead662ae54ef625ca7000" alt=""
data:image/s3,"s3://crabby-images/eb0f6/eb0f626512e0f4b6a7eac566a81cb14576a22986" alt=""
Hiccup
(kind/hiccup:div
[:h3 "raw image"]
[
raw-image:h3 "darkened image"]
[-> raw-tensor
(0.5)
(fun/* :byte-bgr))]) (bufimg/tensor->image
raw image
data:image/s3,"s3://crabby-images/002b3/002b3abbc318b2ea7ecead662ae54ef625ca7000" alt=""
darkened image
data:image/s3,"s3://crabby-images/9d214/9d2140d89b9c3f781b5a0b1d00d682343b91dcf1" alt=""
Colour channels
def colour-channels
(-> raw-tensor
(1))) (tensor/slice-right
def blue (colour-channels 0)) (
def green (colour-channels 1)) (
def red (colour-channels 2)) (
count colour-channels) (
3
mapv dtype/shape colour-channels) (
1478 2006] [1478 2006] [1478 2006]] [[
-> (tensor/compute-tensor (dtype/shape raw-tensor)
(fn [i j k]
(if (= k 2)
(
(raw-tensor i j k)0))
:uint8)
:byte-bgr)) (bufimg/tensor->image
data:image/s3,"s3://crabby-images/70fd1/70fd158c6a649d966eb39d182ac8e7355a28387a" alt=""
Conditioned processing
-> (tensor/compute-tensor (dtype/shape raw-tensor)
(fn [i j k]
(*
(
(raw-tensor i j k)if (> (green i j)
(
(blue i j))0.3
1)))
:uint8)
:byte-bgr)) (bufimg/tensor->image
data:image/s3,"s3://crabby-images/49dd2/49dd2c573fdcebd1d63716e09e7b17cd4fa19ff1" alt=""
-> (tensor/compute-tensor (dtype/shape raw-tensor)
(fn [i j k]
(*
(
(raw-tensor i j k)if (> (green i j)
(* 1.2 (blue i j)))
(0.3
1)))
:uint8)
:byte-bgr)) (bufimg/tensor->image
data:image/s3,"s3://crabby-images/79000/7900034f7dbcd78d057ab17e27660f038e97f25e" alt=""
->> [0.7 0.8 0.9 1 1.1 1.2 1.3]
(map (fn [factor]
(
[factor-> (tensor/compute-tensor (dtype/shape raw-tensor)
(fn [i j k]
(*
(
(raw-tensor i j k)if (> (green i j)
(* factor (blue i j)))
(0.3
1)))
:uint8)
:byte-bgr))]))) (bufimg/tensor->image
(
[
0.7
data:image/s3,"s3://crabby-images/216a0/216a078870dde5891af228908c208626ca9698fb" alt=""
]
[
0.8
data:image/s3,"s3://crabby-images/d0369/d0369a6106fd322b88b3c2dd88d168c0b5b2b1fb" alt=""
]
[
0.9
data:image/s3,"s3://crabby-images/20b4a/20b4ad808a5586d58ebb949b3cf2c25bde6f21dd" alt=""
]
[
1
data:image/s3,"s3://crabby-images/37f79/37f79c47761d634d8c52c773828d8a2530bd9379" alt=""
]
[
1.1
data:image/s3,"s3://crabby-images/80410/804109f3142d0720bee8ed3d87d64671fb1a562b" alt=""
]
[
1.2
data:image/s3,"s3://crabby-images/6bfa5/6bfa5a9a438adcdda1291d71e91848d2ea567ab7" alt=""
]
[
1.3
data:image/s3,"s3://crabby-images/c6dbe/c6dbe95228c2089e4266fdaaa5a27a931cf760ac" alt=""
]
)