# colorspace | | | | |-|-|-| | [![Build Status]][travis] | [![Latest Version]][crates.io] | [![Docs Badge]][docs.rs] | [Build Status]: https://img.shields.io/travis/anderslanglands/colorspace-rs/master?style=for-the-badge [travis]: https://travis-ci.com/anderslanglands/colorspace-rs [Latest Version]: https://img.shields.io/crates/v/colorspace-rs.svg?style=for-the-badge [crates.io]: https://crates.io/crates/colorspace-rs [Docs Badge]:https://img.shields.io/badge/docs.rs-rustdoc-green?style=for-the-badge [docs.rs]:https://docs.rs/colorspace-rs A crate for colorimetry in Rust. This crate contains types and functions for working with color. The intended use is to support rendering applications (I use it to manage color in a spectral pathtracer), but if you want to be able to convert between spectral, XYZ, L'a'b' and RGB spaces of various flavors such as sRGB, ACES, DCI P3 and ALEXA Wide Gamut then this is the crate for you. This crate is still WIP but is fairly stable. Some minor refactoring may occur, but the core types are complete and stable. Future development will be mostly about adding functionality and SIMD-ifying as many operations as possible. I also intend to integrate OCIO at some point. ## Types ### Tristimulus The library contains two main types for working with color values. `XYZf` and `RGBf` can be either single- or double-precision and have all the expected mathematical operations defined. The `RGBu8` and `RGBu16` types are for storage only (for writing to images or passing to e.g. OpenGL for display) and do not define any operations. To do maths with them you must convert to `RGBf` first ### Spectral Power Distribution `SPD`s are defined as a pair of `Vec`s of wavelengths and associated values. The library supplies spectral data for CIE illuminants in the `illuminant` module, and for the color checker chart in the `color_checker` module. ## Examples ### Convert a slice of 32-bit sRGB colors to 8-bit DCI-P3 ```rust use colorspace::*; let srgb = &color_space_rgb::model_f32::SRGB; let dci_p3 = &color_space_rgb::model_f32::DCI_P3; let mut px_dci_p3_u8 = vec![rgbu8(0, 0, 0); px_srgb.len()]; rgb_to_rgb(srgb, dci_p3, &px_srgb, &mut px_dci_p3_u8); ``` ### Spectral to 8-bit, gamma-encoded sRGB conversion ```rust use colorspace::*; // Convert the spectral data for a measured MacBeth chart swatch to XYZ // using the CIE 1931 2-degree CMFs and a D65 illuminant let xyz = colorchecker::SPECTRAL["dark_skin"] .to_xyz(&illuminant::spd::D65, &cmf::CIE_1931_2_DEGREE); // Convert the XYZ value to scene-referred (i.e. linear) sRGB by first creating // the conversion matrix and then applying it let model_srgb = &color_space_rgb::model_f64::SRGB; let xf_xyz_to_srgb = xyz_to_rgb_matrix(model_srgb.white, model_srgb); let rgb = xyz_to_rgb(&xf_xyz_to_srgb, xyz); // Convert the scene-referred sRGB value to an 8-bit, display-referred // value by applying the opto-electrical transfer function and using RGBu8's // From impl let rgb: RGBu8 = model_srgb.encode(rgb).into(); assert_eq!(rgb, rgbu8(115, 82, 68)); ``` ## Licence Copyright [2018-2020] [Anders Langlands] colorspace is licensed under Apache License, Version 2.0 http://www.apache.org/licenses/LICENSE-2.0 This crate contains some data taken from the excellent colour-science python library by Mansencal et al.: Copyright (c) 2013-2018, Colour Developers Most of the conversion algorithms are based on those published at Bruce Lindbloom's site: Copyright © 2001 - 2018 Bruce Justin Lindbloom. BabelColor color-checker data is copyright © 2004‐2012 Danny Pascale (www.babelcolor.com); used with permission. Contains data from https://github.com/imallett/simple-spectral accompanying the EGSR 2019 paper "Mallett & Yuksel - Spectral Primary Decomposition for Rendering with sRGB Reflectance".