World Library  
Flag as Inappropriate
Email this Article


Article Id: WHEBN0000172902
Reproduction Date:

Title: OpenEXR  
Author: World Heritage Encyclopedia
Language: English
Subject: ANIM, WebP, GIF, High Efficiency Video Coding tiers and levels, JPEG Network Graphics
Collection: Free Graphics Software, Graphics File Formats, High Dynamic Range File Formats, Open Formats
Publisher: World Heritage Encyclopedia


Filename extension .exr
Developed by Industrial Light and Magic
Initial release 1999 (1999)
Latest release
(10 August 2014 (2014-08-10))
Type of format High dynamic range imaging
Open format? Yes, Modified BSD License
Website .com.openexrwww

OpenEXR is a high dynamic range imaging image file format, released as an open standard along with a set of software tools created by Industrial Light and Magic (ILM), under a free software license similar to the BSD license.[1]

It is notable for supporting 16-bit-per-channel floating point values (half precision), with a sign bit, 5 bits of exponent, and a 10-bit significand. This allows a dynamic range of over 30 stops of exposure.

Both lossless and lossy compression of high dynamic range data is also supported.[2]


  • OpenEXR Overview 1
    • History 1.1
    • Compression methods 1.2
    • Credits 1.3
  • Developing with OpenEXR 2
  • References 3
  • External links 4

OpenEXR Overview

A full technical introduction of the format is available on the website.[2]

OpenEXR, or EXR for short, is a deep raster format developed by ILM and broadly used in the computer-graphics industry, both visual effects and animation.

OpenEXR's multi-resolution and arbitrary channel format makes it appealing for compositing, as it alleviates several painful elements of the process. Since it can store arbitrary channels—specular, diffuse, alpha, RGB, normals, and various other types—in one file, it takes away the need to store this information in separate files. The multi-channel concept also reduces the necessity to "bake" in the aforementioned data to the final image. If a compositer is not happy with the current level of specularity, he or she can adjust that specific channel.[3]

OpenEXR's API makes tools development a relative ease for developers. Since there are almost never two identical production pipelines, custom tools always need to be developed to address problems, e. g. image manipulation issue. OpenEXR's library allows quick and easy access to the image's attributes such as tiles and channels.[3]


OpenEXR was created by ILM in 1999 and released to the public in 2003 along with an open source software library.[4][5] It soon received wide adoption by software used in computer graphics, particularly for film and television production. The format has been updated several times, adding support for tiles, mipmaps, new compression methods, and other features.[5] In 2007, OpenEXR was honored with an Academy Award for Technical Achievement.[5]

OpenEXR 2.0 was released in April 2013, extending the format with support for deep image buffers and multiple images embedded in a single file.[5][6][7] Version 2.2, released August 2014, added the lossy DWA compression format.[8]

Compression methods

There are 3 general types of lossless compression built into OpenEXR, with two different methods of Zip compressing. For most images without a lot of grain, the two Zip compression methods seem to work best, while the PIZ compression algorithm is better suited to grainy images. The following options are available:

Disables all compression.
Run Length Encoding (RLE)
This is a basic form of compression that is comparable to that used by standard Targa files.
Zip (per scanline)
Zip style compression applied to individual scanlines.
Zip (16 scanline blocks)
Zip style compression applied to blocks of 16 scanlines at time. This tends to be the most effective style of compression to use with rendered images that do not have film grain applied.
PIZ (wavelet compression)
This uses a new combined wavelet / Huffman compression. This form of compression is quite effective when dealing with grainy images, and will often surpass any of the other options under grainy conditions.
PXR24 (24 bit data conversion then zipped compression)
This form of compression from Pixar converts data to 24 bit then uses Zip compression. It is lossless for half and 32bit integer data and slightly lossy for 32bit float data.
This form of compression is lossy for half data and stores 32bit data uncompressed.
An extension to B44 where areas of flat color are further compressed. Regular B44 compresses uniformly regardless of image content.
JPEG-like lossy compression format contributed by DreamWorks Animation. Compresses 32 scanlines together.[8]
Same as DWAA, but compresses blocks of 256 scanlines.


From's Technical Introduction:

The ILM OpenEXR file format was designed and implemented by Florian Kainz, Wojciech Jarosz, and Rod Bogart. The PIZ compression scheme is based on an algorithm by Christian Rouet. Josh Pines helped extend the PIZ algorithm for 16-bit and found optimizations for the float-to-half conversions. Drew Hess packaged and adapted ILM's internal source code for public release and maintains the OpenEXR software distribution. The PXR24 compression method is based on an algorithm written by Loren Carpenter at Pixar Animation Studios.[9]

Developing with OpenEXR

The OpenEXR library is developed in C++ and is available in source format as well as compiled format for Windows, Mac OS X and Linux. Python bindings for the library are also available.[10]

As of version 1.3.0, released on June 8, 2006, support for multithreaded reading and writing was added to OpenEXR. Multithreaded reading and writing offers a higher performance gain for systems that have multiple cores or CPUs. OpenEXR handles reading and writing by a means of a thread pool.


  1. ^ License, 
  2. ^ a b "Data Compression" (PDF), Technical introduction ( 
  3. ^ a b Kainz, Florian. "OpenEXR File Layout" (PDF).  
  4. ^ "Industrial Light & Magic Releases Proprietary Extended Dynamic Range Image File Format OpenEXR to Open Source Community" (PDF) (Press release). 22 January 2003. 
  5. ^ a b c d "Main OpenEXR web site". 
  6. ^ Stanczyk, Piotr (9 April 2013). "v2.0.0.0 (GM) release announcement". openexr-announce (Mailing list). 
  7. ^ "OpenEXR 2.0". The CGSoceity. 10 April 2013. 
  8. ^ a b "DreamWorks Animation Contributes Lossy Compression To OpenEXR 2.2" (Press release). Glendale, CA. 8 August 2014. Retrieved 2014-08-18. 
  9. ^ Florian Kainz, Rod Bogart , Piotr Stanczyk. "Technical Introduction to OpenEXR" (PDF). Industrial Light & Magic. Retrieved 7 December 2013. 
  10. ^

External links

  • exrtools incl. exrtoppm exe
This article was sourced from Creative Commons Attribution-ShareAlike License; additional terms may apply. World Heritage Encyclopedia content is assembled from numerous content providers, Open Access Publishing, and in compliance with The Fair Access to Science and Technology Research Act (FASTR), Wikimedia Foundation, Inc., Public Library of Science, The Encyclopedia of Life, Open Book Publishers (OBP), PubMed, U.S. National Library of Medicine, National Center for Biotechnology Information, U.S. National Library of Medicine, National Institutes of Health (NIH), U.S. Department of Health & Human Services, and, which sources content from all federal, state, local, tribal, and territorial government publication portals (.gov, .mil, .edu). Funding for and content contributors is made possible from the U.S. Congress, E-Government Act of 2002.
Crowd sourced content that is contributed to World Heritage Encyclopedia is peer reviewed and edited by our editorial staff to ensure quality scholarly research articles.
By using this site, you agree to the Terms of Use and Privacy Policy. World Heritage Encyclopedia™ is a registered trademark of the World Public Library Association, a non-profit organization.

Copyright © World Library Foundation. All rights reserved. eBooks from World eBook Library are sponsored by the World Library Foundation,
a 501c(4) Member's Support Non-Profit Organization, and is NOT affiliated with any governmental agency or department.