説明
[色空間変換]


色空間と色空間変換

本章では、簡単な色空間の説明と、色空間変換に用いた定義式を示します。 以下に示す色空間のうち、FAST独自仕様と表記されているものは、弊社独自の色空間定義です。 当社旧ライブラリ(FVL,FVXなど)での色空間の定義では、いくつか一般的な定義と異なるものが あったため、今回のライブラリではそれらをより一般的なものに変更しております。 そこで、これら当社旧ライブラリとの互換性を保つために、変更された色空間を 当社独自仕様として別途用意しました。 なお、特に表記がない色空間は、旧ライブラリと同一の仕様か、 または旧ライブラリに存在しなかった色空間です。

RGB

本ライブラリでは、基準色空間としてRGB色空間を定義しています。 Fig1に基準色空間であるRGB色空間を示します。

color_convert_rgb.png

Fig1. RGB色空間

RGB -> RGB への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
  • UC8 -> DOUBLE
  • DOUBLE -> UC8
変換後のRGB色空間を (R',G',B') とします。 なお、DOUBLE -> DOUBLE 、UC8 -> UC8 の同一の画素タイプへの変換には、 fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} R' \\ G' \\ B' \\ \end{array} \right) = \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le R', G', B' \le 255 \]

グレースケール

本変換は、RGB色空間との相互変換が不可な変換です。 つまり、RGBからグレースケール画像へ変換した画像から逆変換によりRGBに戻した画像は、変換前の画像と等しくなりません。 もし、グレースケールで何らかの処理をした後、変換前のRGBを使用したい場合には、RGB画像を保持しておく必要があります。

RGB -> Gray への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
  • UC8 -> DOUBLE
  • DOUBLE -> UC8

\[ Gray = 0.299 \times R + 0.587 \times G + 0.114 \times B \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le Gray \le 255 \]

Gray -> RGB への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
  • UC8 -> DOUBLE
  • DOUBLE -> UC8

\[ \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) = \left( \begin{array}{lll} +1.00000 & +0.00000 & +0.00000 \\ +0.00000 & +1.00000 & +0.00000 \\ +0.00000 & +0.00000 & +1.00000 \\ \end{array} \right) \left( \begin{array}{l} Gray \\ Gray \\ Gray \\ \end{array} \right) \\ \]

\[ 0 \le Gray \le 255 \]

\[ 0 \le R, G, B \le 255 \]

Gray -> Gray への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
  • UC8 -> DOUBLE
  • DOUBLE -> UC8
変換後のGray色空間をGray'とします。 なお、DOUBLE -> DOUBLE 、UC8 -> UC8の同一の画素タイプへの変換には、 fnFIE_img_copy() を使用しています。

\[ Gray' = Gray \]

\[ 0 \le Gray \le 255 \]

\[ 0 \le Gray' \le 255 \]

XYZ

RGB表色系では、等色関数に負の値があります。 そのため、等色関数の値がすべて非負となるようにXYZ表色系が導入されました。 XYZ表色系は他のCIE表色系の基礎となります。
Fig2にXYZ色空間を示します。

color_convert_xyz.png

Fig2. XYZ色空間

RGB -> XYZ への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) = \left( \begin{array}{lll} +2.768900 & +1.751700 & +1.130200 \\ +1.000000 & +4.590700 & +0.060100 \\ +0.000000 & +0.056500 & +5.594300 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le X, Y, Z \le 1440.954 \]

RGB -> XYZ への変換(スケーリングあり)
  • UC8 -> UC8
  • DOUBLE -> UC8

\[ \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) = \left( \begin{array}{lll} +0.490001 & +0.309992 & +0.200007 \\ +0.176966 & +0.812398 & +0.010636 \\ +0.000000 & +0.009999 & +0.990001 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le X, Y, Z \le 255 \]

XYZ -> RGB への変換
  • DOUBLE -> DOUBLE
  • DOUBLE -> UC8

\begin{eqnarray*} \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) &=& \left( \begin{array}{lll} +2.768900 & +1.751700 & +1.130200 \\ +1.000000 & +4.590700 & +0.060100 \\ +0.000000 & +0.056500 & +5.594300 \\ \end{array} \right)^{-1} \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right)\\ &=& \left( \begin{array}{lll} +0.418452 & -0.158652 & -0.082834 \\ -0.091164 & +0.252424 & +0.015706 \\ +0.000921 & -0.002549 & +0.178595 \\ \end{array} \right) \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le X, Y, Z \le 1440.954 \]

\[ 0 \le R, G, B \le 255 \]

XYZ -> RGB への変換(スケーリングあり)
  • UC8 -> UC8
  • UC8 -> DOUBLE

\[ \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) = \left( \begin{array}{lll} +2.364591 & -0.896501 & -0.468080 \\ -0.515151 & +1.426401 & +0.088750 \\ +0.005203 & -0.014407 & +1.009204 \\ \end{array} \right) \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) \\ \]

\[ 0 \le X, Y, Z \le 255 \]

\[ 0 \le R, G, B \le 255 \]

XYZ -> XYZ への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
変換後のXYZ色空間を(X',Y',Z')とします。 なお、変換には fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} X' \\ Y' \\ Z' \\ \end{array} \right) = \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) \\ \]

変換の画素タイプがDOUBLE -> DOUBLEの場合は、

\[ 0 \le X, Y, Z \le 1440.954 \]

\[ 0 \le X', Y', Z' \le 1440.954 \]

変換の画素タイプがUC8 -> UC8の場合は、

\[ 0 \le X, Y, Z \le 255 \]

\[ 0 \le X', Y', Z' \le 255 \]

となります。

XYZ -> XYZ への変換(スケーリングあり)
  • DOUBLE -> UC8
変換後のXYZ色空間を(X',Y',Z')とします。 そして、 $ 0 \le X', Y', Z' \le 255 $ とするためのスケーリング行列をSとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +\dfrac{255.000000}{1440.954000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{1440.954000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{1440.954000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.176966 & +0.000000 & +0.000000 \\ +0.000000 & +0.176966 & +0.000000 \\ +0.000000 & +0.000000 & +0.176966 \\ \end{array} \right) \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} X' \\ Y' \\ Z' \\ \end{array} \right) &=& S \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.176966 & +0.000000 & +0.000000 \\ +0.000000 & +0.176966 & +0.000000 \\ +0.000000 & +0.000000 & +0.176966 \\ \end{array} \right) \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le X, Y, Z \le 1440.954 \]

\[ 0 \le X', Y', Z' \le 255 \]

XYZ -> XYZ への変換(スケーリングあり)
  • UC8 -> DOUBLE
変換後のXYZ色空間を(X',Y',Z')とします。 そして、 $ 0 \le X', Y', Z' \le 1440.954 $ とするためのスケーリング行列をSとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +\dfrac{1440.954000}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{1440.954000}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{1440.954000}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +5.650800 & +0.000000 & +0.000000 \\ +0.000000 & +5.650800 & +0.000000 \\ +0.000000 & +0.000000 & +5.650800 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} X' \\ Y' \\ Z' \\ \end{array} \right) &=& S \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +5.650800 & +0.000000 & +0.000000 \\ +0.000000 & +5.650800 & +0.000000 \\ +0.000000 & +0.000000 & +5.650800 \\ \end{array} \right) \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le X, Y, Z \le 255.0 \]

\[ 0 \le X', Y', Z' \le 1440.954 \]

YUV

YUV(PAL/SECAM)はアジアやヨーロッパでのTVの信号の規格です。 Y成分(輝度)についてはCIE1931XYZに従います。 ここで、CIE1931XYZ表色系とは、CIE(国際照明委員会)で 1931年に採択した等色関数 $x\left(\lambda \right)$$y\left(\lambda \right)$$z\left(\lambda \right)$ に基づく三色表色系です(2°視野 XYZ表色系ともいいます)。
Fig3にYUV色空間を示します。 なお、出力画像オブジェクトの画素タイプがF_IMG_UC8などで、 スケーリング処理された場合は、Fig3と異なります。

color_convert_yuv.png

Fig3. YUV色空間

RGB -> YUV への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ \left( \begin{array}{l} Y \\ U \\ V \\ \end{array} \right) = \left( \begin{array}{lll} +0.299000 & +0.587000 & +0.114000 \\ -0.147000 & -0.289000 & +0.437000 \\ +0.615000 & -0.515000 & -0.100000 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le Y \le 255 \]

\[ -111.18 \le U \le 111.435 \]

\[ -156.825 \le V \le 156.825 \]

RGB -> YUV への変換(スケーリング、オフセットあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
$ 0 \le Y, U, V \le 255 $ とするためのスケーリング行列をS 、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{222.615000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{313.650000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \\ +0.000000 & +1.145475 & +0.000000 \\ +0.000000 & +0.000000 & +0.813008 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} T &=& \left( \begin{array}{l} +0.000000 \vspace{.5em} \\ +\dfrac{255.000000}{222.615000} \times 111.180000 \vspace{.5em} \vspace{.5em} \\ +\dfrac{255.000000}{313.650000} \times 156.825000 \vspace{.5em} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.000000 \\ +127.353952 \\ +127.500000 \\ \end{array} \right)\\ \end{eqnarray*}

YUV色空間への変換行列をMとすると、以下の通りとなります。

\[ \left( \begin{array}{l} Y \\ U \\ V \\ \end{array} \right) = SM \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} Y \\ U \\ V \\ \end{array} \right) = \left( \begin{array}{llll} +0.299000 & +0.587000 & +0.114000 & 0.000000 \\ -0.168385 & -0.331042 & +0.500573 & 127.353952 \\ +0.500000 & -0.418699 & -0.081301 & 127.500000 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le Y, U, V \le 255 \]

YUV -> RGB への変換
  • DOUBLE -> DOUBLE
  • DOUBLE -> UC8

\begin{eqnarray*} \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) &=& \left( \begin{array}{lll} +0.299000 & +0.587000 & +0.114000 \\ -0.147000 & -0.289000 & +0.437000 \\ +0.615000 & -0.515000 & -0.100000 \\ \end{array} \right)^{-1} \left( \begin{array}{l} Y \\ U \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1.000000 & -0.000039 & +1.139828 \\ +1.000394 & -0.393810 & -0.580501 \\ +0.997972 & +2.027879 & -0.000480 \\ \end{array} \right) \left( \begin{array}{l} Y \\ U \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le Y \le 255 \]

\[ -111.18 \le U \le 111.435 \]

\[ -156.825 \le V \le 156.825 \]

\[ 0 \le R, G, B \le 255 \]

YUV -> RGB への変換(スケーリング、オフセットあり)
  • UC8 -> UC8
  • UC8 -> DOUBLE

\begin{eqnarray*} \left( \begin{array}{l} R \\ G \\ B \\ 1 \\ \end{array} \right) &=& \left( \begin{array}{llll} +0.299000 & +0.587000 & +0.114000 & 0.000000 \\ -0.168385 & -0.331042 & +0.500573 & 127.353952 \\ +0.500000 & -0.418699 & -0.081301 & 127.500000 \\ +0.000000 & +0.000000 & +0.000000 & +1.000000 \\ \end{array} \right)^{-1} \left( \begin{array}{l} Y \\ U \\ V \\ 1 \\ \end{array} \right) \\ &=& \left( \begin{array}{llll} +1.000000 & -0.000034 & +1.401989 & -178.749237 \\ +1.000394 & -0.343796 & -0.714016 & +134.820834 \\ +0.997971 & +1.770337 & -0.000590 & -225.384277 \\ +0.000000 & +0.000000 & +0.000000 & +1.000000 \\ \end{array} \right) \left( \begin{array}{l} Y \\ U \\ V \\ 1 \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le Y, U, V \le 255 \]

\[ 0 \le R, G, B \le 255 \]

YUV -> YUV への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
変換後のYUV色空間を(Y',U',V') とします。 なお、変換には fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} Y' \\ U' \\ V' \\ \end{array} \right) = \left( \begin{array}{l} Y \\ U \\ V \\ \end{array} \right) \\ \]

変換の画素タイプがDOUBLE -> DOUBLEの場合は、

\[ 0 \le Y \le 255 \]

\[ -111.18 \le U \le 111.435 \]

\[ -156.825 \le V \le 156.825 \]

\[ 0 \le Y' \le 255 \]

\[ -111.18 \le U' \le 111.435 \]

\[ -156.825 \le V' \le 156.825 \]

変換の画素タイプがUC8 -> UC8の場合は、

\[ 0 \le Y, U, V \le 255 \]

\[ 0 \le Y', U', V' \le 255 \]

となります。

YUV -> YUV への変換(スケーリングあり、オフセットあり)
  • DOUBLE -> UC8
変換後のYUV色空間を(Y',U',V')とします。 そして、 $ 0 \le Y', U', V' \le 255 $ とするためのスケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{222.615000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{313.650000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \\ +0.000000 & +1.145475 & +0.000000 \\ +0.000000 & +0.000000 & +0.813008 \\ \end{array} \right) \end{eqnarray*}

\begin{eqnarray*} T &=& \left( \begin{array}{l} +0.000000 \vspace{.5em} \\ +\dfrac{255.000000}{222.615000}\times 111.180000 \vspace{.5em} \\ +\dfrac{255.000000}{313.650000}\times 156.825000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.000000 \\ +127.353952 \\ +127.500000 \\ \end{array} \right) \\ \end{eqnarray*}

\[ \left( \begin{array}{l} Y' \\ U' \\ V' \\ \end{array} \right) = S \left( \begin{array}{l} Y \\ U \\ V \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} Y' \\ U' \\ V' \\ \end{array} \right) = \left( \begin{array}{llll} +1.000000 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +1.145475 & +0.000000 & +127.353952 \\ +0.000000 & +0.000000 & +0.813008 & +127.500000 \\ \end{array} \right) \left( \begin{array}{l} Y \\ U \\ V \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le Y \le 255 \]

\[ -111.18 \le U \le 111.435 \]

\[ -156.825 \le V \le 156.825 \]

\[ 0 \le Y', U', V' \le 255 \]

YUV -> YUV への変換(スケーリングあり、オフセットあり)
  • UC8 -> DOUBLE
変換後のYUV色空間を(Y',U',V')とします。 そして、 $ 0 \le Y' \le 255 $$ -111.18 \le U' \le 111.435 $$ -156.825 \le V' \le 156.825 $ とするためのスケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{222.615000}{255.0000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{313.650000}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \\ +0.000000 & +0.873000 & +0.000000 \\ +0.000000 & +0.000000 & +1.230000 \\ \end{array} \right) \\ \end{eqnarray*}

\[ T = \left( \begin{array}{l} +0.000000 \\ -111.180000 \\ -156.825000 \\ \end{array} \right) \\ \]

\[ \left( \begin{array}{l} Y' \\ U' \\ V' \\ \end{array} \right) = S \left( \begin{array}{l} Y \\ U \\ V \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} Y' \\ I' \\ V' \\ \end{array} \right) = \left( \begin{array}{llll} +1.000000 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +0.873000 & +0.000000 & -111.180000 \\ +0.000000 & +0.000000 & +1.230000 & -156.825000 \\ \end{array} \right) \left( \begin{array}{l} Y \\ U \\ V \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le Y, U, V \le 255 \]

\[ 0 \le Y' \le 255 \]

\[ -111.18 \le U' \le 111.435 \]

\[ -156.825 \le V' \le 156.825 \]

YIQ

YIQ(NTSC)は北アメリカでのTVの信号の規格です。 Y成分(輝度)についてはCIE1931XYZに従います。
Fig4にYIQ色空間を示します。 なお、出力画像オブジェクトの画素タイプがF_IMG_UC8などで、 スケーリング処理された場合は、Fig4と異なります。

color_convert_yiq.png

Fig4. YIQ色空間

RGB -> YIQ への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ \left( \begin{array}{l} Y \\ I \\ Q \\ \end{array} \right) = \left( \begin{array}{lll} +0.299000 & +0.587000 & +0.114000 \\ +0.596000 & -0.274000 & -0.322000 \\ +0.211000 & -0.523000 & +0.312000 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le Y \le 255 \]

\[ -151.98 \le I \le 151.98 \]

\[ -133.365 \le Q \le 133.365 \]

RGB -> YIQ への変換(スケーリング、オフセットあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
$ 0 \le Y, I, Q \le 255 $ とするためのスケーリング行列をS 、平行移動行列をTとします

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{303.960000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{266.730000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \\ +0.000000 & +0.838926 & +0.000000 \\ +0.000000 & +0.000000 & +0.956023 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} T &=& \left( \begin{array}{l} +0.000000 \vspace{.5em} \\ +\dfrac{255.000000}{303.960000}\times 151.980000 \vspace{.5em} \\ +\dfrac{255.000000}{266.730000}\times 133.365000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.000000 \\ +127.500000 \\ +127.500000 \\ \end{array} \right) \\ \end{eqnarray*}

YIQ色空間への変換行列をMとすると、以下の通りとなります。

\[ \left( \begin{array}{l} Y \\ I \\ Q \\ \end{array} \right) = SM \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} Y \\ I \\ Q \\ \end{array} \right) = \left( \begin{array}{llll} +0.299000 & +0.587000 & +0.114000 & 0.000000 \\ +0.500000 & -0.229866 & -0.270134 & 127.500000 \\ +0.201721 & -0.500000 & +0.298279 & 127.500000 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le Y, I, Q \le 255 \]

YIQ -> RGB への変換
  • DOUBLE -> DOUBLE
  • DOUBLE -> UC8

\begin{eqnarray*} \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) &=& \left( \begin{array}{lll} +0.299000 & +0.587000 & +0.114000 \\ -0.596000 & -0.274000 & -0.322000 \\ +0.211000 & -0.523000 & -0.312000 \\ \end{array} \right)^{-1} \left( \begin{array}{l} Y \\ I \\ Q \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1.000000 & +0.956171 & +0.621430 \\ +1.000000 & -0.272689 & -0.646813 \\ +1.000000 & -1.103744 & +1.700623 \\ \end{array} \right) \left( \begin{array}{l} Y \\ I \\ Q \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le Y \le 255 \]

\[ -151.98 \le I \le 151.98 \]

\[ -133.365 \le Q \le 133.365 \]

\[ 0 \le R, G, B \le 255 \]

YIQ -> RGB への変換(スケーリング、オフセットあり)
  • UC8 -> UC8
  • UC8 -> DOUBLE

\begin{eqnarray*} \left( \begin{array}{l} R \\ G \\ B \\ 1 \\ \end{array} \right) &=& \left( \begin{array}{llll} +0.299000 & +0.587000 & +0.114000 & 0.000000 \\ +0.500000 & -0.229866 & -0.270134 & 127.500000 \\ +0.204721 & -0.500000 & +0.298279 & 127.500000 \\ +0.000000 & +0.000000 & +0.000000 & +1.000000 \\ \end{array} \right)^{-1} \left( \begin{array}{l} Y \\ I \\ Q \\ 1 \\ \end{array} \right) \\ &=& \left( \begin{array}{llll} +1.000000 & +1.139756 & +0.650018 & -228.196109 \\ +1.000000 & -0.325045 & -0.676567 & +127.705429 \\ +1.000000 & -1.135664 & +1.778853 & -59.056581 \\ +0.000000 & +0.000000 & +0.000000 & +1.000000 \\ \end{array} \right) \left( \begin{array}{l} Y \\ I \\ Q \\ 1 \\ \end{array} \right) \end{eqnarray*}

\[ 0 \le Y, I, Q \le 255 \]

\[ 0 \le R, G, B \le 255 \]

YIQ -> YIQ への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
変換後のYIQ色空間を(Y',I',Q')とします。 なお、変換には fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} Y' \\ I' \\ Q' \\ \end{array} \right) = \left( \begin{array}{l} Y \\ I \\ Q \\ \end{array} \right) \\ \]

変換の画素タイプがDOUBLE -> DOUBLEの場合は、

\[ 0 \le Y \le 255 \]

\[ -151.98 \le I \le 151.98 \]

\[ -133.365 \le Q \le 133.365 \]

\[ 0 \le Y' \le 255 \]

\[ -151.98 \le I' \le 151.98 \]

\[ -133.365 \le Q' \le 133.365 \]

変換の画素タイプがUC8 -> UC8の場合は、

\[ 0 \le Y, I, Q \le 255 \]

\[ 0 \le Y', I', Q' \le 255 \]

となります。

YIQ -> YIQ への変換(スケーリングあり、オフセットあり)
  • DOUBLE -> UC8
変換後のYIQ色空間(Y',I',Q')とします。 そして、 $ 0 \le Y', I', Q' \le 255 $ とするためのスケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{303.960000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{266.730000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \\ +0.000000 & +0.838926 & +0.000000 \\ +0.000000 & +0.000000 & +0.956023 \\ \end{array} \right) \end{eqnarray*}

\[ T = \left( \begin{array}{l} +0.0 \\ +127.5 \\ +127.5 \\ \end{array} \right) \\ \]

\[ \left( \begin{array}{l} Y' \\ I' \\ Q' \\ \end{array} \right) = S \left( \begin{array}{l} Y \\ I \\ Q \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} Y' \\ I' \\ Q' \\ \end{array} \right) = \left( \begin{array}{llll} +1.000000 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +0.838926 & +0.000000 & +127.500000 \\ +0.000000 & +0.000000 & +0.956023 & +127.500000 \\ \end{array} \right) \left( \begin{array}{l} Y \\ I \\ Q \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le Y \le 255 \]

\[ -151.98 \le I \le 151.98 \]

\[ -133.365 \le Q \le 133.365 \]

\[ 0 \le Y', I', Q' \le 255 \]

YIQ -> YIQ への変換(スケーリングあり、オフセットあり)
  • UC8 -> DOUBLE
変換後のYIQ色空間を(Y',I',Q')とします。 そして、 $ 0 \le Y' \le 255 $$ -151.98 \le I' \le 151.98 $$ -133.365 \le V' \le 133.365 $ とするためのスケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{303.960000}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{266.730000}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1.000000 & +0.000000 & +0.000000 \\ +0.000000 & +1.192000 & +0.000000 \\ +0.000000 & +0.000000 & +1.046000 \\ \end{array} \right) \\ \end{eqnarray*}

\[ T = \left( \begin{array}{l} +0.000000 \\ -151.980000 \\ -133.365000 \\ \end{array} \right) \\ \]

\[ \left( \begin{array}{l} Y' \\ I' \\ Q' \\ \end{array} \right) = S \left( \begin{array}{l} Y \\ I \\ Q \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} Y' \\ I' \\ Q' \\ \end{array} \right) = \left( \begin{array}{llll} +1.000000 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +1.192000 & +0.000000 & -151.980000 \\ +0.000000 & +0.000000 & +1.046000 & -133.365000 \\ \end{array} \right) \left( \begin{array}{l} Y \\ I \\ Q \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le Y \le 255 \]

\[ -151.98 \le I \le 151.98 \]

\[ -133.365 \le Q \le 133.365 \]

\[ 0 \le Y', I', Q' \le 255 \]

I1I2I3

RGB色空間はRGBの3値が互いに相関を持っているため情報の重複があると考えらます。 このRGBを無相関な3値に変換しようというのがI1I2I3色空間です。
Fig5にI1I2I3色空間を示します。

color_convert_i1i2i3.png

Fig5. I1I2I3色空間

RGB -> I1I2I3 への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ \end{array} \right) = \left( \begin{array}{lll} +\dfrac{1}{3} & +\dfrac{1}{3} & +\dfrac{1}{3} \vspace{.5em} \\ +\dfrac{1}{2} & +0 & -\dfrac{1}{2} \vspace{.5em} \\ -\dfrac{1}{4} & +\dfrac{1}{2} & -\dfrac{1}{4} \vspace{.5em} \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right)\\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le I1 \le 255 \]

\[ -127.5 \le I2, I3 \le 127.5 \]

RGB -> I1I2I3 への変換(オフセットあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
$ 0 \le I1', I2', I3' \le 255 $ とするための平行移動行列をT とします。

\[ T = \left( \begin{array}{l} +0 \vspace{.5em} \\ +\dfrac{255}{2} \vspace{.5em} \\ +\dfrac{255}{2} \vspace{.5em} \\ \end{array} \right) \\ \]

I1I2I3色空間への変換行列をMとすると、以下の通りとなります。

\[ \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ \end{array} \right) = M \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ \end{array} \right) = \left( \begin{array}{llll} +\dfrac{1}{3} & +\dfrac{1}{3} & +\dfrac{1}{3} & +0 \vspace{.5em} \\ +\dfrac{1}{2} & +0 & -\dfrac{1}{2} & +\dfrac{255}{2} \vspace{.5em} \\ -\dfrac{1}{4} & +\dfrac{1}{2} & -\dfrac{1}{4} & +\dfrac{255}{2} \vspace{.5em} \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ 1 \\ \end{array} \right)\\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le I1, I2, I3 \le 255 \]

I1I2I3 -> RGB への変換
  • DOUBLE -> DOUBLE
  • DOUBLE -> UC8

\begin{eqnarray*} \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) &=& \left( \begin{array}{lll} +\dfrac{1}{3} & +\dfrac{1}{3} & +\dfrac{1}{3} \vspace{.5em} \\ +\dfrac{1}{2} & +0 & -\dfrac{1}{2} \vspace{.5em} \\ -\dfrac{1}{4} & +\dfrac{1}{2} & -\dfrac{1}{4} \vspace{.5em} \\ \end{array} \right)^{-1} \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +1 & +1 & -\dfrac{2}{3} \vspace{.5em} \\ +1 & +0 & +\dfrac{4}{3} \vspace{.5em} \\ +1 & -1 & -\dfrac{2}{3} \vspace{.5em} \\ \end{array} \right) \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le I1 \le 255 \]

\[ -127.5 \le I2, I3 \le 127.5 \]

\[ 0 \le R, G, B \le 255 \]

I1I2I3 -> RGB への変換(オフセットあり)
  • UC8 -> UC8
  • UC8 -> DOUBLE

\begin{eqnarray*} \left( \begin{array}{l} R \\ G \\ B \\ 1 \\ \end{array} \right) &=& \left( \begin{array}{llll} +\dfrac{1}{3} & +\dfrac{1}{3} & +\dfrac{1}{3} & +0 \vspace{.5em} \\ +\dfrac{1}{2} & +0 & -\dfrac{1}{2} & +\dfrac{255}{2} \vspace{.5em} \\ -\dfrac{1}{4} & +\dfrac{1}{2} & -\dfrac{1}{4} & +\dfrac{255}{2} \vspace{.5em} \\ +0 & +0 & +0 & +1 \vspace{.5em} \\ \end{array} \right)^{-1} \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ 1 \\ \end{array} \right) \\ &=& \left( \begin{array}{llll} +1 & +1 & -\dfrac{2}{3} & -\dfrac{85}{2} \vspace{.5em} \\ +1 & +0 & +\dfrac{4}{3} & -170 \vspace{.5em} \\ +1 & -1 & -\dfrac{2}{3} & +\dfrac{425}{2} \vspace{.5em} \\ +0 & +0 & +0 & +1 \vspace{.5em} \\ \end{array} \right) \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ 1 \\ \end{array} \right) \end{eqnarray*}

\[ 0 \le I1, I2, I3 \le 255 \]

\[ 0 \le R, G, B \le 255 \]

I1I2I3 -> I1I2I3 への変換(オフセットなし)
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
変換後のI1I2I3色空間を(I1',I2',I3')とします。 なお、変換には fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} I1' \\ I2' \\ I3' \\ \end{array} \right) = \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ \end{array} \right) \\ \]

変換の画素タイプがDOUBLE -> DOUBLEの場合は、

\[ 0 \le I1 \le 255 \]

\[ -127.5 \le I2, I3 \le 127.5 \]

\[ 0 \le I1' \le 255 \]

\[ -127.5 \le I2', I3' \le 127.5 \]

変換の画素タイプがUC8 -> UC8の場合は、

\[ 0 \le I1, I2, I3 \le 255 \]

\[ 0 \le I1', I2', I3' \le 255 \]

となります。

I1I2I3 -> I1I2I3 への変換(オフセットあり)
  • DOUBLE -> UC8
変換後のI1I2I3色空間を(I1',I2',I3') とします。 そして、 $ 0 \le I1', I2', I3' \le 255 $ とするための平行移動行列をTとします。

\[ T = \left( \begin{array}{l} +0 \vspace{.5em} \\ +\dfrac{255}{2} \vspace{.5em} \\ +\dfrac{255}{2} \vspace{.5em} \\ \end{array} \right) \]

\[ \left( \begin{array}{l} I1' \\ I2' \\ I3' \\ \end{array} \right) = \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} I1' \\ I2' \\ I3' \\ \end{array} \right) = \left( \begin{array}{llll} +1 & +0 & +0 & +0 \vspace{.5em} \\ +0 & +1 & +0 & +\dfrac{255}{2} \vspace{.5em} \\ +0 & +0 & +1 & +\dfrac{255}{2} \vspace{.5em} \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le I1 \le 255 \]

\[ -127.5 \le I2, I3 \le 127.5 \]

\[ 0 \le I1', I2', I3' \le 255 \]

I1I2I3 -> I1I2I3 への変換(オフセットあり)
  • UC8 -> DOUBLE
変換後のI1I2I3色空間を(I1',I2',I3')とします。 そして、 $ -127.5 \le I1', I2', I3' \le 127.5 $ とするための平行移動行列をTとします。

\begin{eqnarray*} T &=& \left( \begin{array}{l} +0 \vspace{.5em} \\ -\dfrac{255}{2} \vspace{.5em} \\ -\dfrac{255}{2} \vspace{.5em} \\ \end{array} \right) \left( \begin{array}{l} I1' \\ I2' \\ I3' \\ \end{array} \right) \\ &=& \left( \begin{array}{l} I1 \\ I2 \\ I3 \\ \end{array} \right) + T \end{eqnarray*}

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} I1' \\ I2' \\ I3' \\ \end{array} \right) = \left( \begin{array}{llll} +1 & +0 & +0 & +0 \vspace{.5em} \\ +0 & +1 & +0 & -\dfrac{255}{2} \vspace{.5em} \\ +0 & +0 & +1 & -\dfrac{255}{2} \vspace{.5em} \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le I1, I2, I3 \le 255 \]

\[ 0 \le I1' \le 255 \]

\[ -127.5 \le I2', I3' \le 127.5 \]

HSV(Smithの六角錐モデル)

RGB色空間では、人間の感覚に合った色彩に関する処理を行うことは難しいです。 そこで、直感的にわかりやすいマンセル表色系に近い色相、彩度、明度の三属性からなる色空間です。 HSV色空間には、いくつかのモデルが存在します。 ここでは、Smithの六角錐モデルを示します。
Fig6にHSV(Smithの六角錐モデル)色空間を示します。 なお、出力画像オブジェクトの画素タイプがF_IMG_UC8などで、 スケーリング処理された場合は、Fig6と異なります。

color_convert_hsv_smith.png

Fig6. HSV(Smithの六角錐モデル)色空間

RGB -> HSV への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ H=\left \{ \begin{array}{ll} \dfrac{\pi}{3}(b -g) & \mbox{if}\ R = \max \left\{ R, G, B \right\} \vspace{.5em} \\ \dfrac{\pi}{3}(2 + r - b) & \mbox{if}\ G = \max \left\{ R, G, B \right\} \vspace{.5em} \\ \dfrac{\pi}{3}(4 + g - r) & \mbox{if}\ B = \max \left\{ R, G, B \right\} \vspace{.5em} \\ \end{array} \right. \]

\[ S=\frac{\max \left\{ R, G, B \right\} - \min \left\{ R, G, B \right\}}{\max \left\{ R, G, B \right\}} \]

\[ V=\frac{\max \left\{ R, G, B \right\}}{255} \]

ここで、

\[ r=\frac{\max \left\{ R, G, B \right\} - R}{\max \left\{ R, G, B \right\} - \min \left\{ R, G, B \right\}} \]

\[ g=\frac{\max \left\{ R, G, B \right\} - G}{\max \left\{ R, G, B \right\} - \min \left\{ R, G, B \right\}} \]

\[ b=\frac{\max \left\{ R, G, B \right\} - B}{\max \left\{ R, G, B \right\} - \min \left\{ R, G, B \right\}} \]

$H<0$ のとき、 $H$$2\pi$ を加えます。 $\max \left\{ R, G, B \right\}=0$ のとき
$S=0,H=$不定となります。
ただし、本ライブラリでは、 $H=$ 不定の場合、 $H=0$ とします。

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

RGB -> HSV への変換(スケーリングあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
先に求められたH, S, Vが、 $ 0 \le H, S, V \le 255 $ となるようにスケーリング処理をします。 変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{255.000000}{2\pi} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +255.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +255.000000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +255.000000 & +0.000000 \\ +0.000000 & +0.000000 & +255.000000 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +255.000000 & +0.000000 \\ +0.000000 & +0.000000 & +255.000000 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

\[ 0 \le H', S', V' \le 255 \]

HSV -> RGB への変換
  • DOUBLE -> DOUBLE
  • DOUBLE -> UC8

\[ H'=\frac{H}{\pi/3} \]

\[ h=floor\left( H' \right) \]

\[ V' = V \times 255 \]

\[ P=V'\times \left(1 - S\right) \]

\[ Q=V'\times \left\{1 - S\times \left(H' - h\right)\right\} \]

\[ T=V'\times \left\{1 - S\times \left(1 - H' + h\right)\right\} \]

$h=0$ のとき

\[ R = V',\qquad G = T,\qquad B = P \]

$h=1$ のとき

\[ R = Q,\qquad G = V',\qquad B = P \]

$h=2$ のとき

\[ R = P,\qquad G = V',\qquad B = T \]

$h=3$ のとき

\[ R = P,\qquad G = Q,\qquad B = V' \]

$h=4$ のとき

\[ R = T,\qquad G = P,\qquad B = V' \]

$h=5$ のとき

\[ R = V',\qquad G = P,\qquad B = Q \]

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

\[ 0 \le R, G, B \le 255 \]

HSV -> RGB への変換(スケーリングあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
まず、与えられたH,S,Vを $ 0 \le H \le 2\pi $$ 0 \le S, V \le 1 $ となるようにスケーリング処理をします。 変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{2\pi}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{1.000000}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{1.000000}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.003922 & +0.000000 \\ +0.000000 & +0.000000 & +0.003922 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.003922 & +0.000000 \\ +0.000000 & +0.000000 & +0.003922 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H, S, V \le 255 \]

\[ 0 \le H' \le 2\pi \]

\[ 0 \le S', V' \le 1 \]

以後の計算は、スケーリングがない場合と同様です。

HSV -> HSV への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
変換後のHSV色空間を(H',S',V')とします。 なお、変換には fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) = \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \]

変換の画素タイプがDOUBLE -> DOUBLEの場合は、

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

\[ 0 \le H' \le 2\pi \]

\[ 0 \le S', V' \le 1 \]

変換の画素タイプがUC8 -> UC8の場合は、

\[ 0 \le H, S, V \le 255 \]

\[ 0 \le H', S', V' \le 255 \]

となります

HSV -> HSV への変換(スケーリングあり)
  • DOUBLE -> UC8
変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{255.000000}{2\pi} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +255.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +255.000000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +255.000000 & +0.000000 \\ +0.000000 & +0.000000 & +255.000000 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +255.000000 & +0.000000 \\ +0.000000 & +0.000000 & +255.000000 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

\[ 0 \le H', S', V' \le 255 \]

HSV -> HSV への変換(スケーリングあり)
  • UC8 -> DOUBLE
変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{2\pi}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{1.000000}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{1.000000}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.003922 & +0.000000 \\ +0.000000 & +0.000000 & +0.003922 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.003922 & +0.000000 \\ +0.000000 & +0.000000 & +0.003922 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H, S, V \le 255 \]

\[ 0 \le H' \le 2\pi \]

\[ 0 \le S', V' \le 1 \]

HSV(Jobloveらの双六角錐モデル)

双六角錐モデルは、Smithの六角錐モデルをより精密にしたもので、デザイン分野で利用されるオストワルト表色系に近いモデルです。
Fig7にHSV(Jobloveらの双六角錐モデル)色空間を示します。 なお、出力画像オブジェクトの画素タイプがF_IMG_UC8などで、 スケーリング処理された場合は、Fig7と異なります。 Fig7のHueはH、DiffはS、SumはVを表しています。

color_convert_hsv_joblove.png

Fig7. HSV(Jobloveらの双六角錐モデル)色空間

RGB -> HSV への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ H=\left \{ \begin{array}{ll} \dfrac{\pi}{3}(b - g) & \mbox{if}\ R = \max \left\{ R, G, B \right\} \vspace{.5em} \\ \dfrac{\pi}{3}(2 + r - b) & \mbox{if}\ G = \max \left\{ R, G, B \right\} \vspace{.5em} \\ \dfrac{\pi}{3}(4 + g - r) & \mbox{if}\ B = \max \left\{ R, G, B \right\} \vspace{.5em} \\ \end{array} \right. \]

\[ S=\left \{ \begin{array}{ll} \dfrac{\max \left\{ R, G, B \right\} - \min \left\{ R, G, B \right\}}{\max \left\{ R, G, B \right\} + \min \left\{ R, G, B \right\}} & \mbox{if}\ V\le 0.5 \vspace{.5em} \\ \dfrac{\max \left\{ R, G, B \right\} - \min \left\{ R, G, B \right\}}{(2\times 255) - \max \left\{ R, G, B \right\} - \min \left\{ R, G, B \right\}} & \mbox{if}\ otherwise \vspace{.5em} \\ \end{array} \right.\]

\[ V=\frac{\max \left\{ R, G, B \right\} + \min \left\{ R, G, B \right\}}{2\times 255} \]

$r, g, b$ は、Smithの六角錐モデルと同定義です。
$H<0$ のとき、 $H$$2\pi$ を加えます。
$\max \left\{ R, G, B \right\}=0$ のとき
$S=0,H=$不定となります。
ただし、本ライブラリでは、 $H=$ 不定の場合、 $H=0$ とします。

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

RGB -> HSV への変換(スケーリングあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
先に求められたH, S, Vが、 $ 0 \le H, S, V \le 255 $ となるようにスケーリング処理をします。 変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{255.000000}{2\pi} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +255.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +255.000000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +255.000000 & +0.000000 \\ +0.000000 & +0.000000 & +255.000000 \\ \end{array} \right) \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +255.000000 & +0.000000 \\ +0.000000 & +0.000000 & +255.000000 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

\[ 0 \le H', S', V' \le 255 \]

HSV -> RGB への変換
  • DOUBLE -> DOUBLE
  • DOUBLE -> UC8

\[ R = X\qquad \left(h = H + \frac{2}{3} \pi\right) \]

\[ G = X\qquad \left(h = H\right) \]

\[ B = X\qquad \left(h = H - \frac{2}{3} \pi\right) \]

Xは必要に応じて以下の処理で求めます。

\[ h'=\left \{ \begin{array}{ll} h + 2\pi & \mbox{if}\ h<0 \\ h - 2\pi & \mbox{if}\ h>2\pi \\ h & \mbox{if}\ otherwise \\ \end{array} \right. \]

\[ M_{2}=\left \{ \begin{array}{ll} V\times \left(1 + S\right) & \mbox{if}\ V\le 0.5 \\ V + S - V\times S & \mbox{if}\ otherwise \\ \end{array} \right. \]

\[ M_{1}=2V - M_{2} \]

\[ X=\left \{ \begin{array}{ll} \dfrac{M_{1} + \left(M_{2} - M_{1}\right)\times h'}{\pi/3} & \mbox{if}\ h'<\dfrac{\pi}{3} \\ M_{2} & \mbox{if}\ \dfrac{\pi}{3} \le h' < \pi \vspace{.5em} \\ \dfrac{M_{1} + \left(M_{2} - M_{1}\right)\times \left(\dfrac{4}{3} \pi - h'\right)}{\pi/3} & \mbox{if}\ \pi \le h' < \dfrac{4}{3}\pi \vspace{.5em} \\ M_{1} & \mbox{if}\ \dfrac{4}{3}\pi \le h' < 2\pi \vspace{.5em} \\ \end{array} \right. \]

S=0のとき、

\[ R = G = B = V \]

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

\[ 0 \le R, G, B \le 255 \]

HSV -> RGB への変換(スケーリングあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
まず、与えられたH,S,Vを $ 0 \le H \le 2\pi $$ 0 \le S, V \le 1 $ となるようにスケーリング処理をします。 変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{2\pi}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{1.000000}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{1.000000}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.003922 & +0.000000 \\ +0.000000 & +0.000000 & +0.003922 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.003922 & +0.000000 \\ +0.000000 & +0.000000 & +0.003922 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H, S, V \le 255 \]

\[ 0 \le H' \le 2\pi \]

\[ 0 \le S', V' \le 1 \]

以後の計算は、スケーリングがない場合と同様です。

HSV -> HSV への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
変換後のHSV色空間を(H',S',V')とします。 なお、変換には fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) = \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \]

変換の画素タイプがDOUBLE -> DOUBLEの場合は、

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

\[ 0 \le H' \le 2\pi \]

\[ 0 \le S', V' \le 1 \]

変換の画素タイプがUC8 -> UC8の場合は、

\[ 0 \le H, S, V \le 255 \]

\[ 0 \le H', S', V' \le 255 \]

となります

HSV -> HSV への変換(スケーリングあり)
  • DOUBLE -> UC8
変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{255.000000}{2\pi} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +255.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +255.000000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +255.000000 & +0.000000 \\ +0.000000 & +0.000000 & +255.000000 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +255.000000 & +0.000000 \\ +0.000000 & +0.000000 & +255.000000 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H \le 2\pi \]

\[ 0 \le S, V \le 1 \]

\[ 0 \le H', S', V' \le 255 \]

HSV -> HSV への変換(スケーリングあり)
  • UC8 -> DOUBLE
変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{2\pi}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{1.000000}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{1.000000}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.003922 & +0.000000 \\ +0.000000 & +0.000000 & +0.003922 \\ \end{array} \right) \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.003922 & +0.000000 \\ +0.000000 & +0.000000 & +0.003922 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H, S, V \le 255 \]

\[ 0 \le H' \le 2\pi \]

\[ 0 \le S', V' \le 1 \]

L*a*b*

CIEが均等知覚色空間の標準化のために推奨した表色系です。 この表色系は、三刺激値X,Y,Zで均等色空間を近似することを目的に設計され、L*a*b* の直交座標系で定義されています。
ただし、RGBから L*a*b* 色空間変換で L*a*b* の画素タイプがF_IMG_UC8であった場合、 スケーリング、オフセット処理が施されるため、均等色空間としての意味を成しませんので注意してください。
Fig8に L*a*b* 色空間を示します。 なお、出力画像オブジェクトの画素タイプがF_IMG_UC8などで、 スケーリング処理された場合は、Fig8と異なります。

color_convert_lab.png

Fig8. L*a*b*色空間

RGB -> L*a*b* への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) = \left( \begin{array}{lll} +0.490001 & +0.309992 & +0.200007 \\ +0.176966 & +0.812398 & +0.010636 \\ +0.000000 & +0.009999 & +0.990001 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right)\\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le X, Y, Z \le 255 \]

\[ L^*=\left \{ \begin{array}{ll} 116\times \left(\dfrac{Y}{Y_{n}}\right)^{\dfrac{1}{3}} - 16 & \mbox{if}\ \dfrac{Y}{Y_{n}} > 0.008856 \vspace{.5em} \\ 116\times \left\{7.787\left(\dfrac{Y}{Y_{n}}\right) + \dfrac{16}{116}\right\} - 16\\ = 903.3\left(\dfrac{Y}{Y_{n}}\right) & \mbox{if}\ otherwise \vspace{.5em} \\ \end{array} \right. \]

※CIEが修正式を勧告しています。

\[ a^*=500\left\{f\left(\frac{X}{X_{n}}\right) - f\left(\frac{Y}{Y_{n}}\right)\right\} \]

\[ b^*=200\left\{f\left(\frac{Y}{Y_{n}}\right) - f\left(\frac{Z}{Z_{n}}\right)\right\} \]

関数 $f\left(\frac{X}{X_{n}}\right)$ は、以下の通りです。

\[ f\left(\frac{X}{X_{n}}\right)=\left \{ \begin{array}{ll} \left(\dfrac{X}{X_{n}}\right)^{\dfrac{1}{3}} & \mbox{if}\ \dfrac{X}{X_{n}} > 0.008856 \vspace{.5em} \\ 7.787\left(\dfrac{X}{X_{n}}\right) + \dfrac{16}{116} & \mbox{if}\ otherwise \vspace{.5em} \\ \end{array} \right. \]

$f\left(\frac{Y}{Y_{n}}\right)$$f\left(\frac{Z}{Z_{n}}\right)$ も同様です。
$X_{n}$$Y_{n}$$Z_{n}$ は、対象と同一照明下の標準白色に対する三刺激値です。 照明の種類毎に指定する必要となります。 ただし、本ライブラリでは照明の種類が特定できないため、 $X_{n}=Y_{n}=Z_{n}=255$ と定義します。

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le L^* \le 100 \]

\[ -128.152308 \le a^* \le 182.446523 \]

\[ -155.347701 \le b^* \le 156.201147 \]

RGB -> L*a*b* への変換(スケーリングあり、オフセットあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
本処理では、最終的に$ 0 \le L^{*},a^{*},b^{*} \le 255 $ となるため、一部の計算を省略可能となります。

\[ \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) = \left( \begin{array}{lll} +0.490001 & +0.309992 & +0.200007 \\ +0.176966 & +0.812398 & +0.010636 \\ +0.000000 & +0.009999 & +0.990001 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le X, Y, Z \le 255 \]

\[ L^{*}=f\left(\frac{Y}{Y_{n}}\right) \]

\[ a^{*}=f\left(\frac{X}{X_{n}}\right) - f\left(\frac{Y}{Y_{n}}\right) \]

\[ b^{*}=f\left(\frac{Y}{Y_{n}}\right) - f\left(\frac{Z}{Z_{n}}\right) \]

関数 $f\left(\frac{X}{X_{n}}\right)$ は、以下の通りです。

\[ f\left(\frac{X}{X_{n}}\right)=\left \{ \begin{array}{ll} \left(\dfrac{X}{X_{n}}\right)^{\dfrac{1}{3}} & \mbox{if}\ \dfrac{X}{X_{n}} > 0.008856 \vspace{.5em} \\ 7.787\left(\dfrac{X}{X_{n}}\right) + \dfrac{16}{116} & \mbox{if}\ otherwise \vspace{.5em} \\ \end{array} \right. \]

$f\left(\frac{Y}{Y_{n}}\right)$$f\left(\frac{Z}{Z_{n}}\right)$ も同様です。

$X_{n}$$Y_{n}$$Z_{n}$ は、対象と同一照明下の標準白色に対する三刺激値です。 照明の種類毎に指定する必要があります。 ただし、本ライブラリでは照明の種類が特定できないため、 $X_{n}=Y_{n}=Z_{n}=255$ と定義します。

\[ 0 \le R, G, B \le 255 \]

\[ 0.137931 \le L^{*} \le 1.00 \]

\[ -0.256305 \le a^{*} \le 0.364893 \]

\[ -0.776739 \le b^{*} \le 0.781006 \]

$ 0 \le L^{*},a^{*},b^{*} \le 255 $ とするためのスケーリング行列をS 、平行移動行列をTとします。 変換後の L*a*b* 色空間を $\left(\acute{L^{*}},\acute{a^{*}},\acute{b^{*}}\right) $ とします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +\dfrac{255.000000}{1.137931} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{0.621198} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{1.557745} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +295.799988 & +0.000000 & +0.000000 \\ +0.000000 & +410.497136 & +0.000000 \\ +0.000000 & +0.000000 & +163.698166 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} T &=& \left( \begin{array}{l} -\dfrac{255.000000}{1.137931}\times 0.137931 \vspace{.5em} \\ +\dfrac{255.000000}{0.621198}\times 0.256305 \vspace{.5em} \\ +\dfrac{255.000000}{1.557745}\times 0.776739 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} -30.909084 \\ +105.212468 \\ +127.150750 \\ \end{array} \right) \\ \end{eqnarray*}

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = S \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = \left( \begin{array}{llll} +295.799988 & +0.000000 & +0.000000 & -30.909084 \\ +0.000000 & +410.497136 & +0.000000 & +105.212468 \\ +0.000000 & +0.000000 & +163.698166 & +127.150750 \\ \end{array} \right) \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le L'^{*},a'^{*},b'^{*} \le 255 \]

L*a*b* -> RGB への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ x=\left \{ \begin{array}{ll} f_{x}^{3} & \mbox{if}\ f_{x}^{3} > 0.008856 \vspace{.5em} \\ \dfrac{116\times f_{x} - 16}{903.3} & \mbox{if}\ otherwise \vspace{.5em} \\ \end{array} \right. \]

\[ y=\left \{ \begin{array}{ll} \left\{\dfrac{L + 16}{116}\right\}^{3} & \mbox{if}\ L > 903.3\times 0.008856 \vspace{.5em} \\ \dfrac{L}{903.3} & \mbox{if}\ otherwise \vspace{.5em} \\ \end{array} \right. \]

\[ z=\left \{ \begin{array}{ll} f_{z}^{3} & \mbox{if}\ f_{z}^{3} > 0.008856 \vspace{.5em} \\ \dfrac{116\times f_{z} - 16}{903.3} & \mbox{if}\ otherwise \vspace{.5em} \\ \end{array} \right. \]

ここで、 $f_{x}$$ f_{y}$$f_{z}$は以下の通りです。

\[ f_{x} = f_{y} + \frac{a}{500} \]

\[ f_{y}=\left \{ \begin{array}{ll} \dfrac{L + 16}{116} & \mbox{if}\ y > 0.008856 \vspace{.5em} \\ \dfrac{903.3\times y + 16}{116} & \mbox{if}\ otherwise \vspace{.5em} \\ \end{array} \right. \]

\[ f_{z} = f_{y} + \frac{b}{200} \]

求められた $x$$y$$z$ より、 $X$$Y$$Z$ を求めます。

\[ X = x\times X_{n} \]

\[ Y = y\times Y_{n} \]

\[ Z = z\times Z_{n} \]

$X_{n}$$Y_{n}$$Z_{n}$ は、対象と同一照明下の標準白色に対する三刺激値です。 照明の種類毎に指定する必要があります。 ただし、本ライブラリでは照明の種類が特定できないため、 $X_{n}=Y_{n}=Z_{n}=255$ と定義します。

\[ \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) = \left( \begin{array}{lll} +2.364591 & -0.896501 & -0.468080 \\ -0.515151 & +1.426401 & +0.088750 \\ +0.005203 & -0.014407 & +1.009204 \\ \end{array} \right) \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right)\\ \]

\[ 0 \le X, Y, Z \le 255 \]

\[ 0 \le L^* \le 100 \]

\[ -128.152308 \le a^* \le 182.446523 \]

\[ -155.347701 \le b^* \le 156.201147 \]

\[ 0 \le R, G, B \le 255 \]

L*a*b* -> RGB への変換(スケーリングあり、オフセットあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
まず、与えられた L*a*b* を $ 0 \le L^{*} \le 100 $$ -128.152308 \le a^{*} \le 182.446523 $$ -155.347701 \le b^{*} \le 156.201147 $ となるようにスケーリング処理をします。 変換後の L*a*b* 色空間を $\left(\acute{L^{*}},\acute{a^{*}},\acute{b^{*}}\right)$ とします。 ここで、スケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +\dfrac{255.000000}{100.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{310.598831} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{311.548848} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +2.550000 & +0.000000 & +0.000000 \\ +0.000000 & +0.820995 & +0.000000 \\ +0.000000 & +0.000000 & +0.818491 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} T &=& \left( \begin{array}{l} +0.000000 \vspace{.5em} \\ +\dfrac{255.000000}{310.598831}\times 128.152308 \vspace{.5em} \\ +\dfrac{255.000000}{311.548848}\times 156.201147 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{l} +0.000000 \\ +105.212368 \\ +127.150731 \\ \end{array} \right) \\ \end{eqnarray*}

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = S \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = \left( \begin{array}{llll} +2.550000 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +0.820995 & +0.000000 & +105.212368 \\ +0.000000 & +0.000000 & +0.818491 & +127.150731 \\ \end{array} \right) \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le L^{*},a^{*},b^{*} \le 255 \]

\[ 0 \le \acute{L^{*}} \le 100 \]

\[ -128.152308 \le \acute{a^{*}} \le 182.446523 \]

\[ -155.347701 \le \acute{b^{*}} \le 156.201147 \]

以後の計算は、スケーリングなし、オフセットなしの場合と同様です。

L*a*b* -> L*a*b* への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
変換後の L*a*b* 色空間を $\left(\acute{L^{*}},\acute{a^{*}},\acute{b^{*}}\right)$ とします。 なお、変換には fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ \end{array} \right) \\ \]

変換の画素タイプがDOUBLE -> DOUBLE の場合は、

\[ 0 \le L^{*} \le 100 \]

\[ -128.152308 \le a^{*} \le 182.446523 \]

\[ -155.347701 \le b^{*} \le 156.201147 \]

\[ 0 \le \acute{L^{*}} \le 100 \]

\[ -128.152308 \le \acute{a^{*}} \le 182.446523 \]

\[ -155.347701 \le \acute{b^{*}} \le 156.201147 \]

変換の画素タイプが UC8 -> UC8 の場合は、

\[ 0 \le L^{*},a^{*},b^{*} \le 255 \]

\[ 0 \le \acute{L^{*}},\acute{a^{*}},\acute{b^{*}} \le 255 \]

となります

L*a*b* -> L*a*b* への変換(スケーリングあり、オフセットあり)
  • DOUBLE -> UC8
変換後の L*a*b* 色空間を $\left(\acute{L^{*}},\acute{a^{*}},\acute{b^{*}}\right)$ とします。 ここで、スケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +\dfrac{255.000000}{100.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{310.598831} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{311.548848} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +2.550000 & +0.000000 & +0.000000 \\ +0.000000 & +0.820995 & +0.000000 \\ +0.000000 & +0.000000 & +0.818491 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} T &=& \left( \begin{array}{l} +0.000000 \vspace{.5em} \\ +\dfrac{255.000000}{310.598831}\times 128.152308 \vspace{.5em} \\ +\dfrac{255.000000}{311.548848}\times 155.347701 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{l} +0.000000 \\ +105.212368 \\ +127.150731 \\ \end{array} \right) \\ \end{eqnarray*}

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = S \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = \left( \begin{array}{llll} +2.550000 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +0.820995 & +0.000000 & +105.212368 \\ +0.000000 & +0.000000 & +0.818491 & +127.150731 \\ \end{array} \right) \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le L^{*} \le 100 \]

\[ -128.152308 \le a^{*} \le 182.446523 \]

\[ -155.347701 \le b^{*} \le 156.201147 \]

\[ 0 \le \acute{L^{*}}, \acute{a^{*}}, \acute{b^{*}} \le 255 \]

L*a*b* -> L*a*b* への変換(スケーリングあり、オフセットあり)
  • UC8 -> DOUBLE
変換後の L*a*b* 色空間を $\left(\acute{L^{*}},\acute{a^{*}},\acute{b^{*}}\right)$ とします。 ここで、スケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +\dfrac{100.000000}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{310.598831}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{311.548848}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.392157 & +0.000000 & +0.000000 \\ +0.000000 & +1.218035 & +0.000000 \\ +0.000000 & +0.000000 & +1.221760 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} T &=& \left( \begin{array}{l} +0.000000 \\ -128.152308 \\ -155.347701 \\ \end{array} \right) \\ \end{eqnarray*}

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = S \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = \left( \begin{array}{llll} +0.392157 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +1.218035 & +0.000000 & -128.152308 \\ +0.000000 & +0.000000 & +1.221760 & -155.347701 \\ \end{array} \right) \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le L^{*},a^{*},b^{*} \le 255 \]

\[ 0 \le \acute{L^{*}} \le 100 \]

\[ -128.152308 \le \acute{a^{*}} \le 182.446523 \]

\[ -155.347701 \le \acute{b^{*}} \le 156.201147 \]

HSV(FAST独自仕様)

一般にはHLS色空間と呼ばれています。 上記のHSV色空間とは、彩度と輝度の考え方が異なります。
彩度は、純色から彩度が落ちることは、灰色になるという考えに基づいています。
輝度は輝度0を黒、100を白として、その中間を純色としています。 通常HSV色空間では、明度100を純色としています。
Fig9にYC1C2色空間、Fig10にHSV色空間を示します。 なお、出力画像オブジェクトの画素タイプがF_IMG_UC8などで、 スケーリング処理された場合は、Fig10と異なります。 本色空間では、RGBをまずYC1C2に変換後、HSVに変換します。 Fig9のCrはC1、CbはC2を表しています。

color_convert_ycc.png

Fig9. YC1C2色空間

color_convert_hls.png

Fig10. HSV(FAST独自仕様)色空間

RGB -> HSV への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE

\[ \left( \begin{array}{l} Y \\ C1 \\ C2 \\ \end{array} \right) = \left( \begin{array}{lll} +0.299000 & +0.587000 & +0.114000 \\ +0.701000 & -0.587000 & -0.114000 \\ -0.299000 & -0.587000 & +0.886000 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right)\\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le Y \le 255 \]

\[ -127.5 \le C1, C2 \le 127.5 \]

求められた $ Y,C1,C2 $ より、 $ H,S,V $ が求められます。

\[ H=\arctan \left(\frac{C1}{C2}\right) \]

\[ S=\sqrt{C1^{2}+C2^{2}} \]

\[ V=Y \]

\[ -\pi \le H \le \pi \]

\[ 0 \le S \le 227.792515 \]

\[ 0 \le V \le 225 \]

RGB -> HSV への変換(スケーリングあり、オフセットあり)
  • UC8 -> UC8
  • DOUBLE -> UC8
先で求められたH, S, Vが、 $ 0 \le H, S, V \le 255 $ となるようにスケーリング処理をします。 変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{255.000000}{2\pi} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{227.792515} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +1.000000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +1.119440 & +0.000000 \\ +0.000000 & +0.000000 & +1.000000 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +1.119440 & +0.000000 \\ +0.000000 & +0.000000 & +1.000000 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

HSV -> RGB
  • UC8 -> UC8
  • UC8 -> DOUBLE

\[ Y = V \]

\[ C1 = S\times \sin \left(H\right) \]

\[ C2 = S\times \cos \left(H\right) \]

\[ -\pi \le H \le \pi \]

\[ 0 \le S \le 227.792515 \]

\[ 0 \le V \le 225 \]

\[ 0 \le Y \le 255 \]

\[ -127.5 \le C1, C2 \le 127.5 \]

\[ \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) = \left( \begin{array}{lll} +1.000000 & +1.000000 & +0.000000 \\ +1.000000 & -0.509370 & -0.194208 \\ +1.000000 & +0.000000 & +1.000000 \\ \end{array} \right) \left( \begin{array}{l} Y \\ C1 \\ C2 \\ \end{array} \right) \\ \]

\[ 0 \le Y \le 255 \]

\[ -127.5 \le C1, C2 \le 127.5 \]

\[ 0 \le R, G, B \le 255 \]

HSV -> RGB への変換(スケーリングあり)
  • UC8 -> UC8
  • UC8 -> DOUBLE
まず、与えられたH,S,Vを $ -\pi \le H \le \pi $$ 0 \le S, V \le 1 $ となるようにスケーリング処理をします。 変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{2\pi}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{227.792515}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +1.000000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.893304 & +0.000000 \\ +0.000000 & +0.000000 & +0.100000 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.893304 & +0.000000 \\ +0.000000 & +0.000000 & +0.100000 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

\[ 0 \le H, S, V \le 255 \]

\[ -\pi \le H' \le \pi \]

\[ 0 \le S' \le 227.792515 \]

\[ 0 \le V' \le 225 \]

以後の計算は、スケーリングなしと同様です。

HSV -> HSV への変換
  • DOUBLE -> DOUBLE
  • UC8 -> UC8
変換後のHSV色空間を(H',S',V')とします。 なお、変換には fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) = \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \]

変換の画素タイプが DOUBLE -> DOUBLE の場合は、

\[ -\pi \le H \le \pi \]

\[ 0 \le S \le 227.792515 \]

\[ 0 \le V \le 255 \]

\[ -\pi \le H' \le \pi \]

\[ 0 \le S' \le 227.792515 \]

\[ 0 \le V' \le 255 \]

変換の画素タイプが UC8 -> UC8 の場合は、

\[ 0 \le H, S, V \le 255 \]

\[ 0 \le H', S', V' \le 255 \]

となります

HSV -> HSV への変換(スケーリングあり)
  • DOUBLE -> UC8
変換後のHSV色空間を(H',S',V') とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{255.000000}{2\pi} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{227.792515} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +1.000000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +1.119440 & +0.000000 \\ +0.000000 & +0.000000 & +1.000000 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.584510 & +0.000000 & +0.000000 \\ +0.000000 & +1.119440 & +0.000000 \\ +0.000000 & +0.000000 & +1.000000 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

ただし、 $H'<0$ ならば $ H' \gets H' + 255 $

\[ -\pi \le H \le \pi \]

\[ 0 \le S \le 227.792515 \]

\[ 0 \le V \le 255 \]

\[ 0 \le H', S', V' \le 255 \]

HSV -> HSV への変換(スケーリングあり)
  • UC8 -> DOUBLE
変換後のHSV色空間を(H',S',V')とします。 ここで、スケーリング行列を SCALE とします。

\begin{eqnarray*} SCALE &=& \left( \begin{array}{lll} +\dfrac{2\pi}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{227.792515}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +1.000000 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.893304 & +0.000000 \\ +0.000000 & +0.000000 & +0.100000 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} \left( \begin{array}{l} H' \\ S' \\ V' \\ \end{array} \right) &=& SCALE \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024640 & +0.000000 & +0.000000 \\ +0.000000 & +0.893304 & +0.000000 \\ +0.000000 & +0.000000 & +0.100000 \\ \end{array} \right) \left( \begin{array}{l} H \\ S \\ V \\ \end{array} \right) \\ \end{eqnarray*}

ただし、 $H' > \pi$ ならば $ H' \gets H' - 2\pi $

\[ 0 \le H, S, V \le 255 \]

\[ -\pi \le H' \le \pi \]

\[ 0 \le S' \le 227.792515 \]

\[ 0 \le V' \le 255 \]

L*a*b*(FAST独自仕様)

本変換では、処理の高速化のため、一部の変換式を省略して処理が行われています。 また、上記した本ライブラリでの L*a*b* 色空間の変換とは異なり、 RGBから L*a*b* 色空間変換で L*a*b* の画素タイプがF_IMG_UC8であった場合のみではなく、 全ての変換で、等色空間としての意味を成しませんので注意してください。
本色空間は、上記した L*a*b* の各成分をスケーリング変換したものとほぼ同等です。 前述したように、一部の変換式を省略して処理が行われているために、完全には一致しません。

RGB -> L*a*b* 、L*a*b* -> RGB 共に、画素タイプがUC8 -> UC8の変換では、数値テーブルを利用します。

RGB -> L*a*b* への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE
  • UC8 -> UC8
  • DOUBLE -> UC8

\[ \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) = \left( \begin{array}{lll} +0.501053 & +0.314737 & +0.184211 \\ +0.262000 & +0.656000 & +0.082000 \\ +0.018349 & +0.147706 & +0.833945 \\ \end{array} \right) \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) \\ \]

\[ 0 \le R, G, B \le 255 \]

\[ 0 \le X, Y, Z \le 255 \]

\[ L^{*}=\sqrt[3]{Y} \]

\[ a^{*}=\sqrt[3]{X} - \sqrt[3]{Y} \]

\[ b^{*}=\sqrt[3]{Y} - \sqrt[3]{Z} \]

\[ 0 < L^{*} < 6.341326 \]

\[ -1.196460 < a^{*} < 1.147458 \]

\[ -3.213898 < b^{*} < 2.677538 \]

変換後の L*a*b* 色空間を $\left(\acute{L^{*}},\acute{a^{*}},\acute{b^{*}}\right)$ とします。 ここで、スケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +\dfrac{255.000000}{6.341326} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{255.000000}{2.343919} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{255.000000}{5.891436} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +40.212410 & +0.000000 & +0.000000 \\ +0.000000 & +108.792155 & +0.000000 \\ +0.000000 & +0.000000 & +43.283166 \\ \end{array} \right) \\ \end{eqnarray*}

\begin{eqnarray*} T &=& \left( \begin{array}{l} +0.000000 \vspace{.5em} \\ +\dfrac{255.000000}{2.343919}\times 1.196459 \vspace{.5em} \\ +\dfrac{255.000000}{5.891436}\times 3.213898 \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.000000\\ +130.165353 \\ +139.107679 \\ \end{array} \right) \\ \end{eqnarray*}

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = S \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = \left( \begin{array}{llll} +40.212410 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +108.792155 & +0.000000 & +130.165353 \\ +0.000000 & +0.000000 & +43.283166 & +139.107679 \\ \end{array} \right) \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le L^{*},a^{*},b^{*} \le 255 \]

L*a*b* -> RGB への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE
  • UC8 -> UC8
  • DOUBLE -> UC8
まず、与えられた L*a*b* を $ 0 \le L^{*} \le 6.431326 $$ -1.196459 \le a^{*} \le 1.147460 $$ -3.213898 \le b^{*} \le 2.677538 $ となるようにスケーリング処理をします。 変換後の L*a*b* 色空間を $\left(\acute{L^{*}},\acute{a^{*}},\acute{b^{*}}\right)$ とします。 ここで、スケーリング行列をS、平行移動行列をTとします。

\begin{eqnarray*} S &=& \left( \begin{array}{lll} +\dfrac{6.341326}{255.000000} & +0.000000 & +0.000000 \vspace{.5em} \\ +0.000000 & +\dfrac{2.343919}{255.000000} & +0.000000 \vspace{.5em} \\ +0.000000 & +0.000000 & +\dfrac{5.891436}{255.000000} \vspace{.5em} \\ \end{array} \right) \\ &=& \left( \begin{array}{lll} +0.024868 & +0.000000 & +0.000000 \\ +0.000000 & +0.009192 & +0.000000 \\ +0.000000 & +0.000000 & +0.023104 \\ \end{array} \right) \\ \end{eqnarray*}

\[ T = \left( \begin{array}{l} +0.000000 \\ +1.196459 \\ +3.213898 \\ \end{array} \right) \\ \]

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = S \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ \end{array} \right) + T \]

ここで、上式を斉次座標を用いて表します。

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = \left( \begin{array}{llll} +0.024868 & +0.000000 & +0.000000 & +0.000000 \\ +0.000000 & +0.009192 & +0.000000 & +1.196459 \\ +0.000000 & +0.000000 & +0.023104 & +3.213898 \\ \end{array} \right) \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ 1 \\ \end{array} \right) \\ \]

\[ 0 \le L^{*},a^{*},b^{*} \le 255 \]

\[ 0 < \acute{L^{*}} < 6.341326 \]

\[ -1.196460 < \acute{a^{*}} < 1.147458 \]

\[ -3.213898 < \acute{b^{*}} < 2.677538 \]

\[ X = \left(\acute{L^{*3}} + \acute{a^{*3}}\right)^{3} \]

\[ Y = \acute{L^{*3}} \]

\[ Z = \left(\acute{L^{*3}} - \acute{b^{*3}}\right)^{3} \]

\[ 0 \le X \le 242.25 \]

\[ 0 \le Y \le 255 \]

\[ 0 \le Z \le 277.95 \]

\[ \left( \begin{array}{l} R \\ G \\ B \\ \end{array} \right) = \left( \begin{array}{lll} +2.613898 & -1.149547 & -0.464354 \\ -1.060250 & +2.025183 & +0.035068 \\ +0.130276 & -0.333402 & +1.203126 \\ \end{array} \right) \left( \begin{array}{l} X \\ Y \\ Z \\ \end{array} \right) \\ \]

\[ 0 \le L^{*},a^{*},b^{*} \le 255 \]

\[ 0 \le R, G, B \le 255 \]

L*a*b* -> L*a*b* への変換
  • DOUBLE -> DOUBLE
  • UC8 -> DOUBLE
  • UC8 -> UC8
  • DOUBLE -> UC8
変換後のL*a*b* 色空間を$\left(\acute{L^{*}},\acute{a^{*}},\acute{b^{*}}\right)$ とします。 なお、DOUBLE -> DOUBLE 、UC8 -> UC8 の同一の画素タイプへの変換には、 fnFIE_img_copy() を使用しています。

\[ \left( \begin{array}{l} \acute{L^{*}} \\ \acute{a^{*}} \\ \acute{b^{*}} \\ \end{array} \right) = \left( \begin{array}{l} L^{*} \\ a^{*} \\ b^{*} \\ \end{array} \right) \\ \]

\[ 0 \le L^{*},a^{*},b^{*} \le 255 \]

\[ 0 \le \acute{L^{*}},\acute{a^{*}},\acute{b^{*}} \le 255 \]



Documentation copyright © 2009-2023 FAST Corporation.
Generated on Sat Oct 28 09:27:57 2023 for FIEライブラリ by doxygen 1.5.6-FASTSP-p2