• Stars
    star
    2,058
  • Rank 22,467 (Top 0.5 %)
  • Language
  • Created about 8 years ago
  • Updated almost 2 years ago

Reviews

There are no reviews yet. Be the first to send feedback to the community and the maintainers!

Repository Details

Film Emulsion-Like Camera Rendering Transforms for Blender

Download the latest version of Filmic Blender

Who?

This is a simple OpenColorIO configuration for intermediate to advanced imagers using Blender's Cycles raytracing engine, or the Renderman system as included by default.

What?

This OpenColorIO configuration adds a closer-to-photorealistic view transform for your renders. For imagers working with non-photorealistic rendering, it also will bring significant dynamic range and lighting capabilities to your work, as well as potentially open up correct transforms for rendering to HDR displays and other such forward looking technology. It is as close to a Magic Buttonâ„¢ you can get for an experienced imager. The kit embodies a high dynamic range transfer function and an intensity gamut mapping.

Filmic does two things:

  1. It compresses the scene referred linear radiometric energy values down to the display / output referred range. This aspect is known as a transfer function or tone mapping. The shape of the Filmic Base Log with a contrast aesthetic roughly emulates a photographic film curve.
  2. It compresses the gamut for high intensity values. As colour ratios increase in intensity, highly saturated ratios tend to be resistant to transfer function compression, which results in peculiar feeling imagery with some regions feeling appropriately over-exposed and others "lingering" behind. Filmic considers all colour values fair game, and attempts to blend colours into a consistent output that matches our learned expectations from film emulsion-like media.

When?

This repository is ready to use right now, with no compilation or special Blender application binaries required.

Why?

Because the basic sRGB nonlinear transfer functions (OETF / EOTF) were designed to describe an aspect of device response and never for rendering. This configuration is a step towards providing imagers with a reliable camera rendering transform and a base of aesthetic looks useful for modern raytracing engine CGI, animation, and visual effects work with real-world cameras.

How?

  1. Download the latest version of Filmic Blender. Replace your current OpenColorIO configuration in Blender with this version.

  2. The Blender OpenColorIO configuration directory is located in:

    BLENDER/bin/VERSIONNUMBER/datafiles/colormanagement
    

    Move the existing colormanagement directory to a backup location, and place the contents of this repository into a new colormanagement directory.

  3. Optionally, instead of replacing the actual directory, use the environment variable to specify where the OCIO configuration lives:

    export OCIO=/path/to/where/the/filmic-blender/config.ocio
    
  4. From within the Color Management panel, change the View to your desired contrast level and render.

Once you have Blender utilising the configuration, you are free to render away. You may discover that some of your materials were broken due to exceptionally low lighting levels, and may require reworking. General PBR advice holds true when using wider and more photographic illumination levels.

Supported Display Colorimetry

The current configuration supports:

  • Generic sRGB / REC.709 displays with 2.2 native power function
  • Display P3 displays with 2.2 native power function. Examples include:
    • Apple MacBook Pros from 2016 on.
    • Apple iMac Pros.
    • Apple iMac from late 2015 on.

Due to an unfortunate side effect of the way Blender has thus far integrated colour management, folks pushing pixels on Apple Display P3 devices will need to be careful when encoding images. Loosely:

  • When viewing renders, use the Apple Display P3 setting.
  • When saving nonlinear display referred files such as JPEG, TIFF, etc. it is critical that the Display be set to the file encoding. For example, for sRGB imagery, the View must be set to sRGB for the file to be properly encoded. If this is not done, the file will not be encoded properly. The bug / todo can be found at the link provided.

Additional Information and Technical Details

The basic kit of weaponry includes:

View Transforms

A set of View transforms that include:

  1. sRGB OETF. This is an accurate version of the sRGB transfer function. This is identical to what imagers would use as the "Default" View transform in Blender proper. Should be avoided at all costs for CGI work. Useful in some edge cases for albedo textures, for example.
  2. Non-Colour Data. This is a view useful for evaluating a data format. Do not expect to see perceptual values however, as it is literally data dumped directly to the screen. Use this transform on your buffer, via the UV Image Viewer Properties panel, if your buffer represents data and not colour information. This will keep it out of the OpenColorIO transformation pipeline chain and leave it as data.
  3. Linear Raw. This is a colour managed linearized version of your data. For all intents an purposes, will look identical to Non-Colour Data, but applied to colour based data such as an image.
  4. Filmic Log Encoding Base. This is the workhorse View for all of your rendering work. Setting it in the View will result in a log encoded appearance, which will look exceptionally low contrast. Use this if you want to adjust the image for grading using another tool such as Resolve, with no additional modifications. Save to a high bit depth display referred format such as 16 bit TIFF. This basic view is designed to be coupled with one of the contrast looks.

Look Transforms

A set of Look transforms that include:

  1. Greyscale. This Look is based off of the Filmic Log Encoding Base and will deliver a weighted greyscale version of the image. The weights used are for REC.709 RGB lights, which are the same lights specified in sRGB.

  2. Five contrast base looks for use with the Filmic Log Encoding Base. All map middle grey 0.18 to 0.5 display referred. Each has a smooth roll off on the shoulder and toe. They include:

    1. Very High Contrast.
    2. High Contrast.
    3. Medium High Contrast.
    4. Base Contrast. Similar to the sRGB contrast range, with a smoother toe.
    5. Medium Low Contrast.
    6. Low Contrast.
    7. Very Low Contrast.
  3. False Colour. This Look is an extremely useful tool for evaluating your image in terms of the dynamic range and latitude. It is a colour coded "heat map" of your image values, according to the following codes:

    Value Colour Scene Referred Value
    Low Clip Black Scene Referred Linear value below 0.0001762728758.
    -7.5 EV Purple Scene Referred Linear value 0.00099436891.
    -5.0 EV Blue Scene Referred Linear value 0.005625.
    -2.5 EV Cyan Scene Linear value 0.005625.
    -0.01 EV Green-Cyan Scene Referred Linear value ~0.178.
    0 EV Grey Scene Referred Linear value 0.18009142.
    +0.01 EV Green-Yellow Scene Referred Linear value ~0.181.
    +2.17 EV Yellow Scene Referred Linear value 0.80779930598.
    +4.33 EV Red Scene Referred Linear value 3.62857262286.
    High Clip White Scene Referred Linear value above 16.29174024.

Grading Your Work

Given that images generated under Cycles are scene referred, many nodes in Blender, being broken, will not work properly. This may have been hidden if one used a range that perfectly mapped to the display referred domain such as the sRGB transfer function, however using a proper camera rendering transform exacerbates this brokenness.

There are a good number of nodes that work absolutely fine. For grading, it is highly encouraged to use the ASC CDL node, as it operates on scene referred imagery perfectly well. It is in the Color -> Color Balance node. Do not use the Lift, Gamma, Gain default as it is strictly a display referred formula and will break on scene referred imagery. Instead, change the drop down to ASC CDL and use the Slope, Offset, and Power controls to perform grading.

Almost all of the Adobe PDF specification blend modes in the Mix node are also display referred and are broken for Cycles rendering. That includes but is not limited to Overlay, Screen, and other such modes.

Viewing in Other Applications

It is important to tag your imagery generated with Filmic with the canonized sRGB ICC for viewing outside of Blender and across applications and the web. Simply assign the profile to your generated image using the tool of your choice. Do not convert.

Colorimetric Information

RGB Primaries

Filmic was designed to be easily integrated into existing pipelines, and as such, uses the primaries and achromatic white colour outlined in ITU-R BT.709 specification. As a result, the reference space lights match the sRGB specification and are as follows:

Primary x y
Red 0.64 0.33
Green 0.30 0.60
Blue 0.15 0.06
Achromatic 0.3127 0.3290

RGB to XYZ transform

Following with the above, the transformation for primaries to the CIE 1931 2 degree standard observer XYZ model, is:

Primary Red Green Blue
X 0.4123910 0.3575840 0.1804810
Y 0.2126390 0.7151690 0.0721923
Z 0.0193308 0.1191950 0.9505320

Transfer Function of Base Log Encoding

The canonized ground-truth encoding for Filmic is the Filmic Base Log Encoding. The Base Log Encoding is a pure normalized log 2 encoding in two parts, to accomodate the gamut mapping for wide primary ratio intensity gamut mapping. The first portion that is routed through the 3D LUT for the gamut compression at value range -12.473931188, 12.526068812. The final Base Log Encoding covers the log 2 range of -12.473931188, 4.026068812.

Transfer Function of Aesthetic Outputs

The contrasts are designed for an idealized sRGB display, with the aforementionned primaries, and an Electro-Optical Transfer Function consisting of a pure 2.2 power function.

Issues

Please post any and all issues to the issue tracker at GitHub.

More Repositories

1

blender

Mirror of the official Blender Git repository. Updated every hour.
C
658
star
2

AgX

There Be Kraken and Dragons
234
star
3

blender-addons

Python
126
star
4

filmic-resolve

Filmic Resolve Cube LUTs
115
star
5

blender-addons-contrib

Python
54
star
6

Testing_Imagery

Colourimetric Test Imagery
30
star
7

AgX-Resolve

AgX Picture Formation for DaVinci Resolve
C
22
star
8

ACES-1.2-Displays-Formatted

Proper display by display colourimetric breakdown of the ACES 1.2 configuration
Roff
19
star
9

AgX-S2O3

Nothing to see here. Move along...
Python
16
star
10

bassam-test

Simple WfE view transform with 6.5 stops over middle grey.
15
star
11

Blender-NLE-NextGen

Musings about a theoretical next generation Blender non linear editor component.
12
star
12

SB2383-Configuration-Generation

Eduardo Suazo and Chris Brejon experimental OpenColorIO configuration.
Python
10
star
13

blender-io-timeline-markers

A method to import and export Blender Timeline Markers for use in other Blender projects.
Python
8
star
14

iccinspector

V2 and V4 compatible ICC Inspector
Python
8
star
15

OpenColorIO-Colour-Management-Test

5
star
16

YCbCrExporter

A Y'Cb'Cr' lab that allows a filmmaker / artist to manipulate their files to maximize quality.
C++
5
star
17

djv-view

C++
4
star
18

Apple-ICC-Peeler

Used to peel apart Apple DCI-P3 ICCs for OpenColorIO.
Python
4
star
19

filmic-nuke

Filmic Nuke
4
star
20

SB2383-Configuration

Testing OpenColorIO configuration for Eduardo Suazo and Chris Brejon.
4
star
21

filmic-gh5-vlogl

Filmic with GH5 V-Log L / V-Gamut transforms
3
star
22

developer-colorspace-testing

A high dynamic range set of imagery for testing OCIO based colour transforms
3
star
23

blender-dev-tools

Python
3
star
24

nikonD5200ocio

Transform set based on Filmic with the Nikon D5200 camera transfer function.
2
star
25

natron-ocioconfig

Natron OpenColorIO configuration
2
star
26

Equivalent-Luminance-Test

Equivalent Luminance Test based on Kindlmann, Reinhard, and Creem. https://doi.org/10.1109/VISUAL.2002.1183788
2
star
27

camera-spectral-sensitivity

Mirror of source code available at http://www.gujinwei.org/research/camspec/.
C
2
star
28

krita-hdr-ocio

Developer Krita HDR OpenColorIO Configuration
Python
1
star
29

Filmic-Contrasts

Comma separated Filmic contrasts.
1
star
30

ocio-blender-default

Blender's default OCIO configuration
1
star
31

ocio-images

Clone of the v4 OpenColorIO images set found on Google Code
1
star
32

Abney_Experiment

1
star
33

L-C-Demo

1
star
34

spectral-cycles-ocio-config

A minimal configuration for the Spectral Cycles path tracing engine
Python
1
star
35

interpolation_revisited

Git repository of P. Thévenaz, T. Blu, M. Unser, "Interpolation Revisited," IEEE Transactions on Medical Imaging, vol. 19, no. 7, pp. 739-758, July 2000.
C
1
star
36

Generic-ICC-DIsplay-Profiles

A selection of simple, generic ICC display profiles to help creators out.
1
star