Welcome to Image Merger! A crate that provides blazing-fast functionality for merging many images. It is built on top of the image crate and works to boost performance by utilizing parallel processing and avoiding unnecessary costly operations.
A Merger paces many small images onto a larger canvas in a specific pattern/location. As of today, this library only has one type of Merger, a KnownSizeMerger
which focuses on performance as its top priority, but more will be added soon. An example of an output from a KnownSizeMerger
is below, this is the general output from the crate's tests.
data:image/s3,"s3://crabby-images/7e8aa/7e8aab1a893ed9708d05083b76b760f0f11fe689" alt=""
data:image/s3,"s3://crabby-images/5208c/5208cc95629e336879509208f0a84f0ba3f19521" alt=""
data:image/s3,"s3://crabby-images/80515/80515251728e1ea15c1e3c3e87a80764bd06020a" alt=""
Run the following Cargo command in your project directory:
cargo add image-merger
The disparity in merging 10,000 images of 100x100 pixels between the merger and a linear implementation is significant. As depicted below, the x-axis illustrates the number of images being merged, ranging from 1 to 10,000, while the y-axis indicates the duration in milliseconds it took to merge all the images. The linear implementation is shown in green and the image merger in orange.
data:image/s3,"s3://crabby-images/0473f/0473f34d500e40bba8cc866a69de0cde063c7aa0" alt=""
Over the 10,000 image interval, the image merger yielded an average 3.646x speed increase over the linear implementation. Effectively speaking, the combined average time, in ms, to generate a merged image with