The ACES project home page is here:
The latest documentation on the ACES transforms and specifications can be found here:
Colorspaces in this configurations are grouped into the following families: ACES, ADX, Look, Output, Input, Utility, Aliases. Descriptions for the colorspaces in the different families are provided below.
For ease of use across a broader number of applications, the family name of each colorspace is pre-prended to the colorspace name when the configuration is authored. Those prefixes will be omitted in this document, but will show up when the configuration is loaded and used.
- ACES2065-1
- ACEScc
- ACESproxy
- ACEScg
Colorspaces and transforms representing the core ACES working and interchange colorspaces.
Transforms generated based on the ACES CTL Transforms
- ADX10
- ADX16
Colorspaces and transforms representing the ACES ADX spaces used for film scanning and printing.
- Transforms generated based on the ACES CTL Transforms
- Alex Fry's ACES 0.7.1 OCIO config was also a valuable resource.
- ACES 1.0 to 0.1 emulation
- ACES 1.0 to 0.2 emulation
- ACES 1.0 to 0.7 emulation
Colorspaces and transforms emulating the look of the ACES 0.1, 0.2 and 0.7 release.
- Should be applied to data in the ACES2065-1 colorspace.
- Should be used before an ACES Output Transform.
Transforms generated based on the ACES CTL Transforms
- sRGB (D60 sim.)
- Rec.709
- Rec.709 (D60 sim.)
- Rec.2020
- Rec.2020 ST2048 (1000 nits)
- DCDM (P3 gamut clip)
- DCDM
- P3-D60 ST2048 (1000 nits)
- P3-D60 ST2048 (2000 nits)
- P3-D60 ST2048 (4000 nits)
- P3-D60
- P3-DCI
Colorspaces and transforms implementing the ACES Output Transforms. These colorspaces produce code values ready for display on hardware devices calibrated to the standard used to name the colorspace.
- Transforms generated based on the ACES CTL Transforms
- All transforms produce full-range output. Host applications should be used to apply an full-to-legal scaling needed.
There are a variety of Input Transforms covering different cameras manufacturers, gamuts, transfer functions and camera settings. See below for specifics.
Colorspaces and transforms that implement the ACES Input Transforms. These colorspaces are used to convert from camera-specific formats and encodings to ACES.
References and descriptions are provided for each group of Input Transforms below.
- The colorspaces whose names include a transfer function and a gamut name are full implementations of ACES Input Transforms.
- Ex. The ARRI 'V3 LogC (EI160) - Wide Gamut' colorspace
- Ex. The RED 'REDlogFilm - DRAGONcolor2' colorspace
- Ex. The Canon 'Canon-Log - DCI-P3 Daylight' colorspace
- The colorspaces that start with 'Linear - ' will convert to or from a specific gamut but not apply a transfer function.
- The colorspaces that start with 'Curve - ' will apply a transfer function but not convert between gamuts.
- ARRI Input Transforms
- Conversations with Joseph Goldstone of ARRI
- Canon ACES landing page
- Clog white paper
- C500 Drivers and Software
- C300 Drivers and Software
- Choose OSX Mountain Lion v10.8 to download the IDTs
- C100 Drivers and Software
- Choose OSX Mountain Lion v10.8 to download the IDTs
- Understanding REDlogFilm and REDgamma
- Conversations with Graeme Nattress of RED
- The quality and consistency of these transforms has not been verified.
- Conversations with David Newman of GoPro
A collection of colorspaces that are used to facilitate the creation of LUTs and other basic functionality.
- The 'Log2 xx nits Shaper' and 'Dolby PQ xx nits Shaper' spaces cover the linear range centered around 18% grey. The 48 nits spaces cover -6.5 stops (0.0028125) to +6.5 stops(16.291740). The 1000 nits spaces cover -12 stops to +10 stops. The 2000 nits spaces cover -12 stops to +11 stops. The 4000 nits spaces cover -12 stops to +12 stops.
- The LMT shaper spaces cover the linear range going from 10 stops below 18% grey (0.00017578125) to 6.5 stops above 18% grey (16.291740)
- The colorspaces starting with 'Linear - ' will convert to or from a specific gamut but not apply a transfer function.
- The colorspaces starting with 'Curve - ' will apply a transfer function but not convert between gamuts.
The role colorspaces are aliases to the colorspaces used for the OCIO 'roles' functionality.
The alias colorspaces are named with all lower-case letters and no spaces, dashes, parentheses or other characters that would not work well in a filename. They are only references, aliases for the base colorspaces with more user-friendly names. These spaces were added to enable OCIO's token-based colorspace / filename matching.
- These colorspaces should not generally be used by most artists.
The standard OCIO roles are defined. They role assignments are:
- color_picking: Output - Rec.709
- color_timing: ACEScc
- compositing_log: ACEScc
- data: Raw
- default: ACES2065-1
- matte_paint: ACEScc
- reference: Raw
- scene_linear: ACEScg
- texture_paint: Raw
Additionally, a number of colorspaces that are gaining wider adoption have been added to the config. Their names and assignment are:
- compositing_linear: ACEScg
- rendering: ACEScg
The default config has one Display named ACES, which contains the following Views / colorspaces:
- sRGB D60 sim., colorspace: sRGB (D60 sim.)
- DCDM, colorspace: DCDM
- DCDM P3 gamut clip, colorspace: DCDM (P3 gamut clip)
- P3-D60, colorspace: P3-D60
- P3-D60 PQ 1000 nits, colorspace: P3-D60 PQ (1000 nits)
- P3-D60 PQ 2000 nits, colorspace: P3-D60 PQ (2000 nits)
- P3-D60 PQ 4000 nits, colorspace: P3-D60 PQ (4000 nits)
- P3-DCI, colorspace: P3-DCI
- Rec.2020, colorspace: Rec.2020
- Rec.2020 ST2048 1000 nits, colorspace: Rec.2020 ST2048 (1000 nits)
- Rec.709, colorspace: Rec.709
- Rec.709 D60 sim., colorspace: Rec.709 (D60 sim.)
- Raw, colorspace: Raw
- Log, colorspace: ACEScc
Considerations for custom config generation:
- The choice of a single Display and many Views may not align well with the implementation of OCIO in an application.
- If you would like to generate a config that contains multiple Displays, with a small number of Views for each, review the config generation script's '--createMultipleDisplays' option.
- If a Look is added to the config, a new set of Views will be added, one for each of the Views listed above except Raw and Log, that includes the Look. The Views with Looks will be interleaved in the View list with the original Views.
- To add a custom Look to the config, review the config generation script's '--addACESLookLUT', '--addACESLookCDL', '--addCustomLookLUT' and '--addCustomLookCDL' optoins.
The default resolution is 64x64x64 for the 3D LUTs and 4096 for the 1D LUTs.
The LUTs used internally by OCIO can be can be retrieved from the repository here.
LUTs that can be used outside of OCIO are included in the 'baked' directory here.
- The LUTs encode the ACES Output Transform for a specific colorspace input and are generally named:
- 'Ouput Transform name' for 'Input colorspace name'.extension
- Ex. 'sRGB (D60 sim.) for ACEScc.icc'
The LUTs included in the 'baked' directory cover the following formats and applications:
- .3dl for Autodesk Flame
- .3dl for Autodesk Lustre
- .lut for SideFX Houdini
- .csp for Autodesk Maya
- .icc for Adobe Photoshop
Configurations can be generated by the following Python package: aces_1.0.1/python
Usage is described on the command line and in the package root __init__.py file.
Features exposed for customization by the user include:
- The resolution of 1D and 3D LUTs
- Inclusion of custom Looks
- Two modes of creating the list of OCIO Displays and Views
- Selection of shaper function: Log2 or Dolby PQ
The configuration depends on the ACES 1.0.1 + Hotfixes CTL. The release contains a number of minor bug fixes and small additions in the utilities folder but is otherwise the same as the master ACES 1.0.1 release.
The CTL is available here:
Clone this repo using the following command:
- git clone --branch hotfixes https://github.com/ampas/aces-dev.git
The Python configuration generation package depends on the following libraries:
- OpenImageIO: http://openimageio.org
- Detailed build instructions can be found here: OpenImageIO Build Instructions
- OpenColorIO: http://opencolorio.org
- Detailed build instructions can be found here: OpenColorIO Build Instructions
- CTL: https://github.com/ampas/CTL
Use the following commands to build these packages on Mac OSX
- OpenColorIO
- brew install -vd opencolorio --with-python
- Update the homebrew repository of install scripts to make sure that OpenImageIO is included.
- brew tap homebrew/science
- Optional Dependencies for OpenImageIO
- brew install -vd libRaw
- brew install -vd OpenCV
- OpenImageIO
- brew install -vd openimageio --with-python
- CTL
- brew install -vd CTL
- OpenColorIO, a second time. ociolutimage will build with openimageio installed.
- brew uninstall -vd opencolorio
- brew install -vd opencolorio --with-python
The script used to generate these transforms and the transforms themselves were the product of work and conversations with a number of people. Thanks go to:
- Steve Agland
- Joe Bogacz
- Jack Binks
- Scott Dyer
- Alex Fry
- Alex Forsythe
- Joseph Goldstone
- Stephen Hill
- Jim Houston
- Thomas Mansencal
- Robert Molholm
- Nikola Milosevic
- Will McCown
- Graeme Nattress
- David Newman
- Sam Richards
- Erik Strauss
- Doug Walker
- Kevin Wheatley
The original author of this OCIO config is:
- Haarm-Pieter Duiker
Academy Color Encoding System (ACES) software and tools are provided by the Academy under the following terms and conditions: A worldwide, royalty-free, non-exclusive right to copy, modify, create derivatives, and use, in source and binary forms, is hereby granted, subject to acceptance of this license.
Copyright 2014-2021 Academy of Motion Picture Arts and Sciences (A.M.P.A.S.). Portions contributed by others as indicated. All rights reserved.
Performance of any of the aforementioned acts indicates acceptance to be bound by the following terms and conditions:
-
Copies of source code, in whole or in part, must retain the above copyright notice, this list of conditions and the Disclaimer of Warranty.
-
Use in binary form must retain the above copyright notice, this list of conditions and the Disclaimer of Warranty in the documentation and/or other materials provided with the distribution.
-
Nothing in this license shall be deemed to grant any rights to trademarks, copyrights, patents, trade secrets or any other intellectual property of A.M.P.A.S. or any contributors, except as expressly stated herein.
-
Neither the name "A.M.P.A.S." nor the name of any other contributors to this software may be used to endorse or promote products derivative of or based on this software without express prior written permission of A.M.P.A.S. or the contributors, as appropriate.
This license shall be construed pursuant to the laws of the State of California, and any disputes related thereto shall be subject to the jurisdiction of the courts therein.
Disclaimer of Warranty: THIS SOFTWARE IS PROVIDED BY A.M.P.A.S. AND CONTRIBUTORS "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE, AND NON-INFRINGEMENT ARE DISCLAIMED. IN NO EVENT SHALL A.M.P.A.S., OR ANY CONTRIBUTORS OR DISTRIBUTORS, BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, RESITUTIONARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
WITHOUT LIMITING THE GENERALITY OF THE FOREGOING, THE ACADEMY SPECIFICALLY DISCLAIMS ANY REPRESENTATIONS OR WARRANTIES WHATSOEVER RELATED TO PATENT OR OTHER INTELLECTUAL PROPERTY RIGHTS IN THE ACADEMY COLOR ENCODING SYSTEM, OR APPLICATIONS THEREOF, HELD BY PARTIES OTHER THAN A.M.P.A.S.,WHETHER DISCLOSED OR UNDISCLOSED.