A Web App for generating 1D and 3D Lookup Tables (LUTs) for video cameras that shoot log gammas, principally the Sony CineAlta line.
LUTCalc generates 1D and 3D .cube format LUTs suitable for use in DaVinci Resolve, Adobe Speedgrade and as user 3D LUTs in Sony's log-recording video cameras. These include the PMW-F5, PMW-F55 and PXW-FS7.
How To Start
Chrome (Windows, Mac or Linux): LUTCalc currently needs to be run as an app extension. Either click Window->Extensions in the menu bar or type chrome://extensions in the address bar. Check 'developer mode' in the top right, then click 'Load unpacked extension' and find the main LUTCalc directory and click select. LUTCalc should then show up on the list of installed extensions. You can now uncheck developer mode and start LUTCalc either by clicking 'Launch' or from the Chrome App Launcher.
Firefox: I have been developing using Firefox, so opening index.html in the main directory should work.
Internet Explorer: currently looking in to making this work.
Gamma / Gamut Information
The sources of information used are white papers and standards documents, analysis and comparison of test images and LUT calculations using known reference LUTs.
Sony S-Log3 - Technical Summary for S-Gamut3.Cine/S-Log3 and S-Gamut3/S-Log3
Sony S-Gamut3 / S-Gamut3.cine - Sony Excel spreadsheet of various gamut matrices
Sony S-Log2 - Sony technical paper on S-Log2
Sony S-Log - S-Log: A new LUT for digital production mastering and interchange applications
Sony Look Profile LUTs - Sony Community Website
Arri LogC / Wide Gamut - ALEXA Log C Curve - Usage in VFX
Canon C-Log - Canon-Log Cine Optoelectronic Transfer Function
Canon LUTs and Gamut Information - Canon C500 Support Site
Canon C300 Input Device Transform (IDT) - Canon C300 Support Site - under 'Software'. You have to specify 'Mountain Lion' on a Mac or 'Windows XP' on a PC for it to be displayed. C500 and C100 have the same IDTs for CP Lock, though the C500 also offers 'Cinema Gamut' (see above link).
Panasonic Varicam V-Log and V-Gamut - V-Log/V-Gamut Reference Manual
Cineon - Understanding Cineon
Rec709 - ITU BT.709-5
sRGB - Wikipedia entry
Dolby PQ and alternative prospective transfer functions for HDR displays - Non-linear Opto-Electrical Transfer Functions for High Dynamic Range Television
Chromatic adaptation and Von Kries transform for colour temperature adjustments - Wikipedia article
LUTCalc File List
- index.html (window.html) - HTML5 base of LUTCalc. Launch to start.
- lutcamerabox.js - builds the UI object where camera and ISO are chosen.
- lutgammabox.js - builds the UI object for transfer curve (gamma) and colour space (gamut) selection.
- luttweaksbox.js - builds the UI object for customising the transfer (gamma) curves and colour spaces / gamuts.
- lutanalyst.js - extension to luttweaksbox which reads and then analyses LUTs into transfer function and colour space components so that they can be adapted for use with other input colour spaces and further tweaked as with the built-in options.
- lutlutbox.js - builds the UI object containing options concerning the LUT format.
- lutgeneratebox.js - builds the 'Generate' button that triggers the LUT generation, plus the generation logic itself.
- lutpreview.js - builds the UI object which previews LUTs on test images.
- lutinfobox.js - builds the UI object which shows instructions, plots of the input and output gammas against stop and IRE and data values for correct exposure with the chosen output gamma.
- lutformats.js - controller object for the parsers and builders of various LUT formats.
- lut-cube.js - .cube format parsing and building (Adobe format and DaVinci format).
- lut-davinci.js - DaVinci Resolve 1D .ilut input LUT and .olut output LUT parsing and building.
- lut-vlt.js - Panasonic .vlt MLUT format parsing and building.
- lut-3dl.js - .3dl format parsing and building (Assimilate, Autodesk and Kodak formats).
- lut-lut.js - Assimilate 1D .lut parsing and building.
- lut-spi1d.js - Sony Pictures International 1D .spi1d format parsing and building.
- lut-spi3d.js - Sony Pictures International 3D .spi3d format parsing and building.
- lut-la.js - cube-based .lacube and .labin LUTAnalyst parsing and building.
- twk-wb.js - white balance (colour temperature / fluori green / magenta) adjustment.
- twk-asccdl.js - adjustment based on the ASC-CDL operations.
- twk-psstcdl.js - colour-specific adjustment based on the ASC-CDL controls.
- twk-hg.js - adjustment to allow for a second choice of gamut in the highlights.
- twk-blkhi.js - adjustment of the black level and a user-selectable scene reflectance response level.
- twk-fc.js - false colour overlay option.
- twk-la.js - LUTAnalyst UI controls.
- twk-blank.js - empty example object which demonstrates the layout.
- lutmessage.js - handles creation and message passing for multiple web worker calculation threads.
- gamma.js - handles all the calculations relating to transfer functions (gammas).
- colourspace.js - handles all the functions relating to colour spaces (gamuts).
Binary LUT Files
- LC709.labin - little-endian Float64Array buffer of colour space (S-Log3 to S-Log3, S-Gamut3.cine to LC709) data based on Sony's look profile.
- LC709A.labin - colour space data based on Sony's look profile.
- V709.labin - experimental colour space data based on Panasonic's reference V-log to V709 LUT.
- cpoutdaylight.labin - Canon CP lock to S-Gamut3.cine data developed by testing against Canon's reference daylight IDT.
- cpouttungsten.labin - Canon CP lock to S-Gamut3.cine data developed by testing against Canon's reference tungsten IDT.
- splash.js - displays a splash screen and sets the version.
- lut.js - LUT handling object. Will calculate interpolated values from LUTs using cubic and tricubic interpolation. Also includes code for breaking a 3D LUT into gamma and gamut component LUTs and changing the input gamma / gamut (as used by the LUTAnalyst tool).
- ring.js - ring spline object. Like a 1D LUT which connects back on itself. Used in the PSST-CDL calculations.
- lutfile.js - file handling object.
- lutinputs.js - simple object into which the other objects can place their form input objects, to allow interaction without globals.
- brent.js - Brent's method of root finding for LUTAnalyst.
- tests.js - object containing feature / environment detection tests.
- window.html - web app version of index.html.
- background.js - web app required code.
- manifest.webapp - web app manifest.
- manifest.json - alternative web app manifest format.
- reset.css - DOM reset stylesheet.
- fonts.css - font options stylesheet.
- ui.css - style sheet controlling specific UI elements.
- style.css - base stylesheet controlling the look of the app. All dimensions (greater than 1 pixel) are em values.
- info.css - stylesheet controlling the information / instructions window.
- background.js - Chrome packaged app requirement
- LUTCalc.icns - icon file containing a logo in a format suitable for Mac OSX Apps in XCode.
- logo(x).png - various sizes of png containing the LUTCalc logo for the Chrome app.
- Gray LSB/ MSB .png - 16-stop grayscale test image.
- CW LSB / MSB .png - Representation image of the Rec709 Colour Gamut for use in the preview window.
- README.md - this file.
- CHANGELOG.md - changelog.
- LICENSE - GPL2 License document.
External Code Used
- The function 'createRadioElement' is used to dynamically create radio buttons. This came from a tip by Prestaul on stackoverflow
All other code is by me, Ben Turley.