HSB vs HSL vs HSV

Is HSB same as HSL?

No. HSB is the same as HSV, but HSL is different. All these are used as a friendly way to represent RGB colors. The Wikipedia article on HSL an HSV explains the differences using color cylinders: HSL and HSV.

Basically, Hue is the same for HSB and HSL but the Saturation takes different values, and Brightness and Lightness are also different.

If not, why isn't there an HSBL or even HSBLV?

I don't get the point. Both HSB/HSV and HSL can represent any RGB color. Having B and L independently is not possible because of the way they are defined. A given HSB Brightness and Saturation is associated to a fixed Lightness. In fact converting between them is very easy.

I find many different methods of calculating these values, can someone show me the FASTEST ones?

There's a similar question here for calculating HSB from RGB: Fast, optimized and accurate RGB <-> HSB conversion code in C. There's a Java implementation there that might help. For converting between HSB/HSV and HSL see HSL vs HSB vs HSV.


  1. HSB!=HSL and HSB==HSV
  2. HSBL and HSBLV not exists because Lightness and Brightness (also called Value) are substitutes
  3. Here are conversion methods (more on wiki HSL2RGB and HSV2RGB)

HSV -> RGB (implementation in js here)

enter image description here

RGB -> HSV (implementation in js here)

enter image description here


Originally the difference between Brightness And Lightness Is. "Brightness" is used for Subtractive colors and "Lightness" for Additive colors. Now if your program is dealing with Subtractive colors like the CMYK system it is better to use HSB otherwise it is better HSL.

Tags:

C++

Colors

Hsv

Hsl

Hsb