Which image metrics to use for selecting representative images from large image sets?
Posted: 2016-01-29T07:24:05-07:00
For example when selecting nice images for preview image montages of videos, movies (thumbnails, contact sheets, etc):
data:image/s3,"s3://crabby-images/60151/60151d4811b990d0147267d152ddd72058898315" alt="Image"
data:image/s3,"s3://crabby-images/a2798/a2798f6480d5d8e5e390d23b8c247a8b2a24a0b1" alt="Image"
data:image/s3,"s3://crabby-images/0b0a1/0b0a166b3922edc61a42d9fe7ac46ae2e14b97ea" alt="Image"
Currently I extract about 1500 images equidistantly from a 1.5 hour video, and I calculate the following metrics for every images.
entropy:
number of unique colours:
standard deviation:
canny edge detector metric:
and last but not least the jpeg file size in bytes.
Then I normalize all of those data series to the 0.0-1.0 interval, and finally I calculate their root mean square (RMS). I normalize the RMS values as well into the 0.0-1.0 interval. Then I simply sort the images in reverse order according to the calculated RMS value, and I select the needed number of images by hand from the first part of the list...
What other image metrics and selecting methods should I consider to automate this process even further, possibly fully automatic?
data:image/s3,"s3://crabby-images/354f3/354f38746c43cc66e90b81b9192b0e2c84099a19" alt="Image"
data:image/s3,"s3://crabby-images/60151/60151d4811b990d0147267d152ddd72058898315" alt="Image"
data:image/s3,"s3://crabby-images/a2798/a2798f6480d5d8e5e390d23b8c247a8b2a24a0b1" alt="Image"
data:image/s3,"s3://crabby-images/0b0a1/0b0a166b3922edc61a42d9fe7ac46ae2e14b97ea" alt="Image"
Currently I extract about 1500 images equidistantly from a 1.5 hour video, and I calculate the following metrics for every images.
entropy:
Code: Select all
identify -format "%[entropy]" 000001.jpg
Code: Select all
identify -format "%k" 000001.jpg
Code: Select all
convert 000001.jpg -format "%[fx:standard_deviation]" info:
Code: Select all
convert 000001.jpg -colorspace gray -canny 0x1+15%+40% -format "%[fx:mean]" info:
Then I normalize all of those data series to the 0.0-1.0 interval, and finally I calculate their root mean square (RMS). I normalize the RMS values as well into the 0.0-1.0 interval. Then I simply sort the images in reverse order according to the calculated RMS value, and I select the needed number of images by hand from the first part of the list...
What other image metrics and selecting methods should I consider to automate this process even further, possibly fully automatic?
data:image/s3,"s3://crabby-images/354f3/354f38746c43cc66e90b81b9192b0e2c84099a19" alt="Image"