data:image/s3,"s3://crabby-images/945e5/945e541913552c0a975363dff38c6fbb56cb0d20" alt="Logo"
iq - a little tool for image manipulation
Inspired by `jq`, iq is an experimental tool for manipulating images through expressions which transform pixels.
Usage
iq 0.1.0
[email protected]
USAGE:
iq [OPTIONS] [ARGS]
ARGS:
<input_path> The path to the input image
<output_path> Where to write the output image
OPTIONS:
-b, --blank <dimensions> Use a blank canvas of provided size 'HxW' (ex. '100x300')
-e, --expr <expressions> The expressions to evaluate
-f, --file <file> Pass a file containing expressions to run
-h, --help Print help information
-V, --version Print version information
Examples
Disclaimer: The tool is a work in progress and in its very early stages. There are certainly bugs and plenty of things to improve.
iq
is passed an image and a set of expressions and produces an output image. For example:
iq -e "_ => p(_.y, _.x, _.r, 0, 0)" assets/dalle_logo.png out.jpg
Would produce an output image out.jpg
with the green and blue color channels removed.
data:image/s3,"s3://crabby-images/5f79f/5f79f6abc015e10e0c115fdb6e16c5fcfdfa0a57" alt="Logo"
Slice Ranges
Expressions can do much more complex actions than simply uniformly changing colors. For example given this DALLE generated image of Philip Seymour Hoffman in the Disney film "Cars":
data:image/s3,"s3://crabby-images/881d7/881d7b5ceb13f0b48177d3e9218e7ce076e8f9d9" alt="Logo"
We can crop patches of the image using "slice ranges":
# Crop out a circle and replace the outside with a gradient
iq -e "[0:100, 0:100]" \
assets/examples/dalle_philip_seymour_in_cars_movie.jpg \
cropped_seymour.jpg
data:image/s3,"s3://crabby-images/cb239/cb2399fa378d7c3e65590b860aadf8486fad71d7" alt="Logo"
Match Expressions
We can use match expressions to apply other expressions conditionally
# Change any pixel with a green channel value greater than 128 to white
iq -e "_.g > 128 => p(_.y, _.x, 255, 255, 255) : _" \
assets/examples/dalle_philip_seymour_in_cars_movie.jpg \
highlight_mcqueen.jpg
data:image/s3,"s3://crabby-images/c8111/c8111a99fb66ff4db8bdd1f8d9b6af9c1c35c6f1" alt="Logo"
# Crop out a circle and replace the outside with a gradient
iq -e "
([].w/2) >= sqrt(sq(_.x - center().x) + sq(_.y - center().y)) =>
p(_.y, _.x, _.r, 255 - _.r, _.r) :
p(_.y, _.x, (_.r * _.y) / [].h, (_.g * _.x) / [].w, 0)
" \
assets/examples/dalle_philip_seymour_in_cars_movie.jpg \
circle_seymour.jpg
data:image/s3,"s3://crabby-images/d5232/d5232778dcab604971cd5bcd18fb4f472e52c87e" alt="Logo"
Layering
If we provide more than one expression separated by semicolons they will be alpha composited together. For example consider this DALLE generated bottle of ranch testifying in court;
data:image/s3,"s3://crabby-images/0b6d9/0b6d9d2a0653333bb1d255523ae29ea4ab03d31c" alt="Logo"
# Superimpose a rotated version on the original;
iq -e "
_ => p(_.y, _.x, _.r, _.g, _.b, _.a * 0.5);
_ => p(_.x, _.y, _.r, _.g, _.b, _.a * 0.5);
" \
assets/examples/dalle_ranch_testifying_in_court.jpg \
rotate.jpg
data:image/s3,"s3://crabby-images/c1346/c13460dbcbf5674dd2b9ad88db6d94cc242d6265" alt="Logo"
Pixel Functions
There are a few builtin pixel functions like:
color_norm
color_add
color_scale
neighbors
That when combined with other standard features can even do some convolutions like this sobel edge detection:
# Crop into a circle and do sobel edge detection
iq -e "
([].w/2) >= sqrt(sq(_.x - center().x) + sq(_.y - center().y)) => color_norm(color_add(
color_scale(neighbors(_, -1, -1), -1.0),
color_scale(neighbors(_, 0, -1), -2.0),
color_scale(neighbors(_, 1, -1), -1.0),
color_scale(neighbors(_, 1, -1), 1.0),
color_scale(neighbors(_, 1, 0), 2.0),
color_scale(neighbors(_, 1, 1), 1.0)
));
" \
assets/examples/dalle_ranch_testifying_in_court.jpg \
circle_edge_ranch.jpg
data:image/s3,"s3://crabby-images/ab0ac/ab0ac77e93309b83fedb5ca5f8ef68704c300956" alt="Logo"
Language Reference
Coming soon...
How it works
iq
is written in rust
and uses LALRPOP for parser/lexer generation.
Installation
Right now the tool is only distributed as source. Clone the repo and do a standard cargo build
Contributing
All contributions are welcome!
License
Distributed under the MIT License. See LICENSE.txt
for more information.