Page 1 of 1
convert is toooooo slow with many images
Posted: 2015-06-13T17:47:06-07:00
by saulortega
Hello.
Version: ImageMagick 6.6.9-7 2014-03-06 Q16
http://www.imagemagick.org
Copyright: Copyright (C) 1999-2011 ImageMagick Studio LLC
Features: OpenMP
I'm running this command:
Code: Select all
convert *.JPG -morph 2 -monitor -normalize mov/%05d.jpg
With 10 images, it takes
15 seconds. With 30 images, it takes
1 hour!.
With 10 images, it do not writes on disk. With 30 images (~1.2 MB) it writes 400 MB in temp disk. With 50 images 3 GB!
Why???!!!
Re: convert is toooooo slow with many images
Posted: 2015-06-13T18:51:22-07:00
by fmw42
You are reading every image into memory. That will slow things down. See
http://www.imagemagick.org/Usage/files/#massive for processing large image(s).
Re: convert is toooooo slow with many images
Posted: 2015-06-14T05:58:08-07:00
by saulortega
Code: Select all
However your system may reject large memory requests and still force IM to cache the image to disk (about 1000 times slower).
data:image/s3,"s3://crabby-images/4ac5a/4ac5a8366e9f952069e2a4b42fa26707c45914cf" alt="Shocked :shock:"
That explains it.
Is not there some way to tell IM not load all images in memory at once but in twos?
data:image/s3,"s3://crabby-images/904e0/904e0168ab918ee4c3574d031ad055e4bab3dd1e" alt="Smile :)"
Re: convert is toooooo slow with many images
Posted: 2015-06-14T06:29:29-07:00
by magick
You could write a shell script to call the convert utility for every two images. You might get some improvement by upgrading to the latest ImageMagick release @ 6.9.1-5. You might get some improvement by forcing all pixel access to disk (to prevent swap thrashing) by adding "-limit memory 2mb -limit map 2mb" to your command line. You might get some improvement by setting the MAGICK_TMPDIR environment variable to a partition other than /tmp, instead use /data/tmp, for example.
Re: convert is toooooo slow with many images
Posted: 2015-06-20T15:40:07-07:00
by saulortega
Well, I programmed my own script. Now I takes 1 hour processing 1000 images.
Re: convert is toooooo slow with many images
Posted: 2015-10-05T07:49:31-07:00
by Nemo_bis
Another experience: to create a PDF from 24 JPG files, convert eats 3 GiB RAM and 4 GiB swap, bringing the machine to swapdeath, and is eventually killed by Linux.
This makes sense given
viewtopic.php?f=1&t=28438&p=126258 says we need 8 bytes per pixel and these are 35 MPx images: 35*10**6*24*8/1024**3 = 6 GiB memory needed. And I'd need to convert ~300 such images, not just 24!
Changing the resource limits makes it die faster but not complete the job, it just can't take this much memory on my 8 GB RAM machine.
Code: Select all
$ identify -version
Version: ImageMagick 6.8.8-10 Q16 x86_64 2015-03-10 http://www.imagemagick.org
Copyright: Copyright (C) 1999-2014 ImageMagick Studio LLC
Features: DPC Modules OpenMP
Delegates: bzlib cairo djvu fftw fontconfig freetype gslib jng jpeg lcms ltdl lzma openexr pangocairo png ps rsvg tiff webp wmf x xml zlib
$ convert -list resource
File Area Memory Map Disk Thread Throttle Time
--------------------------------------------------------------------------------
38400 15.948GB 7.4266GiB 14.853GiB unlimited 2 0 unlimited
$ time convert 000*jpg output.fromjpeg75.pdf
Ucciso
real 7m23.713s
user 0m21.734s
sys 0m13.826s
$ time convert -limit memory 7GiB 000*jpg output.fromjpeg75.pdf
Ucciso
real 0m36.269s
user 0m22.991s
sys 0m10.424s
In contrast mogrify completes the job in a reasonable time, but then I have to merge the individual PDF files. As magick suggested in another thread about large collections of TIFF, I tried tiffcp + tiff2pdf instead and it's indeed way faster: 1 min instead of 4 for the same PDF.
Code: Select all
$ time mogrify -format jpg -quality 75 000*tif
real 1m46.553s
user 1m6.503s
sys 0m17.276s
$ time mogrify -format pdf 000*jpg
real 4m10.036s
user 3m19.764s
sys 0m23.655s
$ time tiffcp -c lzw 000*tif out.lzw.tiff
real 0m57.404s
user 0m35.480s
sys 0m4.750s
$ time tiff2pdf -o output.jpeg75.pdf -j -q 75 -u m -F out.lzw.tiff
real 0m55.016s
user 0m49.864s
sys 0m4.687s
$ time tiff2pdf -o output.lossless.pdf -z -u m -F out.lzw.tiff
real 4m15.793s
user 4m1.839s
sys 0m9.028s
Re: convert is toooooo slow with many images
Posted: 2015-10-05T15:44:32-07:00
by magick
Note, ImageMagick resource limits are enforced for ImageMagick, not its delegate libraries. We cannot control, for example, how much resources Ghostscript consumes or the JPEG library.