#color-space #color-conversion #color #xyz #format-conversion #lab #hsv

colorutils-rs

High performance utilities for color format handling and conversion

60 releases (6 breaking)

0.7.4 Dec 28, 2024
0.7.3 Nov 13, 2024
0.7.2 Oct 18, 2024
0.5.5 Jul 25, 2024

#384 in Video

Download history 658/week @ 2024-09-21 132/week @ 2024-09-28 590/week @ 2024-10-05 664/week @ 2024-10-12 229/week @ 2024-10-19 126/week @ 2024-10-26 231/week @ 2024-11-02 259/week @ 2024-11-09 108/week @ 2024-11-16 78/week @ 2024-11-23 71/week @ 2024-11-30 381/week @ 2024-12-07 161/week @ 2024-12-14 162/week @ 2024-12-21 679/week @ 2024-12-28 515/week @ 2025-01-04

1,528 downloads per month
Used in 5 crates (4 directly)

BSD-3-Clause OR Apache-2.0

765KB
19K SLoC

Rust utilities for color handling and conversion.

The goal is to provide support for common conversion and SIMD options for most common conversion path for high-performance

Available SIMD fast paths generally 5-10 times faster than naive implementations

Allows conversion between

  • Rgb/Rgba/Rgba1010102/Rgb565/RgbF16
  • HSL
  • HSV
  • CIE LAB
  • CIE LUV
  • CIE LCh
  • XYZ
  • Sigmoidal
  • Oklab
  • Oklch
  • Jzazbz
  • Jzczhz
  • lαβ (l-alpha-beta)
  • XYB

Performance

There are some prebuilt functions for ex.

srgb_to_lab(src_bytes, width * components, &mut lab_store, width * 3 * std::mem::size_of::<f32>() as u32, width, height);

Prebuilt solutions ~3-5 times faster than naive implementation. If your case fits that you prebuilt function. Speed increasing done with AVX, NEON and SSE, if you are disabled or not using CPU with this features then you won't receive any benefits.

Also, fma target feature for x86-64 is available.

Target feature at compile time +avx2 must be activated to properly compile avx2 instructions. This is an important step even when runtime dispatch are used.

This project is licensed under either of

  • BSD-3-Clause License (see LICENSE)
  • Apache License, Version 2.0 (see LICENSE)

at your option.

Dependencies

~2MB
~44K SLoC