Skip to content

Releases: facelessuser/coloraide

4.2

26 Jan 20:04
Compare
Choose a tag to compare
  • NEW: Provide new color spaces Oklrab/OkLrCh which use a modified lightness prediction.
  • NEW: Add new matrix math functions that are specifically optimized for matrices and vectors of length 3 and
    leverage it in all appropriate places for a performance boost.
  • NEW: Combine logic of algebra optimized vectorize functions and deprecate unnecessary function.
  • NEW: Some typing fixes and adjustments.

4.1.0

05 Dec 06:35
Compare
Choose a tag to compare

4.1.0

  • NEW: The powerless parameter is deprecated in average() as it is required to be always on for proper polar
    space averaging.
  • FIX: Polar space averaging was not setting hues to undefined when colors are evenly distributed. This is
    required as circular means cannot be found in these cases.
  • FIX: When averaging within a polar space, if the result hue is determined to be undefined at the end of
    averaging, the color will be treated as if achromatic, setting saturation/chroma as necessary. This is needed to
    prevent serialization of achromatic colors to a non-achromatic color when undefined values are resolved.
  • FIX: Fully transparent colors should only contribute alpha in color averaging, regardless of premultiply
    setting. This prevents fully transparent color channels, which provide no meaningful data, from distorting averages.
  • FIX: When averaging in a polar space, if a color is considered achromatic but does not have an undefined hue,
    the hue will be treated as undefined. Essentially the powerless parameter is now always True. This ensures that
    achromatic colors properly contribute to the average without distorting the hue.

4.0.1

29 Nov 01:39
2a8b99b
Compare
Choose a tag to compare

4.0.1

  • FIX: Fix issue with continuous interpolation (and any that are derived from it, e.g., cubic spline
    interpolations) that can cause bad hue fixup calculations.
  • FIX: Fix issue with continuous interpolation (and any that are derived from it, e.g., cubic spline
    interpolations) that can cause premultiplication to be applied to a color twice.

4.0

23 Sep 18:27
Compare
Choose a tag to compare
4.0

4.0

  • NEW: Officially support Python 3.13.
  • NEW: Define HTML output representation for Jupyter via _repr_html_.
  • NEW: get(), coords(), alpha(), to_dict() can now return channel values with a specified precision via
    the new precision parameter. Per channel precision can be controlled if a list of precision is given.
  • NEW: to_string() support for per channel precision was added and precision can now accept a list of
    precision.
  • NEW: Remove deprecated model parameter from cam16 ∆E method. Space should be used instead.
  • NEW: Remove deprecated algebra.npow function. algebra.spow should be used instead.
  • NEW: New generic minde-chroma gamut mapping method that allows specifying any Lab-ish or LCh-ish space to
    operate in. oklch-chroma, lch-chroma, and hct-chroma are now derived from minde-chroma and just default to
    using the specified color space to provide backwards compatibility. minde-chroma defaults to using OkLCh by
    default. lch-chroma is still ColorAide's default gamut mapping currently.
  • NEW: All MINDE chroma reduction methods now skip distance checks if a JND of zero is specified. A JND of zero
    essentially disables the MINDE behavior and will reduce chroma as close to the gamut boundary as possible faster
    than it would previously.
  • NEW: MINDE chroma reduction plugins now dynamically figures out lightness range instead of requiring it to be
    specified as a class attribute.
  • NEW: MINDE chroma reduction gamut mapping and ray trace gamut mapping now allow for specifying an adaptive
    option which will bias the chroma reduction by the specified factor in a hue independent way relative to a midpoint
    of L = 50%.
  • NEW: Remove deprecated lab parameter from experimental raytrace gamut mapping method. Users should use
    pspace instead to specify the perceptual space to use.
  • NEW: Class method layer() added to replace compose() with a multi-color handling similar to other API
    methods such as interpolate(), etc.
  • NEW: compose() has been deprecated in favor of the new layer() method and will be removed at some future
    time but is available to help with transition.
  • NEW: Improve experimental raytrace gamut mapping approach when performed in certain perceptual spaces.
  • NEW: The experimental raytrace gamut mapping method now uses OkLCh by default instead of CIELCh (D65). Results
    may vary.
  • BREAK: Pre-configured oklch-raytrace and lch-raytrace variants of the experimental raytrace gamut mapping
    method have been removed to reduce included plugins. OkLCh is the default now and users can still specify CIELCh and
    other perceptual spaces if desired via the pspace parameter. Additionally, documentation has been added so users
    can easily recreate the aforementioned pre-configured methods themselves or their own desired variants.
  • BREAK: MINDE chroma reductions plugin combines the DE and DE_OPTIONS class attributes under DE_OPTIONS.
    Users who have a derived gamut mapping class must combined these two options under DE_OPTIONS.
  • BREAK: MINDE chroma reduction plugin now specifies the perceptual space via the PSPACE attribute instead of
    SPACE. Users who have a derived, personal gamut mapping plugin need to update the name accordingly.
  • BREAK: MINDE chroma reduction plugins now specify the JND under the JND class attribute instead of LIMIT.
    Users who have a derived, personal gamut mapping plugin need to update the name accordingly.
  • BREAK: Interpolation plugin renamed the parameter create to color_cls which is a more descriptive and less
    confusing name. If a user interpolation plugin is derived and overrides the __init__ method, it should update to
    use color_cls instead of create.
  • FIX: HWB and HSV cannot normalize hue and saturation the same way as HSL when saturation is negative.
  • FIX: Fix corner case in ZCAM that could throw a domain error.
  • FIX: Color.new() was documented as a class method but was internally still an instance method. Ensure it is a
    class method.

3.3.1

18 Apr 21:16
Compare
Choose a tag to compare

3.3.1

  • FIX: Ray trace gamut mapping algorithm will better handle perceptual spaces like CAM16 and HCT which have
    atypical achromatic responses. This prevents unexpected cutoff close to white.
  • FIX: Fix some documentation examples regarding gamut mapping in HCT.

3.3

12 Apr 17:40
Compare
Choose a tag to compare
3.3

3.3

  • NEW: Extend the Cylindrical mixin class to expose radial_name() and radial_index() on the color space to
    return the default name or default index of the radial coordinate in polar color spaces. It also exposes
    is_polar() as a simple check to see if the space uses polar coordinates.
  • NEW: Euclidean distance algorithm will now handle cylindrical color spaces by converting the polar coordinates
    to rectangular coordinates in order to return sensible results.
  • NEW: Allow specifying number of colors to return for monochromatic harmony. When fewer are specified, allow them
    to be spaced further apart for better contrast.
  • FIX: Handle unexpected undefined values in Euclidean distance.

3.2

03 Apr 01:26
Compare
Choose a tag to compare
3.2

3.2

  • NEW: Add zcam-jmh color model.
  • NEW: Previously, color spaces such as cam16-jmh, cam16-ucs, jzczhz, etc. would handle achromatic values
    absolutely, based on XYZ with the specified white point which could result in values with non-zero chroma. Now they
    will be handled relative to the space, meaning colors will be considered achromatic when they are close to zero
    chroma. What is considered achromatic is affected by the adapting luminance and other environmental settings.
    This simplifies logic making it faster and also easier for users to subclass with their own environmental settings.
  • NEW: Normalize how color spaces with special viewing conditions are configured. Document configuring viewing
    conditions of color models where applicable.
  • NEW: Add new space parameter in cam16 ∆E method to replace the now deprecate model parameter. space is
    more flexible as users can now create CAM16 UCS spaces with different lighting environments and specify them
    instead.
  • NEW: Remove previously deprecated CAM16 Jab implementation. Use cam16-ucs instead.
  • NEW: Interpolation will now gracefully handle a list of a single color causing the interpolation to just return
    the single color.
  • NEW: More helpful interpolation errors will raise for an empty list.
  • NEW: Generic ray trace gamut mapping now has a new pspace parameter that can be used to specify a perceptual
    space in either LCh-ish or Lab-ish form. lch parameter is now deprecated, but currently still present, but
    pspace will take priority if both are defined.
  • NEW: Rename algebra.npow to algebra.spow (signed power). algebra.npow is now deprecated and will be
    removed at some future time.
  • FIX: Don't force space to clamp negative XYZ when they are absolutizing them in some spaces.
  • FIX: Ensure ST2084 EOTF implements the max step as specified in the spec.

3.1.2

11 Mar 02:54
Compare
Choose a tag to compare

3.1.2

  • ENHANCE: Further improvements to both speed and accuracy of ray trace gamut mapping.
  • FIX: Handle gamut mapping HDR spaces via ray trace more sanely.

3.1.1

03 Mar 00:16
Compare
Choose a tag to compare

3.1.1

  • ENHANCE: Improved performance of ray tracing gamut mapping algorithm.
  • FIX: Fix corner cases for detecting ray trace hits on gamut.

3.1

27 Feb 23:30
Compare
Choose a tag to compare
3.1

3.1

  • NEW: Increase accuracy of the experimental ray tracing gamut mapping algorithm.
  • NEW: Add generic gamut mapping algorithm that employs ray tracing method that can be used with any LCh
    perceptual space.
  • NEW: Ray tracing gamut mapping algorithm parameter traces will no longer do anything as the approach no longer
    has variable passes after new accuracy enhancements.
  • FIX: Jzazbz bug was fixed that would result in a divide by zero failure.