Image formats: Performance Testing: Test 1
Gregor Mosheh
gregor at HOSTGIS.COM
Sat Sep 1 11:20:43 PDT 2007
A customer asked me to do some tests on TIFF, JPEG2000, and ECW, and
rate their relative merits in terms of disk usage, performance/speed,
and image quality.
I can't say that the results are surprising, but at least I have some
procedures and empirical numbers to back it up. For the impatient ones,
skip to the Results section at the end. :)
I will be repeating this with larger files, as well as testing the
effects of overviews and internal tiling, on my own time. This test of
200 MB files was intended to represent the customer's typical use case.
*** DATA AND SETUP
The dataset used for this test is infrared false-color imagery of
Eureka, California.
The pixel size of the data is 10684x6983 pixels.
The spatial extent of the data is:
-124.1987173 40.7379805 -124.0836036 40.8132182
The original TIFF was reprojected from UTM to geographic using gdalwarp.
It was then converted using gdal_translate to generate the ECW and
JPEG2000 versions.
As such, all images are identical data and all are in the same projection.
A mapfile was created listing three layers, named ECW, TIFF, and
JPEG2000, each reading from the corresponding data source.
*** TESTING
I chose to use the shp2img program, rather than web-based rendering
using OpenLayers or Mapscript, in order to eliminate many of the
variables associated with timing, e.g. network lag and delays within the
client.
I chose PNG-24 as the output format since this is what we ually use, for
its combination of quality and color fdelity
The commands, runtimes, and URLs of the resulting images are as follows:
shp2img -m mapfile.map -l TIFF -o tiff-fullview.png
Time: 0.725s
https://www.cartograph.com/~gregor/formats/tiff-fullview.png
shp2img -m mapfile.map -l ECW -o ecw-fullview.png
Time: 3.069s
https://www.cartograph.com/~gregor/formats/ecw-fullview.png
shp2img -m mapfile.map -l JPEG2000 -o jpeg-fullview.png
Time: 6.071s
https://www.cartograph.com/~gregor/formats/jpeg-fullview.png
shp2img -m mapfile.map -l TIFF -e -124.1987173 40.7379805 -124.14116045
40.77559935 -o tiff-quad.png
Time: 0.833s
https://www.cartograph.com/~gregor/formats/tiff-quad.png
shp2img -m mapfile.map -l ECW -e -124.1987173 40.7379805 -124.14116045
40.77559935 -o ecw-quad.png
Time: 3.070s
https://www.cartograph.com/~gregor/formats/ecw-quad.png
shp2img -m mapfile.map -l JPEG2000 -e -124.1987173 40.7379805
-124.14116045 40.77559935 -o jpeg-quad.png
Time: 9.073s
https://www.cartograph.com/~gregor/formats/jpeg-quad.png
*** RESULTS
Storage space:
TIFF: 213 MB, ECW: 60 MB, JPEG2000: 87 MB
Both ECW and JPEG offered sustantial reductions in storage space
requirements, ECW best of all.
Rendering speed:
TIFF was the fastest to render, while ECW was significantly slower.
JPEG2000 was very slow. When seeking a subset of the data, these results
continued, though JPEG2000 showed a very significant slowdown on this
very common task.
Image quality:
The original photo had a grainy quality to it. Although unattractive to
the eye, these grains do represent fine-detail data, useful for
analyzing the loss of such quality.
As expected, TIFF retained all of the fine detail. ECW also showed high
fidelity to the original image. JPEG2000 showed the most loss of the
grainy detail, although in this case it did make for a "smoothing"
effect which was not unattractive.
*** CONCLUSION
ECW and JPEG2000 both provide very good compression, resulting in a 65%
reduction in storage requirements.
Both ECW and JPEG2000 showed some loss of image quality, but the results
are quite acceptable considering the reduction in storage space.
At the file sizes which we typically use (up to 300 MB TIFFs), both ECW
and JPEG2000 are probably too slow for our needs. With very large TIFFs,
the disk access can often outweight the CPU speed and cause TIFF to be
slower than other formats, but in the 200 MB size range, this is not the
case.
More information about the MapServer-users
mailing list